apps/core/preloaded/quickpanel base 09/67209/1 submit/tizen/20160426.005901
authorjin0.kim <jin0.kim@samsung.com>
Tue, 26 Apr 2016 00:53:28 +0000 (09:23 +0830)
committerjin0.kim <jin0.kim@samsung.com>
Tue, 26 Apr 2016 00:54:00 +0000 (09:24 +0830)
Change-Id: Ib84dba03ee41a17e31691d84fc1f43feeb034cf4

533 files changed:
AUTHORS [new file with mode: 0644]
CMakeLists.txt [new file with mode: 0755]
LICENSE [new file with mode: 0644]
NOTICE [new file with mode: 0644]
daemon/accessibility.c [new file with mode: 0755]
daemon/accessibility.h [new file with mode: 0755]
daemon/common.c [new file with mode: 0755]
daemon/common.h [new file with mode: 0755]
daemon/common_uic.c [new file with mode: 0755]
daemon/common_uic.h [new file with mode: 0755]
daemon/datetime/datetime.c [new file with mode: 0755]
daemon/datetime/datetime.h [new file with mode: 0755]
daemon/datetime/util-time.c [new file with mode: 0755]
daemon/datetime/util-time.h [new file with mode: 0755]
daemon/device/brightness.c [new file with mode: 0755]
daemon/handler_controller.c [new file with mode: 0755]
daemon/handler_controller.h [new file with mode: 0755]
daemon/list_util.c [new file with mode: 0755]
daemon/list_util.h [new file with mode: 0755]
daemon/media.c [new file with mode: 0755]
daemon/media.h [new file with mode: 0755]
daemon/minictrl/minictrl.c [new file with mode: 0755]
daemon/minictrl/minictrl.h [new file with mode: 0755]
daemon/modules.c [new file with mode: 0755]
daemon/modules.h [new file with mode: 0755]
daemon/notifications/activenoti.c [new file with mode: 0755]
daemon/notifications/animated_image.c [new file with mode: 0755]
daemon/notifications/animated_image.h [new file with mode: 0755]
daemon/notifications/noti.c [new file with mode: 0755]
daemon/notifications/noti.h [new file with mode: 0755]
daemon/notifications/noti_list_item.c [new file with mode: 0755]
daemon/notifications/noti_list_item.h [new file with mode: 0755]
daemon/notifications/noti_listbox.c [new file with mode: 0755]
daemon/notifications/noti_listbox.h [new file with mode: 0755]
daemon/notifications/noti_node.c [new file with mode: 0755]
daemon/notifications/noti_node.h [new file with mode: 0755]
daemon/notifications/noti_section.c [new file with mode: 0755]
daemon/notifications/noti_section.h [new file with mode: 0755]
daemon/notifications/noti_util.c [new file with mode: 0755]
daemon/notifications/noti_util.h [new file with mode: 0755]
daemon/notifications/noti_view.c [new file with mode: 0755]
daemon/notifications/noti_view.h [new file with mode: 0755]
daemon/notifications/noti_view_listype.c [new file with mode: 0755]
daemon/notifications/noti_view_ongoing.c [new file with mode: 0755]
daemon/notifications/noti_win.c [new file with mode: 0755]
daemon/notifications/noti_win.h [new file with mode: 0755]
daemon/page/page_base.c [new file with mode: 0755]
daemon/page/page_base.h [new file with mode: 0755]
daemon/page/page_edit.c [new file with mode: 0755]
daemon/page/page_edit.h [new file with mode: 0755]
daemon/page/page_setting_all.c [new file with mode: 0755]
daemon/page/page_setting_all.h [new file with mode: 0755]
daemon/page/pager.c [new file with mode: 0755]
daemon/page/pager.h [new file with mode: 0755]
daemon/page/pager_common.c [new file with mode: 0755]
daemon/page/pager_common.h [new file with mode: 0755]
daemon/preference.c [new file with mode: 0755]
daemon/preference.h [new file with mode: 0755]
daemon/quickpanel-ui.c [new file with mode: 0755]
daemon/quickpanel-ui.h [new file with mode: 0755]
daemon/service/animated_icon.c [new file with mode: 0755]
daemon/service/animated_icon.h [new file with mode: 0755]
daemon/service/emergency_mode.c [new file with mode: 0755]
daemon/service/emergency_mode.h [new file with mode: 0755]
daemon/service/keyboard.c [new file with mode: 0755]
daemon/service/keyboard.h [new file with mode: 0755]
daemon/service/noti_led.c [new file with mode: 0755]
daemon/service/noti_led.h [new file with mode: 0755]
daemon/service/reminder.c [new file with mode: 0755]
daemon/service/reminder.h [new file with mode: 0755]
daemon/service/uninstall.c [new file with mode: 0755]
daemon/service/uninstall.h [new file with mode: 0755]
daemon/settings/modules/bluetooth.c [new file with mode: 0755]
daemon/settings/modules/gps.c [new file with mode: 0755]
daemon/settings/modules/rotate-lock.c [new file with mode: 0755]
daemon/settings/modules/sound-profile.c [new file with mode: 0755]
daemon/settings/modules/wifi.c [new file with mode: 0755]
daemon/settings/setting_module_api.c [new file with mode: 0755]
daemon/settings/setting_module_api.h [new file with mode: 0755]
daemon/settings/setting_utils.c [new file with mode: 0755]
daemon/settings/setting_utils.h [new file with mode: 0755]
daemon/settings/settings.c [new file with mode: 0755]
daemon/settings/settings.h [new file with mode: 0755]
daemon/settings/settings_gridbox.c [new file with mode: 0755]
daemon/settings/settings_gridbox.h [new file with mode: 0755]
daemon/settings/settings_icon_common.c [new file with mode: 0755]
daemon/settings/settings_icon_common.h [new file with mode: 0755]
daemon/settings/settings_ipc.c [new file with mode: 0755]
daemon/settings/settings_ipc.h [new file with mode: 0755]
daemon/settings/settings_view_all.c [new file with mode: 0755]
daemon/settings/settings_view_all.h [new file with mode: 0755]
daemon/settings/settings_view_featured.c [new file with mode: 0755]
daemon/settings/settings_view_featured.h [new file with mode: 0755]
daemon/sim_controller.c [new file with mode: 0755]
daemon/sim_controller.h [new file with mode: 0755]
daemon/vi/vi_manager.c [new file with mode: 0755]
daemon/vi/vi_manager.h [new file with mode: 0755]
daemon/voice_control.c [new file with mode: 0755]
daemon/voice_control.h [new file with mode: 0755]
data/CMakeLists.txt [new file with mode: 0755]
data/color_classes.edc [new file with mode: 0755]
data/images/00_check_bg.png [new file with mode: 0755]
data/images/00_check_bg_dim.png [new file with mode: 0755]
data/images/00_check_bg_press.png [new file with mode: 0755]
data/images/00_check_checking.png [new file with mode: 0755]
data/images/00_check_checking_dim.png [new file with mode: 0755]
data/images/00_divider_line.png [new file with mode: 0755]
data/images/00_progress_bar.png [new file with mode: 0755]
data/images/00_progress_bg.png [new file with mode: 0755]
data/images/00_slider_handle.png [new file with mode: 0755]
data/images/00_slider_handle_dim.png [new file with mode: 0755]
data/images/00_slider_handle_press.png [new file with mode: 0755]
data/images/B31_help_tap_1_default.png [new file with mode: 0644]
data/images/B32_help_start_right_01.png [new file with mode: 0644]
data/images/B32_help_start_right_02.png [new file with mode: 0644]
data/images/B32_help_start_right_03.png [new file with mode: 0644]
data/images/B32_help_start_right_04.png [new file with mode: 0644]
data/images/B32_notification_tray_effect_bg_01.png [new file with mode: 0644]
data/images/B32_notification_tray_effect_l_bg.png [new file with mode: 0644]
data/images/Q02_quickpanel_button_nomal_01_center.png [new file with mode: 0755]
data/images/Q02_quickpanel_button_nomal_01_left.png [new file with mode: 0755]
data/images/Q02_quickpanel_button_nomal_01_right.png [new file with mode: 0755]
data/images/Q02_quickpanel_button_press_01_center.png [new file with mode: 0755]
data/images/Q02_quickpanel_button_press_01_left.png [new file with mode: 0755]
data/images/Q02_quickpanel_button_press_01_right.png [new file with mode: 0755]
data/images/bg_pattern.png [new file with mode: 0755]
data/images/bg_press.#.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_00.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_01.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_02.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_03.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_04.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_05.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_06.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_07.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_08.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_09.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_10.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_11.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_12.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_13.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_14.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_15.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_16.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_17.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_18.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_19.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_20.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_21.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_22.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_23.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_24.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_25.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_26.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_27.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_28.png [new file with mode: 0644]
data/images/core_activity_Indicator_medium_29.png [new file with mode: 0644]
data/images/core_icon_badge_container.#.png [new file with mode: 0644]
data/images/core_list_button_bg.#.png [new file with mode: 0644]
data/images/core_probress_bar.#.png [new file with mode: 0644]
data/images/core_probress_bar.png [new file with mode: 0644]
data/images/core_probressbar_bg.#.png [new file with mode: 0644]
data/images/core_progress_bar.#.png [new file with mode: 0644]
data/images/core_progress_bar.png [new file with mode: 0644]
data/images/core_progressbar_bg.#.png [new file with mode: 0644]
data/images/core_progressbar_bg.png [new file with mode: 0644]
data/images/core_slider_center_point_bg.png [new file with mode: 0644]
data/images/core_slider_handle_normal.png [new file with mode: 0644]
data/images/core_slider_handle_press.png [new file with mode: 0644]
data/images/core_theme_bg_01.png [new file with mode: 0644]
data/images/handler_bg.#.png [new file with mode: 0644]
data/images/handler_bg_ef.#.png [new file with mode: 0644]
data/images/handler_btn.png [new file with mode: 0644]
data/images/handler_btn_02.png [new file with mode: 0644]
data/images/icon_arrow_down.png [new file with mode: 0644]
data/images/icon_arrow_up.png [new file with mode: 0644]
data/images/icon_bg.png [new file with mode: 0644]
data/images/icon_bg_press.png [new file with mode: 0644]
data/images/icon_bg_small.png [new file with mode: 0644]
data/images/icon_edit.png [new file with mode: 0644]
data/images/icon_indicator_setting.png [new file with mode: 0644]
data/images/icon_press.png [new file with mode: 0755]
data/images/icon_search.png [new file with mode: 0644]
data/images/icon_settings.png [new file with mode: 0644]
data/images/line_indicator_divider.png [new file with mode: 0644]
data/images/notification_bg.png [new file with mode: 0755]
data/images/quick_btn_close_dim.png [new file with mode: 0755]
data/images/quick_btn_close_nor.png [new file with mode: 0755]
data/images/quick_btn_close_press.png [new file with mode: 0755]
data/images/quick_btn_close_white_dim.png [new file with mode: 0644]
data/images/quick_btn_close_white_nor.png [new file with mode: 0644]
data/images/quick_btn_close_white_press.png [new file with mode: 0644]
data/images/quick_button_each_bg.png [new file with mode: 0644]
data/images/quick_button_each_bg_land.png [new file with mode: 0644]
data/images/quick_button_each_ef.png [new file with mode: 0644]
data/images/quick_button_each_ef_land.png [new file with mode: 0644]
data/images/quick_button_over.png [new file with mode: 0644]
data/images/quick_button_over_land.png [new file with mode: 0644]
data/images/quick_handle.png [new file with mode: 0644]
data/images/quick_handle_both.png [new file with mode: 0755]
data/images/quick_icon_bg_01.png [new file with mode: 0755]
data/images/quick_icon_bg_02.png [new file with mode: 0755]
data/images/quick_icon_bg_small.png [new file with mode: 0755]
data/images/quick_icon_brightness.png [new file with mode: 0644]
data/images/quick_icon_brightness_00.png [new file with mode: 0644]
data/images/quick_icon_brightness_01.png [new file with mode: 0644]
data/images/quick_icon_brightness_02.png [new file with mode: 0644]
data/images/quick_icon_brightness_03.png [new file with mode: 0644]
data/images/quick_icon_brightness_04.png [new file with mode: 0644]
data/images/quick_icon_brightness_05.png [new file with mode: 0644]
data/images/quick_icon_brightness_06.png [new file with mode: 0644]
data/images/quick_icon_brightness_07.png [new file with mode: 0644]
data/images/quick_icon_brightness_08.png [new file with mode: 0644]
data/images/quick_icon_brightness_09.png [new file with mode: 0644]
data/images/quick_icon_brightness_10.png [new file with mode: 0644]
data/images/quick_icon_brightness_11.png [new file with mode: 0644]
data/images/quick_image_dimmed_land.png [new file with mode: 0755]
data/images/quick_image_dimmed_port.png [new file with mode: 0755]
data/images/quick_menu_divide.png [new file with mode: 0644]
data/images/quick_menu_divide_highlight.png [new file with mode: 0644]
data/images/quick_menu_touch.png [new file with mode: 0644]
data/images/quick_progress.9.png [new file with mode: 0755]
data/images/quick_progress_bg.9.png [new file with mode: 0755]
data/images/quick_progress_unknown_port_01.png [new file with mode: 0755]
data/images/quick_progress_unknown_port_02.png [new file with mode: 0755]
data/images/quick_standard_btn_focus.9.png [new file with mode: 0644]
data/images/quick_standard_btn_nor.9.png [new file with mode: 0644]
data/images/quick_standard_btn_nor.png [new file with mode: 0644]
data/images/quick_standard_btn_press.9.png [new file with mode: 0644]
data/images/quickpanel_icon_default.png [new file with mode: 0644]
data/images/toggle_mw_bg_nor.png [new file with mode: 0644]
data/images/toggle_mw_bg_touch.png [new file with mode: 0644]
data/images_icon/Q02_Notification_brightness.png [new file with mode: 0644]
data/images_icon/Q02_Notification_multi_window.png [new file with mode: 0644]
data/images_icon/Q02_Notification_update.png [new file with mode: 0644]
data/images_icon/noti_download_01.png [new file with mode: 0644]
data/images_icon/noti_download_02.png [new file with mode: 0644]
data/images_icon/noti_download_03.png [new file with mode: 0644]
data/images_icon/noti_download_04.png [new file with mode: 0644]
data/images_icon/noti_download_05.png [new file with mode: 0644]
data/images_icon/noti_download_complete.png [new file with mode: 0644]
data/images_icon/noti_install_01.png [new file with mode: 0644]
data/images_icon/noti_install_02.png [new file with mode: 0644]
data/images_icon/noti_install_03.png [new file with mode: 0644]
data/images_icon/noti_install_04.png [new file with mode: 0644]
data/images_icon/noti_install_05.png [new file with mode: 0644]
data/images_icon/noti_install_complete.png [new file with mode: 0644]
data/images_icon/noti_upload_01.png [new file with mode: 0644]
data/images_icon/noti_upload_02.png [new file with mode: 0644]
data/images_icon/noti_upload_03.png [new file with mode: 0644]
data/images_icon/noti_upload_04.png [new file with mode: 0644]
data/images_icon/noti_upload_05.png [new file with mode: 0644]
data/images_icon/noti_upload_complete.png [new file with mode: 0644]
data/images_icon/quick_button_icon_bg.png [new file with mode: 0644]
data/images_icon/quick_icon_allshare.png [new file with mode: 0644]
data/images_icon/quick_icon_auto_rotate.png [new file with mode: 0644]
data/images_icon/quick_icon_blocking_mode.png [new file with mode: 0644]
data/images_icon/quick_icon_bluetooth.png [new file with mode: 0644]
data/images_icon/quick_icon_command.png [new file with mode: 0644]
data/images_icon/quick_icon_downloadbooster_off.png [new file with mode: 0644]
data/images_icon/quick_icon_driving.png [new file with mode: 0644]
data/images_icon/quick_icon_flightmode.png [new file with mode: 0644]
data/images_icon/quick_icon_glovemode.png [new file with mode: 0644]
data/images_icon/quick_icon_gps.png [new file with mode: 0644]
data/images_icon/quick_icon_location.png [new file with mode: 0644]
data/images_icon/quick_icon_mirroring.png [new file with mode: 0644]
data/images_icon/quick_icon_mobile_data.png [new file with mode: 0644]
data/images_icon/quick_icon_multi_window.png [new file with mode: 0644]
data/images_icon/quick_icon_nfc.png [new file with mode: 0644]
data/images_icon/quick_icon_personal_mode.png [new file with mode: 0644]
data/images_icon/quick_icon_power_saving.png [new file with mode: 0644]
data/images_icon/quick_icon_private_mode.png [new file with mode: 0644]
data/images_icon/quick_icon_ready_to_share.png [new file with mode: 0644]
data/images_icon/quick_icon_sbeam.png [new file with mode: 0644]
data/images_icon/quick_icon_sf_vf.png [new file with mode: 0644]
data/images_icon/quick_icon_sf_vn.png [new file with mode: 0644]
data/images_icon/quick_icon_smart_stay.png [new file with mode: 0644]
data/images_icon/quick_icon_sn_vf.png [new file with mode: 0644]
data/images_icon/quick_icon_sn_vn.png [new file with mode: 0644]
data/images_icon/quick_icon_sync.png [new file with mode: 0644]
data/images_icon/quick_icon_torch.png [new file with mode: 0644]
data/images_icon/quick_icon_ultra_power_saving.png [new file with mode: 0644]
data/images_icon/quick_icon_wifi.png [new file with mode: 0644]
data/images_icon/quick_icon_wifi_tethering.png [new file with mode: 0644]
data/images_icon/voice_control_icon_mic.png [new file with mode: 0755]
data/images_noti_icons/Account/noti_account_samsung.png [new file with mode: 0755]
data/images_noti_icons/Account/noti_account_tizen.png [new file with mode: 0755]
data/images_noti_icons/Bluetooth/noti_bluetooth.png [new file with mode: 0755]
data/images_noti_icons/Bluetooth/noti_bluetooth_activated.png [new file with mode: 0755]
data/images_noti_icons/Bluetooth/noti_bluetooth_fail.png [new file with mode: 0755]
data/images_noti_icons/Bluetooth/noti_bluetooth_not_connected.png [new file with mode: 0755]
data/images_noti_icons/Calendar/noti_calendar.png [new file with mode: 0755]
data/images_noti_icons/Calendar/noti_calendar_02.png [new file with mode: 0755]
data/images_noti_icons/Calendar/noti_calendar_alarm.png [new file with mode: 0755]
data/images_noti_icons/Clock/noti_clock_snooze.png [new file with mode: 0755]
data/images_noti_icons/Common/noti_download_01.png [new file with mode: 0755]
data/images_noti_icons/Common/noti_download_02.png [new file with mode: 0755]
data/images_noti_icons/Common/noti_download_03.png [new file with mode: 0755]
data/images_noti_icons/Common/noti_download_04.png [new file with mode: 0755]
data/images_noti_icons/Common/noti_download_05.png [new file with mode: 0755]
data/images_noti_icons/Common/noti_download_complete.png [new file with mode: 0755]
data/images_noti_icons/Common/noti_download_failed.png [new file with mode: 0755]
data/images_noti_icons/Common/noti_syncing.png [new file with mode: 0755]
data/images_noti_icons/Common/noti_upload_01.png [new file with mode: 0755]
data/images_noti_icons/Common/noti_upload_02.png [new file with mode: 0755]
data/images_noti_icons/Common/noti_upload_03.png [new file with mode: 0755]
data/images_noti_icons/Common/noti_upload_04.png [new file with mode: 0755]
data/images_noti_icons/Common/noti_upload_05.png [new file with mode: 0755]
data/images_noti_icons/Common/noti_upload_complete.png [new file with mode: 0755]
data/images_noti_icons/Common/noti_upload_failed.png [new file with mode: 0755]
data/images_noti_icons/Contact/noti_contact_default.png [new file with mode: 0755]
data/images_noti_icons/Contact/noti_icon_missed.png [new file with mode: 0755]
data/images_noti_icons/Drop box/moti_dropbox.png [new file with mode: 0755]
data/images_noti_icons/E-mail/noti_email.png [new file with mode: 0755]
data/images_noti_icons/E-mail/noti_email_delivery_report.png [new file with mode: 0755]
data/images_noti_icons/E-mail/noti_email_read_report.png [new file with mode: 0755]
data/images_noti_icons/E-mail/noti_email_scheduled.png [new file with mode: 0755]
data/images_noti_icons/E-mail/noti_email_sent.png [new file with mode: 0755]
data/images_noti_icons/Etc/Icon_tethering_unknown_usb_fail.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_accessory_connected.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_all_connected.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_auto_rejected.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_backup.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_battery_charge.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_battery_loading.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_bluetooth_download.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_camera_connected.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_chat.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_data_usage_warning.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_desktop_mode.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_dormant_mode.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_download_booster.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_ecb_mode.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_error.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_firewall_activated.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_fm_radio.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_fota.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_fota_completion.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_fota_postpone.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_gqs_on.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_gqs_searching.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_im.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_install_01.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_install_02.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_install_03.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_install_04.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_install_05.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_install_complete.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_install_failed.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_keyboard.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_keyboard_connected.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_mms_delivery_report.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_mms_failed.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_mms_problem.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_multi_email.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_multi_window.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_multiple_devices_connected.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_near_by_device.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_no_sim_full.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_print.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_print_waiting.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_rcs_chat.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_rcs_file_transfer.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_safe_mode.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_screen_recorder.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_screen_recorder_dim.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_sd_card.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_sd_card_decryption.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_sd_card_encryption.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_sd_card_encryption_error.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_sd_card_error.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_sd_card_prepare.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_sd_card_removed.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_shareshot_receive.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_shareshot_receive_problem.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_shareshot_send.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_shareshot_send_problem.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_side_sync.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_sim_toolkit.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_smart_stay.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_smemo_sync.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_spen.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_sync_error.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_tethering_usb_fail.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_tty_mode.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_tv.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_updated_complete.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_updated_failed.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_usb_connected.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_usb_fail.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_usb_mass_storage_connected.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_usb_unknown_fail.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_video.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_voice_mail.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_voice_mail_01.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_voice_mail_02.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_voice_mail_03.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_voice_memo.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_voice_recorder_paused.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_voice_recorder_play.png [new file with mode: 0755]
data/images_noti_icons/Etc/noti_wifi_translate.png [new file with mode: 0755]
data/images_noti_icons/FOTA/noti_fota.png [new file with mode: 0755]
data/images_noti_icons/FOTA/noti_fota_completion.png [new file with mode: 0755]
data/images_noti_icons/FOTA/noti_fota_diagmon.png [new file with mode: 0755]
data/images_noti_icons/FOTA/noti_fota_diagmon_completion.png [new file with mode: 0755]
data/images_noti_icons/FOTA/noti_fota_postpone.png [new file with mode: 0755]
data/images_noti_icons/Facebook/noti_facebook.png [new file with mode: 0755]
data/images_noti_icons/Facebook/noti_facebook_female_default.png [new file with mode: 0755]
data/images_noti_icons/Facebook/noti_facebook_male_default.png [new file with mode: 0755]
data/images_noti_icons/Find my mobile/noti_FMM_call_log.png [new file with mode: 0755]
data/images_noti_icons/Find my mobile/noti_FMM_device_located.png [new file with mode: 0755]
data/images_noti_icons/Find my mobile/noti_FMM_device_unlocked.png [new file with mode: 0755]
data/images_noti_icons/Gallery/noti_gallery_image.png [new file with mode: 0755]
data/images_noti_icons/Gallery/noti_gallery_image_error.png [new file with mode: 0755]
data/images_noti_icons/Internet/noti_internet_flightmode.png [new file with mode: 0755]
data/images_noti_icons/Lock screen/noti_message.png [new file with mode: 0755]
data/images_noti_icons/Lock screen/noti_missed_call.png [new file with mode: 0755]
data/images_noti_icons/Low battery&charge/noti_battery_fully_charging.png [new file with mode: 0755]
data/images_noti_icons/Low battery&charge/noti_charging_battery_low.png [new file with mode: 0755]
data/images_noti_icons/Low battery&charge/noti_charging_cable_disconnected.png [new file with mode: 0755]
data/images_noti_icons/Message/noti_message.png [new file with mode: 0755]
data/images_noti_icons/Message/noti_message_OTA.png [new file with mode: 0755]
data/images_noti_icons/Message/noti_message_cb-msg.png [new file with mode: 0755]
data/images_noti_icons/Message/noti_message_delivery_report.png [new file with mode: 0755]
data/images_noti_icons/Message/noti_message_failed.png [new file with mode: 0755]
data/images_noti_icons/Message/noti_message_mms_failed.png [new file with mode: 0755]
data/images_noti_icons/Message/noti_message_mms_problem.png [new file with mode: 0755]
data/images_noti_icons/Message/noti_message_read_report.png [new file with mode: 0755]
data/images_noti_icons/Message/noti_message_reply.png [new file with mode: 0755]
data/images_noti_icons/Message/noti_message_scheduled.png [new file with mode: 0755]
data/images_noti_icons/Message/noti_message_sending.png [new file with mode: 0755]
data/images_noti_icons/Message/noti_message_sim-card.png [new file with mode: 0755]
data/images_noti_icons/Message/noti_mms.png [new file with mode: 0755]
data/images_noti_icons/Message/noti_voice_mail.png [new file with mode: 0755]
data/images_noti_icons/Multi SIM/noti_no_sim.png [new file with mode: 0755]
data/images_noti_icons/Multi SIM/noti_sim_full.png [new file with mode: 0755]
data/images_noti_icons/Patterns/noti_cooling_down.png [new file with mode: 0755]
data/images_noti_icons/Patterns/noti_screen_captured.png [new file with mode: 0755]
data/images_noti_icons/Private mode/noti_private_mode.png [new file with mode: 0755]
data/images_noti_icons/Send help messages/noti_icon_emergency.png [new file with mode: 0755]
data/images_noti_icons/Send help messages/noti_send_emergency_msg.png [new file with mode: 0755]
data/images_noti_icons/Share with contents/noti_icon_Id_default.png [new file with mode: 0755]
data/images_noti_icons/Tethering/noti_tethering.png [new file with mode: 0755]
data/images_noti_icons/Tethering/noti_tethering_all.png [new file with mode: 0755]
data/images_noti_icons/Tethering/noti_tethering_bt.png [new file with mode: 0755]
data/images_noti_icons/Tethering/noti_tethering_usb.png [new file with mode: 0755]
data/images_noti_icons/Tethering/noti_tethering_wifi.png [new file with mode: 0755]
data/images_noti_icons/Tizen store/noti_tizen_store.png [new file with mode: 0755]
data/images_noti_icons/Wi-Fi/noti_wifi.png [new file with mode: 0755]
data/images_noti_icons/Wi-Fi/noti_wifi_availablility_check1.png [new file with mode: 0755]
data/images_noti_icons/Wi-Fi/noti_wifi_direct.png [new file with mode: 0755]
data/images_noti_icons/Wi-Fi/noti_wifi_direct_auto_off.png [new file with mode: 0755]
data/images_noti_icons/Wi-Fi/noti_wifi_in_range.png [new file with mode: 0755]
data/images_noti_icons/Wi-Fi/noti_wifi_network_available.png [new file with mode: 0755]
data/images_noti_icons/Wi-Fi/noti_wifi_no_detected.png [new file with mode: 0755]
data/images_noti_icons/Wi-Fi/noti_wifi_no_sign.png [new file with mode: 0755]
data/images_noti_icons/Wi-Fi/noti_wifi_translate.png [new file with mode: 0755]
data/quickpanel [new file with mode: 0755]
data/quickpanel.desktop.in [new file with mode: 0755]
data/quickpanel.edc [new file with mode: 0755]
data/quickpanel.sh.in [new file with mode: 0755]
data/quickpanel.xml.in [new file with mode: 0755]
data/quickpanel_activenoti.edc [new file with mode: 0755]
data/quickpanel_animated_icon.edc [new file with mode: 0755]
data/quickpanel_brightness.edc [new file with mode: 0755]
data/quickpanel_datetime.edc [new file with mode: 0755]
data/quickpanel_def.h [new file with mode: 0755]
data/quickpanel_images.edc [new file with mode: 0755]
data/quickpanel_listitem_noti.edc [new file with mode: 0755]
data/quickpanel_listitem_ongoing.edc [new file with mode: 0755]
data/quickpanel_minictrl.edc [new file with mode: 0755]
data/quickpanel_noti_section.edc [new file with mode: 0755]
data/quickpanel_page_setting_all.edc [new file with mode: 0755]
data/quickpanel_setting.edc [new file with mode: 0755]
data/quickpanel_theme.edc [new file with mode: 0755]
data/quickpanel_theme_progressbar.edc [new file with mode: 0755]
data/quickpanel_theme_slider.edc [new file with mode: 0755]
data/quickpanel_voice_control.edc [new file with mode: 0755]
packaging/org.tizen.quickpanel.manifest [new file with mode: 0755]
packaging/org.tizen.quickpanel.spec [new file with mode: 0755]
po/CMakeLists.txt [new file with mode: 0755]
po/ar.po [new file with mode: 0755]
po/az.po [new file with mode: 0755]
po/bg.po [new file with mode: 0755]
po/ca.po [new file with mode: 0755]
po/cs.po [new file with mode: 0755]
po/da.po [new file with mode: 0755]
po/de.po [new file with mode: 0644]
po/el_GR.po [new file with mode: 0755]
po/en.po [new file with mode: 0755]
po/en_PH.po [new file with mode: 0755]
po/en_US.po [new file with mode: 0755]
po/es_ES.po [new file with mode: 0755]
po/es_US.po [new file with mode: 0644]
po/et.po [new file with mode: 0755]
po/eu.po [new file with mode: 0755]
po/fi.po [new file with mode: 0755]
po/fr.po [new file with mode: 0644]
po/fr_CA.po [new file with mode: 0755]
po/ga.po [new file with mode: 0755]
po/gl.po [new file with mode: 0755]
po/hi.po [new file with mode: 0755]
po/hr.po [new file with mode: 0755]
po/hu.po [new file with mode: 0755]
po/hy.po [new file with mode: 0755]
po/is.po [new file with mode: 0755]
po/it_IT.po [new file with mode: 0755]
po/ja_JP.po [new file with mode: 0755]
po/ka.po [new file with mode: 0755]
po/kk.po [new file with mode: 0755]
po/ko_KR.po [new file with mode: 0755]
po/lt.po [new file with mode: 0755]
po/lv.po [new file with mode: 0755]
po/mk.po [new file with mode: 0755]
po/nb.po [new file with mode: 0755]
po/nl.po [new file with mode: 0644]
po/pl.po [new file with mode: 0755]
po/pt_BR.po [new file with mode: 0755]
po/pt_PT.po [new file with mode: 0755]
po/ro.po [new file with mode: 0755]
po/ru_RU.po [new file with mode: 0755]
po/sk.po [new file with mode: 0755]
po/sl.po [new file with mode: 0755]
po/sr.po [new file with mode: 0755]
po/sv.po [new file with mode: 0755]
po/tr_TR.po [new file with mode: 0755]
po/uk.po [new file with mode: 0755]
po/uz.po [new file with mode: 0755]
po/zh_CN.po [new file with mode: 0755]
po/zh_HK.po [new file with mode: 0755]
po/zh_TW.po [new file with mode: 0755]
test/quickpanel_debug_util.c [new file with mode: 0755]
test/quickpanel_debug_util.h [new file with mode: 0755]

diff --git a/AUTHORS b/AUTHORS
new file mode 100644 (file)
index 0000000..24aebc0
--- /dev/null
+++ b/AUTHORS
@@ -0,0 +1,2 @@
+youngsub ko <ys4610.ko at samsung dot com>
+seung taek jung <seungtaek.chung at samsung dot com>
diff --git a/CMakeLists.txt b/CMakeLists.txt
new file mode 100755 (executable)
index 0000000..6f40394
--- /dev/null
@@ -0,0 +1,190 @@
+CMAKE_MINIMUM_REQUIRED(VERSION 2.6)
+PROJECT(quickpanel C)
+
+AUX_SOURCE_DIRECTORY(${CMAKE_CURRENT_SOURCE_DIR}/test TEST_SRCS)
+
+SET(SRCS
+       daemon/modules.c
+       daemon/accessibility.c
+       daemon/voice_control.c
+       daemon/media.c
+       daemon/datetime/util-time.c
+       daemon/datetime/datetime.c
+       daemon/sim_controller.c
+       daemon/minictrl/minictrl.c
+       daemon/preference.c
+       daemon/notifications/noti_list_item.c
+       daemon/notifications/animated_image.c
+       daemon/notifications/activenoti.c
+       daemon/notifications/noti_view_listype.c
+       daemon/notifications/noti_view_ongoing.c
+       daemon/notifications/noti_node.c
+       daemon/notifications/noti_section.c
+       daemon/notifications/noti_win.c
+       daemon/notifications/noti_listbox.c
+       daemon/notifications/noti_util.c
+       daemon/notifications/noti_view.c
+       daemon/notifications/noti.c
+       daemon/device/brightness.c
+       daemon/settings/modules/rotate-lock.c
+       daemon/settings/modules/bluetooth.c
+       daemon/settings/modules/gps.c
+       daemon/settings/modules/wifi.c
+       daemon/settings/modules/sound-profile.c
+       daemon/settings/settings_view_all.c
+       daemon/settings/settings_icon_common.c
+       daemon/settings/settings_gridbox.c
+       daemon/settings/settings_view_featured.c
+       daemon/settings/settings_ipc.c
+       daemon/settings/setting_module_api.c
+       daemon/settings/settings.c
+       daemon/settings/setting_utils.c
+       daemon/vi/vi_manager.c
+       daemon/common_uic.c
+       daemon/handler_controller.c
+       daemon/service/animated_icon.c
+       daemon/service/emergency_mode.c
+       daemon/service/uninstall.c
+       daemon/service/reminder.c
+       daemon/service/keyboard.c
+       daemon/service/noti_led.c
+       daemon/page/pager.c
+       daemon/page/page_base.c
+       daemon/page/pager_common.c
+       daemon/page/page_setting_all.c
+       daemon/quickpanel-ui.c
+       daemon/common.c
+       daemon/list_util.c
+       ${EXTRA_SRCS}
+       ${TEST_SRCS}
+)
+
+SET(PACKAGE ${PROJECT_NAME})
+SET(PREFIX "${CMAKE_INSTALL_PREFIX}/apps/${PKGNAME}")
+SET(BINDIR "${PREFIX}/bin")
+SET(RESDIR "${PREFIX}/res")
+SET(LOCALEDIR "${RESDIR}/locale")
+SET(ICONDIR "${RESDIR}/icons")
+SET(EDJDIR "${RESDIR}/edje")
+SET(DATADIR "${PREFIX}/data")
+SET(DESKTOPDIR "/usr/share/applications")
+SET(MANIFESTXMLDIR "/usr/share/packages")
+SET(SHARED_DIR "${PREFIX}/shared/res")
+
+IF("${CMAKE_BUILD_TYPE}" STREQUAL "")
+       SET(CMAKE_BUILD_TYPE "Release")
+ENDIF("${CMAKE_BUILD_TYPE}" STREQUAL "")
+MESSAGE("Build type: ${CMAKE_BUILD_TYPE}")
+
+INCLUDE_DIRECTORIES(
+               ${CMAKE_CURRENT_SOURCE_DIR}/daemon
+               ${CMAKE_CURRENT_SOURCE_DIR}/daemon/minictrl
+               ${CMAKE_CURRENT_SOURCE_DIR}/daemon/notifications
+               ${CMAKE_CURRENT_SOURCE_DIR}/daemon/service
+               ${CMAKE_CURRENT_SOURCE_DIR}/daemon/settings
+               ${CMAKE_CURRENT_SOURCE_DIR}/daemon/settings/modules
+               ${CMAKE_CURRENT_SOURCE_DIR}/daemon/vi
+               ${CMAKE_CURRENT_SOURCE_DIR}/daemon/page
+               ${CMAKE_CURRENT_SOURCE_DIR}/daemon/datetime
+               ${CMAKE_CURRENT_SOURCE_DIR}/data
+               ${CMAKE_CURRENT_SOURCE_DIR}/test
+               )
+
+INCLUDE(FindPkgConfig)
+pkg_check_modules(pkgs REQUIRED
+       capi-appfw-application
+       capi-system-runtime-info
+       capi-system-info
+       capi-system-device
+       capi-location-manager
+       capi-network-tethering
+       capi-network-bluetooth
+       capi-network-connection
+       capi-network-wifi
+       capi-media-player
+       capi-media-sound-manager
+       capi-media-metadata-extractor
+       capi-system-system-settings
+       capi-base-utils-i18n
+       capi-ui-efl-util
+       tapi
+       feedback
+       notification
+       badge
+       vconf
+       edbus
+       evas
+       ecore
+       edje
+       ecore-input
+       icu-i18n
+       elementary
+       dlog
+       syspopup-caller
+       minicontrol-viewer
+       minicontrol-monitor
+       capi-appfw-package-manager
+       iniparser
+       alarm-service
+       voice-control-setting
+       tzsh-quickpanel-service 
+)
+
+FOREACH(flag ${pkgs_CFLAGS} ${x11_pkgs_CFLAGS})
+       SET(EXTRA_CFLAGS "${EXTRA_CFLAGS} ${flag}")
+ENDFOREACH(flag)
+
+SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${EXTRA_CFLAGS} -Wall -g -O2 -fpie -Werror")
+SET(CMAKE_C_FLAGS_DEBUG "-O0 -g")
+SET(CMAKE_C_FLAGS_RELEASE "-O2")
+
+FIND_PROGRAM(UNAME NAMES uname)
+EXEC_PROGRAM("${UNAME}" ARGS "-m" OUTPUT_VARIABLE "ARCH")
+IF("${ARCH}" STREQUAL "arm")
+       ADD_DEFINITIONS("-DTARGET")
+       MESSAGE("add -DTARGET")
+ENDIF("${ARCH}" STREQUAL "arm")
+
+ADD_DEFINITIONS("-DQP_SETTING_ENABLE")
+ADD_DEFINITIONS("-DQP_BRIGHTNESS_ENABLE")
+ADD_DEFINITIONS("-DQP_MINICTRL_ENABLE")
+ADD_DEFINITIONS("-DQP_SCREENREADER_ENABLE")
+ADD_DEFINITIONS("-DQP_SERVICE_NOTI_LED_ENABLE")
+ADD_DEFINITIONS("-DQP_ANIMATED_IMAGE_ENABLE")
+ADD_DEFINITIONS("-DQP_REMINDER_ENABLE")
+#ADD_DEFINITIONS("-DQP_EMERGENCY_MODE_ENABLE")
+ADD_DEFINITIONS("-DQP_VOICE_CONTROL_ENABLE")
+
+ADD_DEFINITIONS("-DPACKAGE=\"${PACKAGE}\"")
+ADD_DEFINITIONS("-DPACKAGE_NAME=\"${PKGNAME}\"")
+ADD_DEFINITIONS("-DPREFIX=\"${PREFIX}\"")
+ADD_DEFINITIONS("-DRESDIR=\"${RESDIR}\"")
+ADD_DEFINITIONS("-DLOCALEDIR=\"${LOCALEDIR}\"")
+ADD_DEFINITIONS("-DICONDIR=\"${ICONDIR}\"")
+ADD_DEFINITIONS("-DEDJDIR=\"${EDJDIR}\"")
+ADD_DEFINITIONS("-DDATADIR=\"${DATADIR}\"")
+ADD_DEFINITIONS("-DSHARED_DIR=\"${SHARED_DIR}\"")
+
+#ADD_DEFINITIONS("-DFILE_DEBUG")
+ADD_DEFINITIONS("-D_DLOG_USED")
+#ADD_DEFINITIONS("-DHAVE_X")
+
+SET(CMAKE_EXE_LINKER_FLAGS "-Wl,--as-needed")
+
+ADD_EXECUTABLE(${PROJECT_NAME} ${SRCS})
+TARGET_LINK_LIBRARIES(${PROJECT_NAME} ${pkgs_LDFLAGS} ${x11_pkgs_LDFLAGS} "-pie")
+
+INSTALL(TARGETS ${PROJECT_NAME} DESTINATION ${BINDIR})
+INSTALL(DIRECTORY DESTINATION ${DATADIR})
+#INSTALL(FILES ${CMAKE_SOURCE_DIR}/icons/quickpanel_icon_default.png DESTINATION ${RESDIR})
+
+# icons for notification
+INSTALL(DIRECTORY ${CMAKE_SOURCE_DIR}/data/images_noti_icons/ DESTINATION ${SHARED_DIR}/noti_icons FILES_MATCHING PATTERN "*.png")
+INSTALL(FILES ${CMAKE_SOURCE_DIR}/data/images/quickpanel_icon_default.png DESTINATION ${RESDIR})
+
+# License
+INSTALL(FILES ${CMAKE_SOURCE_DIR}/LICENSE DESTINATION /usr/share/license RENAME ${PKGNAME})
+
+# i18n
+ADD_SUBDIRECTORY(data)
+ADD_SUBDIRECTORY(po)
diff --git a/LICENSE b/LICENSE
new file mode 100644 (file)
index 0000000..54b213e
--- /dev/null
+++ b/LICENSE
@@ -0,0 +1,204 @@
+Copyright (c) 2000 - 2015 Samsung Electronics Co., Ltd. All rights reserved.
+
+                                 Apache License
+                           Version 2.0, January 2004
+                        http://www.apache.org/licenses/
+
+   TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
+
+   1. Definitions.
+
+      "License" shall mean the terms and conditions for use, reproduction,
+      and distribution as defined by Sections 1 through 9 of this document.
+
+      "Licensor" shall mean the copyright owner or entity authorized by
+      the copyright owner that is granting the License.
+
+      "Legal Entity" shall mean the union of the acting entity and all
+      other entities that control, are controlled by, or are under common
+      control with that entity. For the purposes of this definition,
+      "control" means (i) the power, direct or indirect, to cause the
+      direction or management of such entity, whether by contract or
+      otherwise, or (ii) ownership of fifty percent (50%) or more of the
+      outstanding shares, or (iii) beneficial ownership of such entity.
+
+      "You" (or "Your") shall mean an individual or Legal Entity
+      exercising permissions granted by this License.
+
+      "Source" form shall mean the preferred form for making modifications,
+      including but not limited to software source code, documentation
+      source, and configuration files.
+
+      "Object" form shall mean any form resulting from mechanical
+      transformation or translation of a Source form, including but
+      not limited to compiled object code, generated documentation,
+      and conversions to other media types.
+
+      "Work" shall mean the work of authorship, whether in Source or
+      Object form, made available under the License, as indicated by a
+      copyright notice that is included in or attached to the work
+      (an example is provided in the Appendix below).
+
+      "Derivative Works" shall mean any work, whether in Source or Object
+      form, that is based on (or derived from) the Work and for which the
+      editorial revisions, annotations, elaborations, or other modifications
+      represent, as a whole, an original work of authorship. For the purposes
+      of this License, Derivative Works shall not include works that remain
+      separable from, or merely link (or bind by name) to the interfaces of,
+      the Work and Derivative Works thereof.
+
+      "Contribution" shall mean any work of authorship, including
+      the original version of the Work and any modifications or additions
+      to that Work or Derivative Works thereof, that is intentionally
+      submitted to Licensor for inclusion in the Work by the copyright owner
+      or by an individual or Legal Entity authorized to submit on behalf of
+      the copyright owner. For the purposes of this definition, "submitted"
+      means any form of electronic, verbal, or written communication sent
+      to the Licensor or its representatives, including but not limited to
+      communication on electronic mailing lists, source code control systems,
+      and issue tracking systems that are managed by, or on behalf of, the
+      Licensor for the purpose of discussing and improving the Work, but
+      excluding communication that is conspicuously marked or otherwise
+      designated in writing by the copyright owner as "Not a Contribution."
+
+      "Contributor" shall mean Licensor and any individual or Legal Entity
+      on behalf of whom a Contribution has been received by Licensor and
+      subsequently incorporated within the Work.
+
+   2. Grant of Copyright License. Subject to the terms and conditions of
+      this License, each Contributor hereby grants to You a perpetual,
+      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+      copyright license to reproduce, prepare Derivative Works of,
+      publicly display, publicly perform, sublicense, and distribute the
+      Work and such Derivative Works in Source or Object form.
+
+   3. Grant of Patent License. Subject to the terms and conditions of
+      this License, each Contributor hereby grants to You a perpetual,
+      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+      (except as stated in this section) patent license to make, have made,
+      use, offer to sell, sell, import, and otherwise transfer the Work,
+      where such license applies only to those patent claims licensable
+      by such Contributor that are necessarily infringed by their
+      Contribution(s) alone or by combination of their Contribution(s)
+      with the Work to which such Contribution(s) was submitted. If You
+      institute patent litigation against any entity (including a
+      cross-claim or counterclaim in a lawsuit) alleging that the Work
+      or a Contribution incorporated within the Work constitutes direct
+      or contributory patent infringement, then any patent licenses
+      granted to You under this License for that Work shall terminate
+      as of the date such litigation is filed.
+
+   4. Redistribution. You may reproduce and distribute copies of the
+      Work or Derivative Works thereof in any medium, with or without
+      modifications, and in Source or Object form, provided that You
+      meet the following conditions:
+
+      (a) You must give any other recipients of the Work or
+          Derivative Works a copy of this License; and
+
+      (b) You must cause any modified files to carry prominent notices
+          stating that You changed the files; and
+
+      (c) You must retain, in the Source form of any Derivative Works
+          that You distribute, all copyright, patent, trademark, and
+          attribution notices from the Source form of the Work,
+          excluding those notices that do not pertain to any part of
+          the Derivative Works; and
+
+      (d) If the Work includes a "NOTICE" text file as part of its
+          distribution, then any Derivative Works that You distribute must
+          include a readable copy of the attribution notices contained
+          within such NOTICE file, excluding those notices that do not
+          pertain to any part of the Derivative Works, in at least one
+          of the following places: within a NOTICE text file distributed
+          as part of the Derivative Works; within the Source form or
+          documentation, if provided along with the Derivative Works; or,
+          within a display generated by the Derivative Works, if and
+          wherever such third-party notices normally appear. The contents
+          of the NOTICE file are for informational purposes only and
+          do not modify the License. You may add Your own attribution
+          notices within Derivative Works that You distribute, alongside
+          or as an addendum to the NOTICE text from the Work, provided
+          that such additional attribution notices cannot be construed
+          as modifying the License.
+
+      You may add Your own copyright statement to Your modifications and
+      may provide additional or different license terms and conditions
+      for use, reproduction, or distribution of Your modifications, or
+      for any such Derivative Works as a whole, provided Your use,
+      reproduction, and distribution of the Work otherwise complies with
+      the conditions stated in this License.
+
+   5. Submission of Contributions. Unless You explicitly state otherwise,
+      any Contribution intentionally submitted for inclusion in the Work
+      by You to the Licensor shall be under the terms and conditions of
+      this License, without any additional terms or conditions.
+      Notwithstanding the above, nothing herein shall supersede or modify
+      the terms of any separate license agreement you may have executed
+      with Licensor regarding such Contributions.
+
+   6. Trademarks. This License does not grant permission to use the trade
+      names, trademarks, service marks, or product names of the Licensor,
+      except as required for reasonable and customary use in describing the
+      origin of the Work and reproducing the content of the NOTICE file.
+
+   7. Disclaimer of Warranty. Unless required by applicable law or
+      agreed to in writing, Licensor provides the Work (and each
+      Contributor provides its Contributions) on an "AS IS" BASIS,
+      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+      implied, including, without limitation, any warranties or conditions
+      of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
+      PARTICULAR PURPOSE. You are solely responsible for determining the
+      appropriateness of using or redistributing the Work and assume any
+      risks associated with Your exercise of permissions under this License.
+
+   8. Limitation of Liability. In no event and under no legal theory,
+      whether in tort (including negligence), contract, or otherwise,
+      unless required by applicable law (such as deliberate and grossly
+      negligent acts) or agreed to in writing, shall any Contributor be
+      liable to You for damages, including any direct, indirect, special,
+      incidental, or consequential damages of any character arising as a
+      result of this License or out of the use or inability to use the
+      Work (including but not limited to damages for loss of goodwill,
+      work stoppage, computer failure or malfunction, or any and all
+      other commercial damages or losses), even if such Contributor
+      has been advised of the possibility of such damages.
+
+   9. Accepting Warranty or Additional Liability. While redistributing
+      the Work or Derivative Works thereof, You may choose to offer,
+      and charge a fee for, acceptance of support, warranty, indemnity,
+      or other liability obligations and/or rights consistent with this
+      License. However, in accepting such obligations, You may act only
+      on Your own behalf and on Your sole responsibility, not on behalf
+      of any other Contributor, and only if You agree to indemnify,
+      defend, and hold each Contributor harmless for any liability
+      incurred by, or claims asserted against, such Contributor by reason
+      of your accepting any such warranty or additional liability.
+
+   END OF TERMS AND CONDITIONS
+
+   APPENDIX: How to apply the Apache License to your work.
+
+      To apply the Apache License to your work, attach the following
+      boilerplate notice, with the fields enclosed by brackets "[]"
+      replaced with your own identifying information. (Don't include
+      the brackets!)  The text should be enclosed in the appropriate
+      comment syntax for the file format. We also recommend that a
+      file or class name and description of purpose be included on the
+      same "printed page" as the copyright notice for easier
+      identification within third-party archives.
+
+   Copyright [yyyy] [name of copyright owner]
+
+   Licensed under the Apache License, Version 2.0 (the "License");
+   you may not use this file except in compliance with the License.
+   You may obtain a copy of the License at
+
+       http://www.apache.org/licenses/LICENSE-2.0
+
+   Unless required by applicable law or agreed to in writing, software
+   distributed under the License is distributed on an "AS IS" BASIS,
+   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+   See the License for the specific language governing permissions and
+   limitations under the License.
+
diff --git a/NOTICE b/NOTICE
new file mode 100644 (file)
index 0000000..177464e
--- /dev/null
+++ b/NOTICE
@@ -0,0 +1 @@
+Copyright (c) 2000 - 2015 Samsung Electronics Co., Ltd. All rights reserved.
\ No newline at end of file
diff --git a/daemon/accessibility.c b/daemon/accessibility.c
new file mode 100755 (executable)
index 0000000..3434832
--- /dev/null
@@ -0,0 +1,123 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#include <stdio.h>
+
+#include <Elementary.h>
+
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "common.h"
+#include "quickpanel-ui.h"
+#include "accessibility.h"
+
+HAPI Evas_Object *quickpanel_accessibility_screen_reader_object_get(void *obj, screen_reader_object_type_e type, const char *part, Evas_Object *parent)
+{
+       Evas_Object *to = NULL;
+       Evas_Object *ao = NULL;
+
+       retif(obj == NULL, NULL, "invalid parameter");
+       retif(type == SCREEN_READER_OBJ_TYPE_EDJ_OBJECT && !part, NULL, "invalid parameter");
+
+       switch (type) {
+       case SCREEN_READER_OBJ_TYPE_ELM_OBJECT:
+               if (part != NULL) {
+                       to = (Evas_Object *)elm_object_part_content_get(obj, part);
+                       ao = (Evas_Object *)to;
+               } else {
+                       ao = (Evas_Object *)obj;
+               }
+               break;
+
+       case SCREEN_READER_OBJ_TYPE_EDJ_OBJECT:
+               to = (Evas_Object *)edje_object_part_object_get(elm_layout_edje_get((Evas_Object *)obj), part);
+               break;
+
+       default:// evas, icon
+               to = (Evas_Object *)obj;
+       }
+
+       if (!ao && to && parent) {              // edj, evas, icon, elm_object_item
+               ao = elm_access_object_get(to);
+               if (ao == NULL) {
+                       ao = elm_access_object_register(to, parent);
+               }
+       }
+
+       return ao;
+}
+
+HAPI Evas_Object *quickpanel_accessibility_ui_get_focus_object(Evas_Object *parent)
+{
+       Evas_Object *focus = elm_button_add(parent);
+       retif(focus == NULL, NULL, "failed to create focus object");
+
+       elm_object_style_set(focus, "focus");
+
+       elm_access_info_set(focus, ELM_ACCESS_INFO, "");
+       elm_access_info_set(focus, ELM_ACCESS_TYPE, "");
+
+       return focus;
+}
+
+HAPI char *quickpanel_accessibility_info_cb(void *data, Evas_Object *obj)
+{
+       char *str = NULL;
+       retif(data == NULL, NULL, "invalid parameter");
+
+       str = _((const char *)data);
+       if (str != NULL) {
+               return strdup(str);
+       }
+
+       return NULL;
+}
+
+HAPI char *quickpanel_accessibility_info_cb_s(void *data, Evas_Object *obj)
+{
+       char *str = NULL;
+       retif(data == NULL, NULL, "invalid parameter");
+
+       /**
+        * @note
+        * system string is not supported.
+        * data should be DID from application po files.
+        */
+       str = _(data);
+       if (str != NULL) {
+               return strdup(str);
+       }
+
+       return NULL;
+}
+
+HAPI void quickpanel_accessibility_screen_reader_data_set(Evas_Object *view, const char *part, char *type, char *info)
+{
+       Evas_Object *ao = NULL;
+       retif(view == NULL, , "invalid parameter");
+       retif(part == NULL, , "invalid parameter");
+
+       ao = quickpanel_accessibility_screen_reader_object_get(view,
+                       SCREEN_READER_OBJ_TYPE_ELM_OBJECT, part, view);
+       if (ao != NULL) {
+               elm_access_info_set(ao, ELM_ACCESS_TYPE, type);
+               elm_access_info_set(ao, ELM_ACCESS_INFO, info);
+       }
+}
diff --git a/daemon/accessibility.h b/daemon/accessibility.h
new file mode 100755 (executable)
index 0000000..b2f1272
--- /dev/null
@@ -0,0 +1,34 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+
+#ifndef __ACCESSIBILITY_H__
+#define __ACCESSIBILITY_H__
+
+typedef enum {
+       SCREEN_READER_OBJ_TYPE_ELM_OBJECT,
+       SCREEN_READER_OBJ_TYPE_EDJ_OBJECT,
+} screen_reader_object_type_e;
+
+extern Evas_Object *quickpanel_accessibility_screen_reader_object_get(void *obj, screen_reader_object_type_e type, const char *part, Evas_Object *parent);
+extern Evas_Object *quickpanel_accessibility_ui_get_focus_object(Evas_Object *parent);
+extern char *quickpanel_accessibility_info_cb(void *data, Evas_Object *obj);
+extern char *quickpanel_accessibility_info_cb_s(void *data, Evas_Object *obj);
+extern void quickpanel_accessibility_screen_reader_data_set(Evas_Object *view, const char *part, char *type, char *info);
+
+#endif                         /* __ACCESSIBILITY_H__ */
diff --git a/daemon/common.c b/daemon/common.c
new file mode 100755 (executable)
index 0000000..e32535f
--- /dev/null
@@ -0,0 +1,398 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <stdio.h>
+#include <sys/stat.h>
+#include <sys/types.h>
+#include <unistd.h>
+
+#include <Elementary.h>
+
+#include <package_manager.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "common.h"
+#include "quickpanel-ui.h"
+
+static inline int _is_space(char in)
+{
+       if ((in == _SPACE)) {
+               return 1;
+       } else {
+               return 0;
+       }
+}
+
+static inline int _l_trim(char *in)
+{
+       int i, j;
+       short int done;
+
+       i = 0;
+       done = 0;
+
+       while (!done && in[i] != '\0') {
+               if (_is_space(in[i])) {
+                       i++;
+               } else {
+                       done = 1;
+               }
+       }
+
+       j = 0;
+       while (in[i] != '\0') {
+               in[j++] = in[i++];
+       }
+
+       in[j] = '\0';
+
+       return 0;
+}
+
+static inline int _r_trim(char *in)
+{
+       int i;
+       short int done;
+
+       i = strlen(in) - 1;
+       done = 0;
+
+       while (!done && !(i < 0)) {
+               if (_is_space(in[i])) {
+                       in[i--] = '\0';
+               } else {
+                       done = 1;
+               }
+       }
+
+       return(0);
+}
+
+HAPI void quickpanel_common_util_char_trim(char *text)
+{
+       retif(text == NULL, , "invalid argument");
+
+       _l_trim(text);
+       _r_trim(text);
+}
+
+HAPI void quickpanel_common_util_char_replace(char *text, char s, char t)
+{
+       retif(text == NULL, , "invalid argument");
+
+       int i = 0, text_len = 0;
+
+       text_len = strlen(text);
+
+       for (i = 0; i < text_len; i++) {
+               if (*(text + i) == s) {
+                       *(text + i) = t;
+               }
+       }
+}
+
+HAPI void quickpanel_common_util_add_char_to_each_charactor(char *dst, const char *src, char t)
+{
+       retif(dst == NULL, , "invalid argument");
+       retif(src == NULL, , "invalid argument");
+
+       int i = 0, text_len = 0;
+
+       text_len = strlen(src);
+
+       for (i = 0; i < text_len; i++) {
+               *(dst + (i * 2)) = *(src + i);
+               *(dst + ((i * 2) + 1)) = t;
+       }
+}
+
+static void _char_set(char *dst, char s, int index, int size)
+{
+       if (index < size) {
+               *(dst + index) = s;
+       }
+}
+
+HAPI void quickpanel_common_util_phone_number_tts_make(char *dst, const char *src, int size)
+{
+       retif(dst == NULL, , "invalid argument");
+       retif(src == NULL, , "invalid argument");
+
+       int no_op = 0;
+       int i = 0, j = 0, text_len = 0;
+
+       text_len = strlen(src);
+
+       for (i = 0, j= 0; i < text_len; i++) {
+               if (no_op == 1) {
+                       _char_set(dst, *(src + i), j++, size);
+               } else {
+                       if (isdigit(*(src + i))) {
+                               if (i + 1 < text_len) {
+                                       if (*(src + i + 1) == '-' || *(src + i + 1) == _SPACE) {
+                                               _char_set(dst, *(src + i), j++, size);
+                                       } else {
+                                               _char_set(dst, *(src + i), j++, size);
+                                               _char_set(dst, _SPACE, j++, size);
+                                       }
+                               } else {
+                                       _char_set(dst, *(src + i), j++, size);
+                                       _char_set(dst, _SPACE, j++, size);
+                               }
+                       } else if (*(src + i) == '-') {
+                               no_op = 1;
+                               _char_set(dst, *(src + i), j++, size);
+                       } else {
+                               _char_set(dst, *(src + i), j++, size);
+                       }
+               }
+       }
+}
+
+HAPI int quickpanel_common_util_is_phone_number(const char *address)
+{
+       int digit_count = 0;
+       retif(address == NULL, 0, "address is NULL");
+
+       int addr_len = 0;
+       addr_len = strlen(address);
+
+       if (addr_len == 0) {
+               return 0;
+       }
+
+       /*  length check phone address should be longer than 2 and shorter than 40 */
+       if (addr_len > 2 && addr_len <= QP_UTIL_PHONE_NUMBER_MAX_LEN) {
+               const char *pszOneChar = address;
+
+               while (*pszOneChar) {
+                       if (isdigit(*pszOneChar)) {
+                               digit_count++;
+                       }
+
+                       ++pszOneChar;
+               }
+
+               pszOneChar = address;
+
+               if (*pszOneChar == '+') {
+                       ++pszOneChar;
+               }
+
+               while (*pszOneChar) {
+                       if (!isdigit(*pszOneChar)
+                                       && (*pszOneChar != '*') && (*pszOneChar != '#')
+                                       && (*pszOneChar != ' ')
+                                       && !((*pszOneChar == '-') && digit_count >= 7)) {
+                               return 0;
+                       }
+
+                       ++pszOneChar;
+               }
+
+               return 1;
+       } else {
+               DBG("invalid address length [%d]", addr_len);
+               return 0;
+       }
+}
+
+static void _current_popup_default_backkey_cb(void *data, Evas_Object *obj, void *event_info)
+{
+       Evas_Object *popup = data;
+       retif(popup == NULL, , "invalid argument");
+
+       if (popup!= NULL) {
+               evas_object_del(popup);
+               popup = NULL;
+       }
+}
+
+static void _current_popup_deleted_cb(void *data, Evas *e, Evas_Object *obj, void *event_info)
+{
+       retif(obj == NULL, , "obj is NULL");
+
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "invalid argument");
+
+       if (ad->popup == obj) {
+               ad->popup = NULL;
+       } else {
+               ERR("popup is created over the popup");
+       }
+}
+
+HAPI void quickpanel_common_ui_set_current_popup(Evas_Object *popup, Evas_Smart_Cb func_back)
+{
+       retif(popup == NULL, , "invalid argument");
+
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "invalid argument");
+
+       ad->popup = popup;
+       evas_object_event_callback_add(popup, EVAS_CALLBACK_DEL, _current_popup_deleted_cb, NULL);
+
+       if (func_back != NULL) {
+               evas_object_data_set(popup, EDATA_BACKKEY_CB, func_back);
+       } else {
+               evas_object_data_set(popup, EDATA_BACKKEY_CB, _current_popup_default_backkey_cb);
+       }
+}
+
+HAPI void quickpanel_common_ui_del_current_popup(void)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "invalid argument");
+
+       if (ad->popup != NULL) {
+               evas_object_del(ad->popup);
+               ad->popup = NULL;
+       }
+}
+
+HAPI void *quickpanel_common_ui_get_buffer_from_image(const char *file_path, size_t *memfile_size, char *ext, int ext_size)
+{
+       FILE *fp = NULL;
+       void *buffer = NULL;
+       char *buf_ext = NULL;
+
+       retif(file_path == NULL, NULL, "invalid data");
+
+       if (ext != NULL) {
+               buf_ext = ecore_file_strip_ext(file_path);
+               if (buf_ext != NULL) {
+                       strncpy(ext, buf_ext, ext_size);
+                       free(buf_ext);
+               }
+       }
+
+       fp = fopen(file_path, "r");
+       if (fp) {
+               struct stat stat_buf;
+               if (stat(file_path, &stat_buf) != 0) {
+                       ERR("Getting file information Error");
+                       goto err;
+               }
+
+               if (stat_buf.st_size > 0) {
+                       buffer = (void *)calloc(1, (size_t)stat_buf.st_size + 1);
+                       if (buffer == NULL) {
+                               ERR("failed to alloc a buffer");
+                               goto err;
+                       }
+                       int result = fread(buffer, sizeof(char), stat_buf.st_size, fp);
+                       if (result != stat_buf.st_size) {
+                               ERR("failed to read a file");
+                               free(buffer);
+                               buffer = NULL;
+                               goto err;
+                       }
+                       if (memfile_size != NULL) {
+                               *memfile_size = result;
+                       }
+               } else {
+                       if (memfile_size != NULL) {
+                               *memfile_size = 0;
+                       }
+               }
+       }
+
+err:
+       if (fp) {
+               fclose(fp);
+       }
+       return buffer;
+}
+
+HAPI char *quickpanel_common_ui_get_pkginfo_icon(const char *pkgid)
+{
+       int ret = 0;
+       char *icon_path = NULL;
+       char *icon_ret = NULL;
+       package_info_h package_info = NULL;
+
+       ret = package_manager_get_package_info(pkgid, &package_info);
+       if (ret != PACKAGE_MANAGER_ERROR_NONE) {
+               ERR("package_manager_get_package_info is failed id : %s %d", pkgid, ret);
+               return NULL;
+       }
+
+       ret = package_info_get_icon(package_info, &icon_path);
+       if (ret != PACKAGE_MANAGER_ERROR_NONE) {
+               ERR("package_info_get_icon is failed %d", ret);
+               return NULL;
+       }
+
+       if (icon_path) {
+               icon_ret = (char*)strdup(icon_path);
+       }
+
+       package_info_destroy(package_info);
+
+       return icon_ret;
+}
+
+HAPI char *quickpanel_common_ui_get_pkginfo_label(const char *pkgid)
+{
+       int ret = 0;
+       char *label = NULL;
+       char *label_ret = NULL;
+       package_info_h package_info = NULL;
+
+       ret = package_manager_get_package_info(pkgid, &package_info);
+       if (ret != PACKAGE_MANAGER_ERROR_NONE) {
+               ERR("package_manager_get_package_info is failed %d", ret);
+               return NULL;
+       }
+
+       ret = package_info_get_label(package_info, &label);
+       if (ret != PACKAGE_MANAGER_ERROR_NONE) {
+               ERR("package_info_get_label is failed %d", ret);
+               return NULL;
+       }
+
+       if (label) {
+               label_ret = (char*)strdup(label);
+       }
+
+       package_info_destroy(package_info);
+
+       return label_ret;
+
+}
+
+HAPI int quickpanel_common_ui_is_package_exist(const char *pkgid)
+{
+       int ret = 0;
+       retif(pkgid == NULL, 0, "invalid parameter");
+
+       package_info_h package_info = NULL;
+
+       ret = package_manager_get_package_info(pkgid, &package_info);
+       if (ret == PACKAGE_MANAGER_ERROR_NO_SUCH_PACKAGE) {
+               DBG("package %s isn't exist", pkgid);
+               return 0;
+       }
+
+       if (package_info) {
+               package_info_destroy(package_info);
+       }
+
+       return 1;
+}
diff --git a/daemon/common.h b/daemon/common.h
new file mode 100755 (executable)
index 0000000..3b9a541
--- /dev/null
@@ -0,0 +1,155 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __QP_COMMON_H_
+#define __QP_COMMON_H_
+
+
+#define QP_OK  (0)
+#define QP_FAIL        (-1)
+#define QP_UTIL_PHONE_NUMBER_MAX_LEN   40
+#define EDATA_BACKKEY_CB "bk_cb"
+
+#ifdef _DLOG_USED
+#undef LOG_TAG
+#define LOG_TAG "QUICKPANEL"
+#include <dlog.h>
+
+#define HAPI __attribute__((visibility("hidden")))
+
+#define DBG(fmt , args...) \
+       do { \
+               LOGD("[%s : %d] "fmt"\n", __func__, __LINE__, ##args); \
+       } while (0)
+
+#define INFO(fmt , args...) \
+       do { \
+               LOGI("[%s : %d] "fmt"\n", __func__, __LINE__, ##args); \
+       } while (0)
+
+#define WARN(fmt , args...) \
+       do { \
+               LOGI("[%s : %d] "fmt"\n", __func__, __LINE__, ##args); \
+       } while (0)
+
+#define ERR(fmt , args...) \
+       do { \
+               LOGE("[%s : %d] "fmt"\n", __func__, __LINE__, ##args); \
+       } while (0)
+
+#define SDBG(fmt , args...) \
+       do { \
+               SECURE_LOGD("[%s : %d] "fmt"\n", __func__, __LINE__, ##args); \
+       } while (0)
+
+#define SINFO(fmt , args...) \
+       do { \
+               SECURE_LOGI("[%s : %d] "fmt"\n", __func__, __LINE__, ##args); \
+       } while (0)
+
+#define SERR(fmt , args...) \
+       do { \
+               SECURE_LOGE("[%s : %d] "fmt"\n", __func__, __LINE__, ##args); \
+       } while (0)
+
+#elif FILE_DEBUG /*_DLOG_USED*/
+#define DBG(fmt , args...) \
+       do { \
+               debug_printf("[D]%s : %d] "fmt"\n", \
+                               __func__, __LINE__, ##args); \
+       } while (0)
+
+#define INFO(fmt , args...) \
+       do { \
+               debug_printf("[I][%s : %d] "fmt"\n",\
+                               __func__, __LINE__, ##args); \
+       } while (0)
+
+#define WARN(fmt , args...) \
+       do { \
+               debug_printf("[W][%s : %d] "fmt"\n", \
+                               __func__, __LINE__, ##args); \
+       } while (0)
+
+#define ERR(fmt , args...) \
+       do { \
+               debug_printf("[E][%s : %d] "fmt"\n", \
+                               __func__, __LINE__, ##args); \
+       } while (0)
+
+#else /*_DLOG_USED*/
+#define DBG(fmt , args...) \
+       do { \
+               fprintf("[D][%s : %d] "fmt"\n", __func__, __LINE__, ##args); \
+       } while (0)
+
+#define INFO(fmt , args...) \
+       do { \
+               fprintf("[I][%s : %d] "fmt"\n", __func__, __LINE__, ##args); \
+       } while (0)
+
+#define WARN(fmt , args...) \
+       do { \
+               fprintf("[W][%s : %d] "fmt"\n", __func__, __LINE__, ##args); \
+       } while (0)
+
+#define ERR(fmt , args...) \
+       do { \
+               fprintf("[E][%s : %d] "fmt"\n", __func__, __LINE__, ##args); \
+       } while (0)
+#endif /*_DLOG_USED*/
+
+#define msgif(cond, str, args...) do { \
+       if (cond) { \
+               ERR(str, ##args);\
+       } \
+} while (0);
+
+#define retif(cond, ret, str, args...) do { \
+       if (cond) { \
+               ERR(str, ##args);\
+               return ret;\
+       } \
+} while (0);
+
+#define retif_nomsg(cond, ret) do { \
+       if (cond) { \
+               return ret;\
+       } \
+} while (0);
+
+#define gotoif(cond, target, str, args...) do { \
+       if (cond) { \
+               WARN(str, ##args); \
+               goto target; \
+       } \
+} while (0);
+
+extern void quickpanel_common_util_char_trim(char *text);
+extern void quickpanel_common_util_char_replace(char *text, char s, char t);
+extern void quickpanel_common_util_add_char_to_each_charactor(char *dst, const char *src, char t);
+extern int quickpanel_common_util_is_phone_number(const char *address);
+extern void quickpanel_common_util_phone_number_tts_make(char *dst, const char *src, int size);
+extern void quickpanel_common_ui_set_current_popup(Evas_Object *popup, Evas_Smart_Cb func_close);
+extern void quickpanel_common_ui_del_current_popup(void);
+extern void *quickpanel_common_ui_get_buffer_from_image(const char *file_path, size_t *memfile_size, char *ext, int ext_size);
+extern char *quickpanel_common_ui_get_pkginfo_icon(const char *pkgid);
+extern char *quickpanel_common_ui_get_pkginfo_label(const char *pkgid);
+extern int quickpanel_common_ui_is_package_exist(const char *pkgid);
+
+#endif                         /* __QP_COMMON_H_ */
diff --git a/daemon/common_uic.c b/daemon/common_uic.c
new file mode 100755 (executable)
index 0000000..7359a7d
--- /dev/null
@@ -0,0 +1,327 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#include <Elementary.h>
+#include <sys/utsname.h>
+#include <Ecore_Input.h>
+
+#include <app.h>
+#include <vconf.h>
+#include <notification.h>
+#include <app_control_internal.h>
+#include <bundle_internal.h>
+#include <system_info.h>
+#include <common_uic.h>
+
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "common.h"
+#include "quickpanel-ui.h"
+
+
+/* binary information */
+#define QP_EMUL_STR            "Emulator"
+#define DEL_TIMER_VALUE        0.480
+#define SYSTEM_INFO_KEY_MODEL "http://tizen.org/system/model_name"
+static Ecore_Timer *_close_timer = NULL;
+
+
+static void _quickpanel_move_data_to_service(const char *key, const char *val, void *data)
+{
+       retif(data == NULL || key == NULL || val == NULL, , "Invialid parameter!");
+
+       app_control_h service = data;
+       app_control_add_extra_data(service, key, val);
+}
+
+HAPI Evas_Object *quickpanel_uic_load_edj(Evas_Object * parent, const char *file, const char *group, int is_just_load)
+{
+       Eina_Bool r;
+       Evas_Object *eo = NULL;
+
+       retif(parent == NULL, NULL, "Invalid parameter!");
+
+       eo = elm_layout_add(parent);
+       retif(eo == NULL, NULL, "Failed to add layout object!");
+
+       r = elm_layout_file_set(eo, file, group);
+       retif(r != EINA_TRUE, NULL, "Failed to set edje object file[%s-%s]!", file, group);
+
+       evas_object_size_hint_weight_set(eo, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       evas_object_size_hint_align_set(eo, EVAS_HINT_FILL, EVAS_HINT_FILL);
+
+       if (is_just_load == 1) {
+               elm_win_resize_object_add(parent, eo);
+       }
+       evas_object_show(eo);
+
+       return eo;
+}
+
+HAPI int quickpanel_uic_is_opened(void)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, 0, "invalid data.");
+
+       return ad->is_opened;
+}
+
+HAPI int quickpanel_uic_is_suspended(void)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, 0, "invalid data.");
+
+       return ad->is_suspended;
+}
+
+HAPI int quickpanel_uic_is_emul(void)
+{
+       int is_emul = 0;
+       char *info = NULL;
+
+       if (system_info_get_platform_string(SYSTEM_INFO_KEY_MODEL, &info) == 0) {
+               if (info == NULL) {
+                       return 0;
+               }
+               if (!strncmp(QP_EMUL_STR, info, strlen(info))) {
+                       is_emul = 1;
+               }
+       }
+
+       free(info);
+
+       return is_emul;
+}
+
+HAPI void quickpanel_uic_initial_resize(Evas_Object *obj, int height)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "invalid data.");
+
+       height = (height % 2 != 0) ? height + 1 : height;
+
+       if (ad->angle == 90 || ad->angle == 270) {
+               evas_object_resize(obj, ad->win_height, height * ad->scale);
+       } else  {
+               evas_object_resize(obj, ad->win_width, height * ad->scale);
+       }
+}
+
+HAPI int quickpanel_uic_launch_app(char *app_id, void *data)
+{
+       int ret = APP_CONTROL_ERROR_NONE;
+       app_control_h service = NULL;
+       char *app_id_from_service = NULL;
+
+       retif(app_id == NULL && data == NULL, APP_CONTROL_ERROR_INVALID_PARAMETER, "Invialid parameter!");
+
+       ret = app_control_create(&service);
+       if (ret != APP_CONTROL_ERROR_NONE) {
+               ERR("app_control_create() return error : %d", ret);
+               return ret;
+       }
+       retif(service == NULL, APP_CONTROL_ERROR_INVALID_PARAMETER, "fail to create service handle!");
+
+       if (app_id != NULL) {
+               app_control_set_operation(service, APP_CONTROL_OPERATION_DEFAULT);
+               app_control_set_app_id(service, app_id);
+
+               if (data != NULL) {
+                       bundle_iterate((bundle *)data, _quickpanel_move_data_to_service, service);
+               }
+       } else {
+               if (data != NULL) {
+                       ret = app_control_import_from_bundle(service, data);
+                       if (ret != APP_CONTROL_ERROR_NONE) {
+                               ERR("Failed to import[%d]", ret);
+                       }
+               }
+       }
+
+       ret = app_control_send_launch_request(service, NULL, NULL);
+       if (ret != APP_CONTROL_ERROR_NONE) {
+               ERR("app_control_send_launch_request() is failed : %d", ret);
+               app_control_get_app_id(service, &app_id_from_service);
+               if (app_id_from_service != NULL) {
+                       quickpanel_uic_launch_app_inform_result(app_id_from_service, ret);
+                       free(app_id_from_service);
+               } else {
+                       quickpanel_uic_launch_app_inform_result(app_id, ret);
+               }
+               app_control_destroy(service);
+               return ret;
+       }
+       app_control_destroy(service);
+       return ret;
+}
+
+HAPI int quickpanel_uic_launch_ug_by_appcontrol(const char *package, void *data)
+{
+       int ret = APP_CONTROL_ERROR_NONE;
+       app_control_h service = NULL;
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, APP_CONTROL_ERROR_INVALID_PARAMETER, "ad null");
+       retif(package == NULL, APP_CONTROL_ERROR_INVALID_PARAMETER, "package null");
+
+       ret = app_control_create(&service);
+       if (ret != APP_CONTROL_ERROR_NONE) {
+               ERR("app_control_create() return error : %d", ret);
+               return ret;
+       }
+       retif(service == NULL, APP_CONTROL_ERROR_INVALID_PARAMETER, "fail to create service handle!");
+
+       app_control_set_operation(service, APP_CONTROL_OPERATION_DEFAULT);
+       app_control_set_app_id(service, package);
+
+       if (data != NULL) {
+               bundle_iterate((bundle *)data, _quickpanel_move_data_to_service, service);
+       }
+
+       ret = app_control_send_launch_request(service, NULL, NULL);
+       if (ret != APP_CONTROL_ERROR_NONE) {
+               ERR("app_control_send_launch_request() is failed : %d", ret);
+               app_control_destroy(service);
+               return ret;
+       }
+       app_control_destroy(service);
+       return ret;
+}
+
+HAPI void quickpanel_uic_launch_app_inform_result(const char *pkgname, int retcode)
+{
+       retif(retcode == APP_CONTROL_ERROR_NONE, , "retcode = APP_CONTROL_ERROR_NONE!");
+       retif(pkgname == NULL && retcode != APP_CONTROL_ERROR_APP_NOT_FOUND, , "Invialid parameter!");
+
+       const char *msg = NULL;
+       char *app_label = NULL;
+
+       if (retcode == APP_CONTROL_ERROR_APP_NOT_FOUND) {
+               notification_status_message_post(_NOT_LOCALIZED("Unable to find application to perform this action."));
+       } else {
+               Eina_Strbuf *strbuf = eina_strbuf_new();
+               char *format = _("IDS_QP_TPOP_UNABLE_TO_OPEN_PS");
+
+               if (strbuf != NULL) {
+                       app_label = quickpanel_common_ui_get_pkginfo_label(pkgname);
+                       if (app_label != NULL) {
+                               eina_strbuf_append_printf(strbuf, format, app_label);
+                               free(app_label);
+                       } else {
+                               eina_strbuf_append_printf(strbuf, format, pkgname);
+                       }
+                       eina_strbuf_append_printf(strbuf, "(%x)", retcode);
+                       msg = eina_strbuf_string_get(strbuf);
+
+                       if (msg != NULL) {
+                               notification_status_message_post(msg);
+                       }
+                       eina_strbuf_free(strbuf);
+               }
+       }
+}
+
+HAPI void quickpanel_uic_open_quickpanel(int reason)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+
+       DBG("reason:%d", reason);
+
+       retif(ad == NULL, , "Invalid parameter!");
+       retif(ad->win == NULL, , "Invalid parameter!");
+
+       ERR("Not yet implemented");
+
+}
+
+HAPI void quickpanel_uic_opened_reason_set(int reason)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "Invalid parameter!");
+
+       ad->opening_reason = reason;
+}
+
+HAPI int quickpanel_uic_opened_reason_get(void)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, OPENED_NO_REASON, "Invalid parameter!");
+
+       return ad->opening_reason;
+}
+
+static void _quickpanel_close(void)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+
+       DBG("");
+
+       if (!ad || !ad->win) {
+               ERR("Invalid parameter");
+               return;
+       }
+
+       int ret = 0;
+       ret = tzsh_quickpanel_service_hide(ad->quickpanel_service);
+       if(ret != 0) {
+               ERR("failed tzsh_quickpanel_service_hide");
+       }
+
+}
+
+static Eina_Bool _quickpanel_close_timer_cb(void *data)
+{
+       if (_close_timer != NULL) {
+               _close_timer = NULL;
+       }
+       _quickpanel_close();
+
+       return ECORE_CALLBACK_CANCEL;
+}
+
+HAPI void quickpanel_uic_close_quickpanel(bool is_check_lock, int is_delay_needed) {
+       int ret = 0;
+       int is_lock_launched = VCONFKEY_IDLE_UNLOCK;
+
+       if (is_check_lock == true) {
+               if (vconf_get_int(VCONFKEY_IDLE_LOCK_STATE, &is_lock_launched) == 0) {
+                       if (is_lock_launched == VCONFKEY_IDLE_LOCK) {
+                               ret = vconf_set_int(VCONFKEY_IDLE_LOCK_STATE, VCONFKEY_IDLE_UNLOCK);
+                               if (ret == 0) {
+                                       ERR("unlock the lockscreen from quickpanel");
+                               } else {
+                                       ERR("failed to unlock the lockscreen from quickpanel");
+                               }
+                       }
+               }
+       }
+
+       if (is_delay_needed) {
+               if( _close_timer == NULL ) {
+                       _close_timer = ecore_timer_add(DEL_TIMER_VALUE, _quickpanel_close_timer_cb, NULL);
+               }
+       } else {
+               _quickpanel_close();
+       }
+}
+
+HAPI void quickpanel_uic_toggle_openning_quickpanel(void)
+{
+       /* TO DO */
+}
diff --git a/daemon/common_uic.h b/daemon/common_uic.h
new file mode 100755 (executable)
index 0000000..2191b25
--- /dev/null
@@ -0,0 +1,42 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __QP_COMMON_UIC_H_
+#define __QP_COMMON_UIC_H_
+
+typedef enum {
+       OPENED_NO_REASON = 0,
+       OPENED_BY_CMD_HIDE_LAUNCH = 1,
+       OPENED_BY_CMD_SHOW_SETTINGS = 2,
+} qp_open_reason;
+
+extern Evas_Object *quickpanel_uic_load_edj(Evas_Object * parent, const char *file, const char *group, int is_just_load);
+extern int quickpanel_uic_launch_app(char *app_id, void *data);
+extern int quickpanel_uic_launch_ug_by_appcontrol(const char *package, void *data);
+extern int quickpanel_uic_is_emul(void);
+extern int quickpanel_uic_is_suspended(void);
+extern int quickpanel_uic_is_opened(void);
+extern void quickpanel_uic_launch_app_inform_result(const char *pkgname, int retcode);
+extern void quickpanel_uic_initial_resize(Evas_Object *obj, int height);
+extern void quickpanel_uic_close_quickpanel(bool is_check_lock, int is_delay_needed);
+extern void quickpanel_uic_open_quickpanel(int reason);
+extern void quickpanel_uic_toggle_openning_quickpanel(void);
+extern void quickpanel_uic_opened_reason_set(int reason);
+extern int quickpanel_uic_opened_reason_get(void);
+
+#endif                         /* __QP_COMMON_UIC_H_ */
diff --git a/daemon/datetime/datetime.c b/daemon/datetime/datetime.c
new file mode 100755 (executable)
index 0000000..a1674ec
--- /dev/null
@@ -0,0 +1,361 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <glib.h>
+#include <string.h>
+#include <Elementary.h>
+
+#include <app.h>
+#include <vconf.h>
+#include <notification.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <sound_manager.h>
+#include <E_DBus.h>
+
+#include "common.h"
+#include "common_uic.h"
+#include "quickpanel-ui.h"
+#include "list_util.h"
+#include "quickpanel_def.h"
+#include "modules.h"
+#include "util-time.h"
+#include "media.h"
+
+#ifdef QP_SCREENREADER_ENABLE
+#include "accessibility.h"
+#endif
+
+#ifdef QP_EMERGENCY_MODE_ENABLE
+#include "emergency_mode.h"
+#endif
+
+static int _init(void *data);
+static int _fini(void *data);
+
+#define PKG_SETTING_EDIT "quickpanel-setting-efl"
+#define QP_TIMEDATE_SETTING_UG "setting-time-efl"
+#define E_DATA_EDITING_VISIBILITT "editing_visible"
+#define E_DATA_TIME_N_DATE_EVENT       "time_n_date_event"
+
+QP_Module qp_datetime_view = {
+       .name = "qp_datetime_view",
+       .init = _init,
+       .fini = _fini,
+       .suspend = NULL,
+       .resume = NULL,
+       .lang_changed = NULL,
+       .refresh = NULL,
+};
+
+static Evas_Object *_datetime_view_get(void);
+
+static void _flag_set(Evas_Object *container, const char *key, int value)
+{
+       retif(container == NULL, , "invalid parameter");
+       retif(key == NULL, , "invalid parameter");
+
+       evas_object_data_set(container, key, (void *)(long)(value));
+}
+
+static int _flag_get(Evas_Object *container, const char *key)
+{
+       retif(container == NULL, 0, "invalid parameter");
+       retif(key == NULL, 0, "invalid parameter");
+
+       return (int)(long)evas_object_data_get(container, key);
+}
+
+static void _set_text_to_part(Evas_Object *obj, const char *part, const char *text)
+{
+       const char *old_text = NULL;
+
+       retif(obj == NULL, , "Invalid parameter!");
+       retif(part == NULL, , "Invalid parameter!");
+       retif(text == NULL, , "Invalid parameter!");
+
+       old_text = elm_object_part_text_get(obj, part);
+       if (old_text != NULL) {
+               if (strcmp(old_text, text) == 0) {
+                       return;
+               }
+       }
+
+       elm_object_part_text_set(obj, part, text);
+}
+
+static void _text_time_clicked_cb(void *data, Evas_Object *obj, void *event_info)
+{
+       Evas_Object *view = _datetime_view_get();
+       int ret;
+
+       if (view) {
+               if (_flag_get(view, E_DATA_TIME_N_DATE_EVENT) == 0) {
+                       DBG("Time & date area click is event disabled");
+                       return;
+               }
+       }
+
+       quickpanel_media_play_feedback();
+
+       ret = quickpanel_uic_launch_ug_by_appcontrol(QP_TIMEDATE_SETTING_UG, NULL);
+       quickpanel_uic_launch_app_inform_result(QP_TIMEDATE_SETTING_UG, ret);
+
+       quickpanel_uic_close_quickpanel(true, 1);
+}
+
+static void _button_setting_clicked_cb(void *data, Evas_Object *obj, void *event_info)
+{
+       quickpanel_media_play_feedback();
+
+#ifdef QP_EMERGENCY_MODE_ENABLE
+       if (quickpanel_emergency_mode_is_on()) {
+               quickpanel_uic_launch_app(PACKAGE_EMERGENCY_MODE_SETTING, NULL);
+       } else {
+               quickpanel_uic_launch_app(QP_SETTING_PKG_SETTING, NULL);
+       }
+#else
+       quickpanel_uic_launch_app(QP_SETTING_PKG_SETTING, NULL);
+#endif
+       quickpanel_uic_close_quickpanel(true, 1);
+}
+
+static Evas_Object *_datetime_view_create(Evas_Object *parent)
+{
+       Evas_Object *focus = NULL;
+       Eina_Bool ret = EINA_TRUE;
+       Evas_Object *view = NULL;
+
+       retif(parent == NULL, NULL, "Invalid parameter!");
+
+       view = elm_layout_add(parent);
+
+       if (view != NULL) {
+               ret = elm_layout_file_set(view, DEFAULT_EDJ,
+                               "quickpanel/datetime");
+               if (ret == EINA_FALSE) {
+                       ERR("failed to load quickpanel/datetime layout");
+               }
+               evas_object_size_hint_weight_set(view, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+               evas_object_size_hint_align_set(view, EVAS_HINT_FILL, EVAS_HINT_FILL);
+               quickpanel_uic_initial_resize(view, QP_DATE_H);
+
+               focus = quickpanel_accessibility_ui_get_focus_object(view);
+               elm_object_part_content_set(view, "focus.datetime", focus);
+               evas_object_smart_callback_add(focus, "clicked", _text_time_clicked_cb, view);
+
+               focus = quickpanel_accessibility_ui_get_focus_object(view);
+               elm_object_part_content_set(view, "focus.setting", focus);
+               evas_object_smart_callback_add(focus, "clicked", _button_setting_clicked_cb, view);
+
+               _flag_set(view, E_DATA_EDITING_VISIBILITT, 0);
+
+#ifdef QP_EMERGENCY_MODE_ENABLE
+               if (quickpanel_emergency_mode_is_on()) {
+                       _flag_set(view, E_DATA_TIME_N_DATE_EVENT, 0);
+                       elm_object_signal_emit(view, "timendate.click.disable", "prog");
+               } else {
+#endif
+                       _flag_set(view, E_DATA_TIME_N_DATE_EVENT, 1);
+                       elm_object_signal_emit(view, "timendate.click.enable", "prog");
+#ifdef QP_EMERGENCY_MODE_ENABLE
+               }
+#endif
+
+               evas_object_show(view);
+       }
+
+       return view;
+}
+
+static Evas_Object *_datetime_view_get(void) {
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, NULL, "invalid argument");
+       retif(ad->view_root == NULL, NULL, "invalid argument");
+
+       return elm_object_part_content_get(ad->view_root
+                       , "qp.base.datetime.swallow");
+}
+
+static void _datetime_view_attach(void *data)
+{
+       Evas_Object *view = NULL;
+       struct appdata *ad = data;
+       retif(ad == NULL, ,"invalid parameter");
+       retif(ad->view_root == NULL, ,"invalid parameter");
+
+       view = _datetime_view_create(ad->view_root);
+       if (view != NULL) {
+               elm_object_part_content_set(ad->view_root, "qp.base.datetime.swallow", view);
+       }
+}
+
+static void _datetime_view_deattach(void *data)
+{
+       Evas_Object *view = NULL;
+       struct appdata *ad = data;
+       retif(ad == NULL, ,"invalid parameter");
+       retif(ad->view_root == NULL, ,"invalid parameter");
+
+       view = elm_object_part_content_unset(ad->view_root, "qp.base.datetime.swallow");
+       if (view != NULL) {
+               evas_object_del(view);
+               view = NULL;
+       }
+}
+
+static int _init(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, QP_FAIL,"invalid parameter");
+
+       _datetime_view_attach(ad);
+
+       return QP_OK;
+}
+
+static int _fini(void *data)
+{
+       _datetime_view_deattach(data);
+
+       return QP_OK;
+}
+
+HAPI void quickpanel_datetime_datentime_event_set(int is_clickable)
+{
+       Evas_Object *view = _datetime_view_get();
+
+       DBG("date n time clickable set[%d]", is_clickable);
+
+       if (view != NULL) {
+               if (is_clickable == 1) {
+                       if (_flag_get(view, E_DATA_TIME_N_DATE_EVENT) == 0) {
+                               _flag_set(view, E_DATA_TIME_N_DATE_EVENT, 1);
+                               elm_object_signal_emit(view, "timendate.click.enable", "prog");
+                       }
+               } else {
+                       if (_flag_get(view, E_DATA_TIME_N_DATE_EVENT) == 1) {
+                               _flag_set(view, E_DATA_TIME_N_DATE_EVENT, 0);
+                               elm_object_signal_emit(view, "timendate.click.disable", "prog");
+                       }
+               }
+       }
+}
+
+HAPI void quickpanel_datetime_editing_icon_visibility_set(int is_visible)
+{
+       Evas_Object *view = _datetime_view_get();
+
+       DBG("visibility set:%d", is_visible);
+
+       if (view != NULL) {
+               if (is_visible == 1) {
+                       if (_flag_get(view, E_DATA_EDITING_VISIBILITT) == 0) {
+                               _flag_set(view, E_DATA_EDITING_VISIBILITT, 1);
+                               elm_object_signal_emit(view, "button,editing,show", "prog");
+                       }
+               } else {
+                       if (_flag_get(view, E_DATA_EDITING_VISIBILITT) == 1) {
+                               _flag_set(view, E_DATA_EDITING_VISIBILITT, 0);
+                               elm_object_signal_emit(view, "button,editing,hide", "prog");
+                       }
+               }
+       }
+}
+
+HAPI void quickpanel_datetime_view_update(char *date, char *time, char *meridiem, int meridiem_type)
+{
+       Evas_Object *view = NULL;
+
+       Eina_Strbuf *strbuf_date = NULL;
+       Eina_Strbuf *strbuf_time = NULL;
+       Eina_Strbuf *strbuf_access = NULL;
+
+       view = _datetime_view_get();
+
+       if (!view) {
+               ERR("view == NULL");
+               return;
+       }
+
+       strbuf_date = eina_strbuf_new();
+       if(!strbuf_date) {
+               ERR("strbuf_date == NULL");
+               return;
+       }
+
+       strbuf_time = eina_strbuf_new();
+       if(!strbuf_time) {
+               ERR("strbuf_time == NULL");
+               eina_strbuf_free(strbuf_date);
+               return;
+       }
+
+       strbuf_access = eina_strbuf_new();
+       if(!strbuf_access) {
+               ERR("strbuf_access == NULL");
+               eina_strbuf_free(strbuf_date);
+               eina_strbuf_free(strbuf_time);
+               return;
+       }
+
+
+       DBG("update time: %s %s %s", date, time, meridiem);
+
+       if (date != NULL) {
+               eina_strbuf_append_printf(strbuf_date, "%s", date);
+               eina_strbuf_append_printf(strbuf_access, "%s ", date);
+       }
+
+       eina_strbuf_ltrim(strbuf_date);
+
+       // -------------------------------------------------------------------------------------
+
+       if (meridiem_type == UTIL_TIME_MERIDIEM_TYPE_PRE && meridiem != NULL && strlen(meridiem) != 0) {
+               eina_strbuf_append_printf(strbuf_time, "<ampm>%s</> ", meridiem);
+               eina_strbuf_append_printf(strbuf_access, "%s ", meridiem);
+       }
+
+       if (time != NULL) {
+               eina_strbuf_append_printf(strbuf_time, "<time>%s</>", time);
+               eina_strbuf_append_printf(strbuf_access, "%s ", time);
+       }
+
+       if (meridiem_type == UTIL_TIME_MERIDIEM_TYPE_POST && meridiem != NULL && strlen(meridiem) != 0) {
+               eina_strbuf_append_printf(strbuf_time, " <ampm>%s</>", meridiem);
+               eina_strbuf_append_printf(strbuf_access, "%s ", meridiem);
+       }
+
+       eina_strbuf_ltrim(strbuf_time);
+
+       // -------------------------------------------------------------------------------------
+
+       LOGI("DATE STR SET: %s", eina_strbuf_string_get(strbuf_time));
+
+       _set_text_to_part(view, "text.date", eina_strbuf_string_get(strbuf_date));
+       _set_text_to_part(view, "text.time", eina_strbuf_string_get(strbuf_time));
+
+       quickpanel_accessibility_screen_reader_data_set(view, "focus.datetime", "", (char *)eina_strbuf_string_get(strbuf_access));
+
+       eina_strbuf_free(strbuf_date);
+       eina_strbuf_free(strbuf_time);
+       eina_strbuf_free(strbuf_access);
+
+       quickpanel_accessibility_screen_reader_data_set(view
+                       , "focus.setting", "", _NOT_LOCALIZED("Settings"));
+
+}
diff --git a/daemon/datetime/datetime.h b/daemon/datetime/datetime.h
new file mode 100755 (executable)
index 0000000..f17fe11
--- /dev/null
@@ -0,0 +1,26 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __DATETIME_H__
+#define __DATETIME_H__
+
+extern void quickpanel_datetime_datentime_event_set(int is_clickable);
+extern void quickpanel_datetime_editing_icon_visibility_set(int is_visible);
+extern void quickpanel_datetime_view_update(char *date, char *time, char *meridiem, int meridiem_type);
+
+#endif /* __DATETIME_H__ */
diff --git a/daemon/datetime/util-time.c b/daemon/datetime/util-time.c
new file mode 100755 (executable)
index 0000000..dbc49ed
--- /dev/null
@@ -0,0 +1,899 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#include <Elementary.h>
+#include <ctype.h>
+#include <glib.h>
+
+#include <unicode/utypes.h>
+#include <unicode/putil.h>
+#include <unicode/uiter.h>
+#include <unicode/udat.h>
+#include <unicode/udatpg.h>
+#include <unicode/ustring.h>
+
+#include <app_control.h>
+#include <vconf.h>
+#include <vconf-keys.h>
+#include <dlog.h>
+#include <system_settings.h>
+#include <utils_i18n.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <notification.h>
+#include <E_DBus.h>
+
+#include "common.h"
+
+#include "quickpanel-ui.h"
+#include "util-time.h"
+#include "datetime.h"
+#include "noti_node.h"
+#include "noti.h"
+
+#define TIME_ZONEINFO_PATH      "/usr/share/zoneinfo/"
+#define TIME_ZONEINFO_PATH_LEN  (strlen(TIME_ZONEINFO_PATH))
+#define BUF_FORMATTER 64
+
+static const char *colon = ":";
+static const char *ratio = "&#x2236;";
+static int _init(void *data);
+static int _fini(void *data);
+static void _lang_changed(void *data);
+static void _util_time_heartbeat_do(void);
+
+
+
+QP_Module qp_datetime_controller = {
+       .name = "qp_datetime_controller",
+       .init = _init,
+       .fini = _fini,
+       .suspend = NULL,
+       .resume = NULL,
+       .lang_changed = _lang_changed,
+       .refresh = NULL,
+};
+
+static struct info {
+       int is_initialized;
+       Ecore_Timer *timer;
+       int is_timer_enabled;
+       UDateFormat *formatter_date;
+       UDateFormat *formatter_time;
+       UDateFormat *formatter_ampm;
+       UDateTimePatternGenerator *generator;
+       UDateTimePatternGenerator *date_generator;
+       int timeformat;
+       char *timeregion_format;
+       char *dateregion_format;
+       char *timezone_id;
+       Eina_Bool is_pre_meridiem;
+} s_info = {
+       .is_initialized = 0,
+       .timer = NULL,
+       .is_timer_enabled = 0,
+       .formatter_date = NULL,
+       .formatter_time = NULL,
+       .formatter_ampm = NULL,
+       .generator = NULL,
+       .date_generator = NULL,
+       .timeformat = QP_TIME_FORMAT_24,
+       .timeregion_format = NULL,
+       .dateregion_format = NULL,
+       .timezone_id = NULL,
+       .is_pre_meridiem = EINA_FALSE,
+};
+
+static Eina_Bool _timer_cb(void *data);
+
+static UChar *uastrcpy(const char *chars)
+{
+       int len = 0;
+       UChar *str = NULL;
+       len = strlen(chars);
+       str = (UChar *) malloc(sizeof(UChar) *(len + 1));
+       if (!str) {
+               return NULL;
+       }
+       u_uastrcpy(str, chars);
+       return str;
+}
+
+static void ICU_set_timezone(const char *timezone)
+{
+       DBG("ICU_set_timezone = %s ", timezone);
+       UErrorCode ec = U_ZERO_ERROR;
+       UChar *str = uastrcpy(timezone);
+       retif(str == NULL, , "uastrcpy error!");
+
+       ucal_setDefaultTimeZone(str, &ec);
+       if (U_SUCCESS(ec)) {
+               DBG("ucal_setDefaultTimeZone() SUCCESS ");
+       } else {
+               ERR("ucal_setDefaultTimeZone() FAILED : %s ",
+                               u_errorName(ec));
+       }
+       free(str);
+}
+
+static char *_get_locale(void)
+{
+       char locale_tmp[32] = { 0, };
+       char *locale = NULL; //vconf_get_str(VCONFKEY_REGIONFORMAT);
+       int ret = 0;
+
+       ret = system_settings_get_value_string(SYSTEM_SETTINGS_KEY_LOCALE_COUNTRY, &locale);
+       msgif(ret != SYSTEM_SETTINGS_ERROR_NONE, "failed to ignore key(SYSTEM_SETTINGS_KEY_LOCALE_COUNTRY) : %d", ret);
+
+       if (locale == NULL) {
+               ERR("vconf_get_str() failed : region format");
+               return strdup("en_GB");
+       }
+
+       strncpy(locale_tmp, locale, sizeof(locale_tmp) - 1);
+
+       // remove .UTF-8
+       if (strlen(locale_tmp) > 0) {
+               char *p = strstr(locale_tmp, ".UTF-8");
+               if (p) {
+                       *p = 0;
+               }
+       }
+
+       free(locale);
+
+       if (strlen(locale_tmp) > 0) {
+               return strdup(locale_tmp);
+       }
+
+       return strdup("en_GB");
+}
+
+/*static char *_get_locale_for_date(void)
+  {
+  char *locale = vconf_get_str(VCONFKEY_REGIONFORMAT);
+  if (locale == NULL) {
+  ERR("vconf_get_str() failed : region format");
+  return strdup("en_GB.UTF8");
+  }
+
+  if (strlen(locale) > 0) {
+  return locale;
+  }
+
+  return strdup("en_GB.UTF8");
+  }*/
+
+static inline char *_extend_heap(char *buffer, int *sz, int incsz)
+{
+       char *tmp;
+
+       *sz += incsz;
+       tmp = realloc(buffer, *sz);
+       if (!tmp) {
+               ERR("Heap");
+               return NULL;
+       }
+
+       return tmp;
+}
+
+static char *_string_replacer(char *src, const char *pattern, const char *replace)
+{
+       char *ptr;
+       char *tmp = NULL;
+       char *ret = NULL;
+       int idx = 0;
+       int out_idx = 0;
+       int out_sz = 0;
+       enum {
+               STATE_START,
+               STATE_FIND,
+               STATE_CHECK,
+               STATE_END,
+       } state;
+
+       if (!src || !pattern) {
+               return NULL;
+       }
+
+       out_sz = strlen(src);
+       ret = strdup(src);
+       if (!ret) {
+               ERR("Heap");
+               return NULL;
+       }
+
+       out_idx = 0;
+       for (state = STATE_START, ptr = src; state != STATE_END; ptr++) {
+               switch (state) {
+               case STATE_START:
+                       if (*ptr == '\0') {
+                               state = STATE_END;
+                       } else if (!isblank(*ptr)) {
+                               state = STATE_FIND;
+                               ptr--;
+                       }
+                       break;
+               case STATE_FIND:
+                       if (*ptr == '\0') {
+                               state = STATE_END;
+                       } else if (*ptr == *pattern) {
+                               state = STATE_CHECK;
+                               ptr--;
+                               idx = 0;
+                       } else if (*ptr == '-') {
+                               state = STATE_CHECK;
+                               *ptr = *pattern;
+                               ptr--;
+                               idx = 0;
+                       } else {
+                               ret[out_idx] = *ptr;
+                               out_idx++;
+                               if (out_idx == out_sz) {
+                                       tmp = _extend_heap(ret, &out_sz, strlen(replace) + 1);
+                                       if (!tmp) {
+                                               free(ret);
+                                               return NULL;
+                                       }
+                                       ret = tmp;
+                               }
+                       }
+                       break;
+               case STATE_CHECK:
+                       if (!pattern[idx]) {
+                               /*!
+                                * If there is no space for copying the replacement,
+                                * Extend size of the return buffer.
+                                */
+                               if (out_sz - out_idx < strlen(replace) + 1) {
+                                       tmp = _extend_heap(ret, &out_sz, strlen(replace) + 1);
+                                       if (!tmp) {
+                                               free(ret);
+                                               return NULL;
+                                       }
+                                       ret = tmp;
+                               }
+
+                               strcpy(ret + out_idx, replace);
+                               out_idx += strlen(replace);
+
+                               state = STATE_FIND;
+                               ptr--;
+                       } else if (*ptr != pattern[idx]) {
+                               ptr -= idx;
+
+                               /* Copy the first matched character */
+                               ret[out_idx] = *ptr;
+                               out_idx++;
+                               if (out_idx == out_sz) {
+                                       tmp = _extend_heap(ret, &out_sz, strlen(replace) + 1);
+                                       if (!tmp) {
+                                               free(ret);
+                                               return NULL;
+                                       }
+
+                                       ret = tmp;
+                               }
+
+                               state = STATE_FIND;
+                       } else {
+                               idx++;
+                       }
+                       break;
+               default:
+                       break;
+               }
+       }
+
+       ret[out_idx] = '\0';
+       return ret;
+}
+
+static UDateTimePatternGenerator *__util_time_generator_get(void *data)
+{
+       UErrorCode status = U_ZERO_ERROR;
+       UDateTimePatternGenerator *generator = NULL;
+
+       struct appdata *ad = data;
+       retif_nomsg(ad == NULL, NULL);
+       retif_nomsg(s_info.timeregion_format == NULL, NULL);
+
+       generator = udatpg_open(s_info.timeregion_format, &status);
+       if (U_FAILURE(status)) {
+               ERR("udatpg_open() failed");
+               generator = NULL;
+               return NULL;
+       }
+       return generator;
+}
+
+static UDateTimePatternGenerator *__util_date_generator_get(void *data)
+{
+       UErrorCode status = U_ZERO_ERROR;
+       UDateTimePatternGenerator *generator = NULL;
+
+       struct appdata *ad = data;
+       retif_nomsg(ad == NULL, NULL);
+       retif_nomsg(s_info.dateregion_format == NULL, NULL);
+
+       generator = udatpg_open(s_info.dateregion_format, &status);
+       if (U_FAILURE(status)) {
+               ERR("udatpg_open() failed");
+               generator = NULL;
+               return NULL;
+       }
+       return generator;
+}
+
+static UDateFormat *__util_time_date_formatter_get(void *data, const char *timezone_id, const char *skeleton)
+{
+       UErrorCode status = U_ZERO_ERROR;
+
+       UChar u_skeleton[BUF_FORMATTER] = {0,};
+       int skeleton_len = 0;
+
+       UChar u_best_pattern[BUF_FORMATTER] = {0,};
+       int32_t u_best_pattern_capacity;
+       UDateFormat *formatter = NULL;
+
+       struct appdata *ad = data;
+       retif_nomsg(ad == NULL, NULL);
+       retif_nomsg(s_info.date_generator == NULL, NULL);
+
+       u_uastrncpy(u_skeleton, skeleton, strlen(skeleton));
+       skeleton_len = u_strlen(u_skeleton);
+
+       u_best_pattern_capacity =
+               (int32_t) (sizeof(u_best_pattern) / sizeof((u_best_pattern)[0]));
+
+       udatpg_getBestPattern(s_info.date_generator, u_skeleton, skeleton_len,
+                       u_best_pattern, u_best_pattern_capacity, &status);
+       if (U_FAILURE(status)) {
+               ERR("udatpg_getBestPattern() failed");
+               return NULL;
+       }
+
+       UChar u_timezone_id[BUF_FORMATTER] = {0,};
+       if (timezone_id == NULL) {
+               u_uastrncpy(u_timezone_id, s_info.timezone_id, sizeof(u_timezone_id));
+               formatter = udat_open(UDAT_IGNORE, UDAT_IGNORE, s_info.dateregion_format, u_timezone_id, -1,
+                               u_best_pattern, -1, &status);
+       } else {
+               u_uastrncpy(u_timezone_id, timezone_id, sizeof(u_timezone_id));
+               formatter = udat_open(UDAT_IGNORE, UDAT_IGNORE, s_info.dateregion_format, u_timezone_id, -1,
+                               u_best_pattern, -1, &status);
+       }
+       if (U_FAILURE(status)) {
+               ERR("udat_open() failed");
+               return NULL;
+       }
+
+       char a_best_pattern[BUF_FORMATTER] = {0,};
+       u_austrcpy(a_best_pattern, u_best_pattern);
+
+       return formatter;
+}
+
+static UDateFormat *__util_time_ampm_formatter_get(void *data, const char *timezone_id)
+{
+       UErrorCode status = U_ZERO_ERROR;
+
+       UChar u_best_pattern[BUF_FORMATTER] = {0,};
+       UDateFormat *formatter = NULL;
+
+       struct appdata *ad = data;
+       retif_nomsg(ad == NULL, NULL);
+
+       u_uastrcpy(u_best_pattern, "a");
+
+       UChar u_timezone_id[BUF_FORMATTER] = {0,};
+       if (timezone_id == NULL) {
+               u_uastrncpy(u_timezone_id, s_info.timezone_id, sizeof(u_timezone_id));
+               formatter = udat_open(UDAT_IGNORE, UDAT_IGNORE, s_info.timeregion_format, u_timezone_id, -1,
+                               u_best_pattern, -1, &status);
+       } else {
+               u_uastrncpy(u_timezone_id, timezone_id, sizeof(u_timezone_id));
+               formatter = udat_open(UDAT_IGNORE, UDAT_IGNORE, s_info.timeregion_format, u_timezone_id, -1,
+                               u_best_pattern, -1, &status);
+       }
+       if (U_FAILURE(status)) {
+               ERR("udat_open() failed");
+               return NULL;
+       }
+
+       char a_best_pattern[BUF_FORMATTER] = {0,};
+       u_austrcpy(a_best_pattern, u_best_pattern);
+
+       return formatter;
+}
+
+static UDateFormat *__util_time_time_formatter_get(void *data, int time_format, const char *timezone_id)
+{
+       char buf[BUF_FORMATTER] = {0,};
+       UErrorCode status = U_ZERO_ERROR;
+       UChar u_pattern[BUF_FORMATTER] = {0,};
+       UChar u_best_pattern[BUF_FORMATTER] = {0,};
+       int32_t u_best_pattern_capacity;
+       char a_best_pattern[BUF_FORMATTER] = {0,};
+
+       UDateFormat *formatter = NULL;
+
+       struct appdata *ad = data;
+       retif_nomsg(ad == NULL, NULL);
+       retif_nomsg(s_info.generator == NULL, NULL);
+
+       if (time_format == QP_TIME_FORMAT_24) {
+               snprintf(buf, sizeof(buf)-1, "%s", "HH:mm");
+       } else {
+               /* set time format 12 */
+               snprintf(buf, sizeof(buf)-1, "%s", "h:mm");
+       }
+
+       if (u_uastrncpy(u_pattern, buf, sizeof(u_pattern)) == NULL) {
+               ERR("u_uastrncpy() is failed.");
+               return NULL;
+       }
+
+       u_best_pattern_capacity =
+               (int32_t) (sizeof(u_best_pattern) / sizeof((u_best_pattern)[0]));
+
+       udatpg_getBestPattern(s_info.generator, u_pattern, u_strlen(u_pattern),
+                       u_best_pattern, u_best_pattern_capacity, &status);
+       if (U_FAILURE(status)) {
+               ERR("udatpg_getBestPattern() failed");
+               return NULL;
+       }
+
+       u_austrcpy(a_best_pattern, u_best_pattern);
+
+       if (a_best_pattern[0] == 'a') {
+               s_info.is_pre_meridiem = EINA_TRUE;
+       } else {
+               s_info.is_pre_meridiem = EINA_FALSE;
+       }
+
+       u_uastrcpy(u_best_pattern, buf);
+
+       UChar u_timezone_id[BUF_FORMATTER] = {0,};
+       if (timezone_id == NULL) {
+               u_uastrncpy(u_timezone_id, s_info.timezone_id, sizeof(u_timezone_id));
+               formatter = udat_open(UDAT_IGNORE, UDAT_IGNORE, s_info.timeregion_format, u_timezone_id, -1,
+                               u_best_pattern, -1, &status);
+       } else {
+               u_uastrncpy(u_timezone_id, timezone_id, sizeof(u_timezone_id));
+               formatter = udat_open(UDAT_IGNORE, UDAT_IGNORE, s_info.timeregion_format, u_timezone_id, -1,
+                               u_best_pattern, -1, &status);
+       }
+       if (U_FAILURE(status)) {
+               ERR("udat_open() failed");
+               return NULL;
+       }
+
+       return formatter;
+}
+
+static void _util_time_formatters_create(void *data)
+{
+       struct appdata *ad = data;
+       retif_nomsg(ad == NULL, );
+
+       if (s_info.generator == NULL) {
+               s_info.generator = __util_time_generator_get(ad);
+       }
+
+       if (s_info.date_generator == NULL) {
+               s_info.date_generator = __util_date_generator_get(ad);
+       }
+
+       if (s_info.formatter_date == NULL) {
+               s_info.formatter_date = __util_time_date_formatter_get(ad, NULL, "MMMMEd");
+       }
+
+       if (s_info.timeformat == QP_TIME_FORMAT_12) {
+               if (s_info.formatter_ampm == NULL) {
+                       s_info.formatter_ampm = __util_time_ampm_formatter_get(ad, NULL);
+               }
+       }
+
+       if (s_info.formatter_time == NULL) {
+               s_info.formatter_time = __util_time_time_formatter_get(ad, s_info.timeformat, NULL);
+       }
+}
+
+static void _util_time_formatters_destroy(void *data)
+{
+       struct appdata *ad = data;
+       retif_nomsg(ad == NULL, );
+
+       if (s_info.date_generator) {
+               udat_close(s_info.date_generator);
+               s_info.date_generator = NULL;
+       }
+
+       if (s_info.generator) {
+               udat_close(s_info.generator);
+               s_info.generator = NULL;
+       }
+
+       if (s_info.formatter_date) {
+               udat_close(s_info.formatter_date);
+               s_info.formatter_date = NULL;
+       }
+       if (s_info.formatter_time) {
+               udat_close(s_info.formatter_time);
+               s_info.formatter_time = NULL;
+       }
+       if (s_info.formatter_ampm) {
+               udat_close(s_info.formatter_ampm);
+               s_info.formatter_ampm = NULL;
+       }
+}
+
+static char *_util_time_regionformat_get(void)
+{
+       return _get_locale();
+}
+
+static char *_util_date_regionformat_get(void)
+{
+       return _get_locale();
+}
+
+static char* _get_timezone_from_vconf(void)
+{
+       char *szTimezone = NULL;
+       szTimezone = vconf_get_str(VCONFKEY_SETAPPL_TIMEZONE_ID);
+       if (szTimezone == NULL || strlen(szTimezone) == 0)
+       {
+               ERR("QUICKPANEL TIMEZONE - Cannot get time zone.");
+               return strdup("N/A");
+       }
+
+       return szTimezone;
+}
+
+static char *_util_time_timezone_id_get(void)
+{
+       char buf[1024] = {0,};
+       ssize_t len = readlink("/opt/etc/localtime", buf, sizeof(buf)-1);
+
+       INFO("QUICKPANEL TIMEZONE -  %s",  buf);
+
+       if (len != -1) {
+               buf[len] = '\0';
+       } else {
+               ERR("QUICKPANEL TIMEZONE - failed to get a timezone information");
+               return _get_timezone_from_vconf();
+       }
+
+       return strdup(buf + 20);
+}
+
+static int _util_time_formatted_time_get(UDateFormat *formatter, time_t tt, char *buf, int buf_len)
+{
+       i18n_udate u_time = (i18n_udate)(tt) * 1000;
+       i18n_uchar u_formatted_str[BUF_FORMATTER] = {0, };
+       int32_t u_formatted_str_capacity;
+       int32_t formatted_str_len = -1;
+       int status = I18N_ERROR_INVALID_PARAMETER;
+
+       u_formatted_str_capacity =
+               (int32_t)(sizeof(u_formatted_str) / sizeof((u_formatted_str)[0]));
+
+       status = i18n_udate_format_date(formatter, u_time, u_formatted_str, u_formatted_str_capacity, NULL, &formatted_str_len);
+       if (status != I18N_ERROR_NONE) {
+               ERR("i18n_udate_format_date() failed");
+               return -1;
+       }
+
+       if (formatted_str_len <= 0) {
+               ERR("formatted_str_len is less than 0");
+       }
+
+       buf = i18n_ustring_copy_au_n(buf, u_formatted_str, (int32_t)buf_len);
+       DBG("date:(%d)[%s][%d]", formatted_str_len, buf, tt);
+
+       return (int)u_strlen(u_formatted_str);
+}
+
+static void _formatter_create(void *data)
+{
+       int ret = 0;
+       struct appdata *ad = data;
+       retif_nomsg(ad == NULL, );
+       bool status = false;
+
+       ret = system_settings_get_value_bool(SYSTEM_SETTINGS_KEY_LOCALE_TIMEFORMAT_24HOUR, &status);
+       msgif(ret != SYSTEM_SETTINGS_ERROR_NONE, "failed to ignore key(SYSTEM_SETTINGS_KEY_LOCALE_TIMEFORMAT_24HOUR) : %d", ret);
+
+       if (status == true){
+               s_info.timeformat = QP_TIME_FORMAT_24;
+       }else{
+               s_info.timeformat = QP_TIME_FORMAT_12;
+       }
+
+       if (s_info.timeregion_format == NULL) {
+               s_info.timeregion_format = _util_time_regionformat_get();
+       }
+
+       if (s_info.dateregion_format == NULL) {
+               s_info.dateregion_format = _util_date_regionformat_get();
+       }
+
+       if (s_info.timezone_id == NULL) {
+               s_info.timezone_id = _util_time_timezone_id_get();
+       }
+
+       ICU_set_timezone(s_info.timezone_id);
+
+       _util_time_formatters_create(ad);
+
+       s_info.is_initialized = 1;
+       DBG("%d %s %s", s_info.timeformat, s_info.timeregion_format, s_info.timezone_id);
+}
+
+static void _formatter_destory(void *data)
+{
+       struct appdata *ad = data;
+       retif_nomsg(ad == NULL, );
+
+       if (s_info.timeregion_format) {
+               free(s_info.timeregion_format);
+               s_info.timeregion_format = NULL;
+       }
+       if (s_info.dateregion_format) {
+               free(s_info.dateregion_format);
+               s_info.dateregion_format = NULL;
+       }
+       if (s_info.timezone_id) {
+               free(s_info.timezone_id);
+               s_info.timezone_id = NULL;
+       }
+
+       _util_time_formatters_destroy(ad);
+
+       s_info.is_initialized = 0;
+}
+
+static void _util_time_setting_changed_cb(system_settings_key_e key, void *data)
+{
+       struct appdata *ad = data;
+
+       _formatter_destory(ad);
+       _formatter_create(ad);
+
+       _util_time_heartbeat_do();
+
+       //upate noti time information.
+       quickpanel_noti_update_by_system_time_changed_setting_cb(key, ad);
+}
+
+static void _util_time_vconf_changed_cb(keynode_t *key, void *data)
+{
+       struct appdata *ad = data;
+
+       _formatter_destory(ad);
+       _formatter_create(ad);
+
+       _util_time_heartbeat_do();
+
+       //upate noti time information.
+       quickpanel_noti_update_by_system_time_changed_vconf_cb(key, ad);
+}
+
+static void _time_event_deattach(void *data)
+{
+       int ret = 0;
+       struct appdata *ad = data;
+       retif_nomsg(ad == NULL, );
+
+       /* unregister vconf cbs */
+       ret = vconf_ignore_key_changed(VCONFKEY_SETAPPL_TIMEZONE_INT, _util_time_vconf_changed_cb);
+       msgif(ret != 0, "failed to set key(%s) : %d", VCONFKEY_SETAPPL_TIMEZONE_INT, ret);
+       ret = vconf_ignore_key_changed(VCONFKEY_SETAPPL_TIMEZONE_ID, _util_time_vconf_changed_cb);
+       msgif(ret != 0, "failed to set key(%s) : %d", VCONFKEY_SETAPPL_TIMEZONE_ID, ret);
+       ret = vconf_ignore_key_changed(VCONFKEY_TELEPHONY_SVC_ROAM, _util_time_vconf_changed_cb);
+       msgif(ret != 0, "failed to set key(%s) : %d", VCONFKEY_TELEPHONY_SVC_ROAM, ret);
+
+       ret = system_settings_unset_changed_cb(SYSTEM_SETTINGS_KEY_TIME_CHANGED);
+       msgif(ret != SYSTEM_SETTINGS_ERROR_NONE, "failed to set key(%d) : %d", SYSTEM_SETTINGS_KEY_TIME_CHANGED, ret);
+       ret = system_settings_unset_changed_cb(SYSTEM_SETTINGS_KEY_LOCALE_TIMEFORMAT_24HOUR);
+       msgif(ret != SYSTEM_SETTINGS_ERROR_NONE, "failed to set key(%d) : %d", SYSTEM_SETTINGS_KEY_LOCALE_TIMEFORMAT_24HOUR, ret);
+       ret = system_settings_unset_changed_cb(SYSTEM_SETTINGS_KEY_LOCALE_COUNTRY);
+       msgif(ret != SYSTEM_SETTINGS_ERROR_NONE, "failed to set key(%d) : %d", SYSTEM_SETTINGS_KEY_LOCALE_COUNTRY, ret);
+}
+
+static void _time_event_attach(void *data)
+{
+       int ret = 0;
+       struct appdata *ad = data;
+       retif_nomsg(ad == NULL, );
+
+       /* register vconf cbs */
+       ret = vconf_notify_key_changed(VCONFKEY_SETAPPL_TIMEZONE_INT, _util_time_vconf_changed_cb, data);
+       msgif(ret != 0, "failed to set key(%s) : %d", VCONFKEY_SETAPPL_TIMEZONE_INT, ret);
+       ret = vconf_notify_key_changed(VCONFKEY_SETAPPL_TIMEZONE_ID, _util_time_vconf_changed_cb, data);
+       msgif(ret != 0, "failed to set key(%s) : %d", VCONFKEY_SETAPPL_TIMEZONE_ID, ret);
+       ret = vconf_notify_key_changed(VCONFKEY_TELEPHONY_SVC_ROAM, _util_time_vconf_changed_cb, data);
+       msgif(ret != 0, "failed to set key(%s) : %d", VCONFKEY_TELEPHONY_SVC_ROAM, ret);
+
+       ret = system_settings_set_changed_cb(SYSTEM_SETTINGS_KEY_TIME_CHANGED, _util_time_setting_changed_cb, data);
+       msgif(ret != SYSTEM_SETTINGS_ERROR_NONE, "failed to set key(%d) : %d", SYSTEM_SETTINGS_KEY_TIME_CHANGED, ret);
+       ret = system_settings_set_changed_cb(SYSTEM_SETTINGS_KEY_LOCALE_TIMEFORMAT_24HOUR, _util_time_setting_changed_cb, data);
+       msgif(ret != SYSTEM_SETTINGS_ERROR_NONE, "failed to set key(%d) : %d", SYSTEM_SETTINGS_KEY_LOCALE_TIMEFORMAT_24HOUR, ret);
+       ret = system_settings_set_changed_cb(SYSTEM_SETTINGS_KEY_LOCALE_COUNTRY, _util_time_setting_changed_cb, data);
+       msgif(ret != SYSTEM_SETTINGS_ERROR_NONE, "failed to set key(%d) : %d", SYSTEM_SETTINGS_KEY_LOCALE_COUNTRY, ret);
+
+}
+
+static void _util_time_get(int is_current_time, time_t tt_a, char **str_date, char **str_time, char **str_meridiem)
+{
+       time_t tt;
+       struct tm st;
+       char buf_date[512] = {0,};
+       char buf_time[512] = {0,};
+       char buf_ampm[512] = {0,};
+
+       char *convert_formatted_str = NULL;
+
+       if (is_current_time == 1) {
+               tt = time(NULL);
+       } else {
+               tt = tt_a;
+       }
+       localtime_r(&tt, &st);
+
+       /* date */
+       _util_time_formatted_time_get(s_info.formatter_date, tt, buf_date, sizeof(buf_date));
+
+       /* time */
+       if (s_info.timeformat == QP_TIME_FORMAT_24) {
+               _util_time_formatted_time_get(s_info.formatter_time, tt, buf_time, sizeof(buf_time)-1);
+       } else {
+               _util_time_formatted_time_get(s_info.formatter_time, tt, buf_time, sizeof(buf_time)-1);
+               int ampm_len = _util_time_formatted_time_get(s_info.formatter_ampm, tt, buf_ampm, sizeof(buf_ampm)-1);
+               if (ampm_len > 4) {
+                       if (st.tm_hour >= 0 && st.tm_hour < 12) {
+                               snprintf(buf_ampm, sizeof(buf_ampm)-1, "AM");
+                       } else {
+                               snprintf(buf_ampm, sizeof(buf_ampm)-1, "PM");
+                       }
+               }
+       }
+
+       if (strstr(s_info.timeregion_format, "ar_")) {
+               convert_formatted_str = strdup(buf_time);
+       } else {
+               convert_formatted_str = _string_replacer(buf_time, colon, ratio);
+       }
+
+       if (str_date != NULL) {
+               *str_date = strdup(buf_date);
+       }
+
+       if (str_meridiem != NULL) {
+               *str_meridiem = strdup(buf_ampm);
+       }
+
+       if (convert_formatted_str)
+       {
+               if (str_time != NULL) {
+                       *str_time = strdup(convert_formatted_str);
+               }
+               free(convert_formatted_str);
+       }
+}
+
+static void _timer_add(void)
+{
+       time_t tt;
+       struct tm st;
+
+       tt = time(NULL);
+       localtime_r(&tt, &st);
+
+       s_info.timer = ecore_timer_add(60 - st.tm_sec, _timer_cb, NULL);
+}
+
+static void _timer_del(void)
+{
+       if (s_info.timer != NULL) {
+               ecore_timer_del(s_info.timer);
+               s_info.timer = NULL;
+       }
+}
+
+static Eina_Bool _timer_cb(void *data)
+{
+       _util_time_heartbeat_do();
+
+       if (s_info.is_timer_enabled ==1) {
+               _timer_del();
+               _timer_add();
+       }
+       return ECORE_CALLBACK_CANCEL;
+}
+
+static int _init(void *data)
+{
+       _formatter_create(data);
+       _time_event_attach(data);
+
+       return QP_OK;
+}
+
+static int _fini(void *data)
+{
+       _time_event_deattach(data);
+       _formatter_destory(data);
+
+       return QP_OK;
+}
+
+static void _lang_changed(void *data)
+{
+       _util_time_vconf_changed_cb(NULL, data);
+}
+
+static void _util_time_heartbeat_do(void)
+{
+       int type_meridiem = UTIL_TIME_MERIDIEM_TYPE_NONE;
+       char *str_date = NULL;
+       char *str_time = NULL;
+       char *str_meridiem = NULL;
+
+       if (s_info.is_initialized == 0) {
+               ERR("time information ins't initialized");
+               return;
+       }
+
+       _util_time_get(1, 0, &str_date, &str_time, &str_meridiem);
+
+       if (str_meridiem != NULL) {
+               if (s_info.is_pre_meridiem == EINA_TRUE) {
+                       type_meridiem = UTIL_TIME_MERIDIEM_TYPE_PRE;
+               } else {
+                       type_meridiem = UTIL_TIME_MERIDIEM_TYPE_POST;
+               }
+       }
+       quickpanel_datetime_view_update(str_date, str_time, str_meridiem, type_meridiem);
+
+       if (str_date) {
+               free(str_date);
+       }
+       if (str_time) {
+               free(str_time);
+       }
+       if (str_meridiem) {
+               free(str_meridiem);
+       }
+}
+
+HAPI void quickpanel_util_time_timer_enable_set(int is_enable)
+{
+       _timer_del();
+
+       if (is_enable == 1) {
+               _timer_add();
+       }
+
+       _util_time_heartbeat_do();
+
+       s_info.is_timer_enabled = is_enable;
+}
diff --git a/daemon/datetime/util-time.h b/daemon/datetime/util-time.h
new file mode 100755 (executable)
index 0000000..ec97d69
--- /dev/null
@@ -0,0 +1,34 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __UTIL_TIME_H__
+#define __UTIL_TIME_H__
+
+#define UTIL_TIME_MERIDIEM_TYPE_NONE 0
+#define UTIL_TIME_MERIDIEM_TYPE_PRE 1
+#define UTIL_TIME_MERIDIEM_TYPE_POST 2
+
+enum qp_time_format {
+       QP_TIME_FORMAT_UNKNOWN,
+       QP_TIME_FORMAT_12,
+       QP_TIME_FORMAT_24,
+};
+
+extern void quickpanel_util_time_timer_enable_set(int is_enable);
+
+#endif                         /* __UTIL_TIME_H__ */
diff --git a/daemon/device/brightness.c b/daemon/device/brightness.c
new file mode 100755 (executable)
index 0000000..9084666
--- /dev/null
@@ -0,0 +1,754 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#include <Elementary.h>
+#include <glib.h>
+#include <string.h>
+
+#include <notification.h>
+#include <vconf.h>
+#include <device/display.h>
+#include <app_control.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "common.h"
+#include "quickpanel-ui.h"
+#include "list_util.h"
+#include "quickpanel_def.h"
+#include "settings_view_featured.h"
+#include "preference.h"
+#include "setting_utils.h"
+#include "page_setting_all.h"
+
+#ifdef QP_SCREENREADER_ENABLE
+#include "accessibility.h"
+#endif
+
+#ifdef QP_EMERGENCY_MODE_ENABLE
+#include "emergency_mode.h"
+#endif
+
+
+#define BRIGHTNESS_MIN 1
+#define BRIGHTNESS_MAX 100
+#define BRIGHTNESS_SIG_ACTIVITY "BRIGHTNESS"
+#define PREF_BRIGHTNESS_ON "ON"
+#define PREF_BRIGHTNESS_OFF "OFF"
+
+typedef struct _brightness_ctrl_obj {
+       int min_level;
+       int max_level;
+       int is_event_registered;
+       int last_requested_level;
+       Evas_Object *viewer;
+       void *data;
+       int level_before;
+       int pos_x;
+
+       Evas_Object *brighntess_slider;
+} brightness_ctrl_obj;
+
+
+int slider_drag_start = -1;
+Eina_Bool is_sliding = EINA_FALSE;
+
+
+static int _init(void *data);
+static int _fini(void *data);
+static void _lang_changed(void *data);
+static void _qp_opened(void *data);
+static void _qp_closed(void *data);
+static void _brightness_view_update(void);
+static void _brightness_register_event_cb(brightness_ctrl_obj *ctrl_obj);
+static void _brightness_deregister_event_cb(brightness_ctrl_obj *ctrl_obj);
+
+static void _brightness_set_image(int level);
+static void _refresh(void *data);
+
+QP_Module brightness_ctrl = {
+       .name = "brightness_ctrl",
+       .init = _init,
+       .fini = _fini,
+       .suspend = NULL,
+       .resume = NULL,
+       .hib_enter = NULL,
+       .hib_leave = NULL,
+       .lang_changed = _lang_changed,
+       .refresh = _refresh,
+       .get_height = NULL,
+       .qp_opened = _qp_opened,
+       .qp_closed = _qp_closed,
+};
+
+static brightness_ctrl_obj *g_ctrl_obj;
+E_DBus_Signal_Handler *g_hdl_brightness;
+
+static Evas_Object *_controller_view_get(void)
+{
+       Evas_Object *view = NULL;
+
+       if (g_ctrl_obj != NULL) {
+               if (g_ctrl_obj->viewer != NULL) {
+                       view = elm_object_part_content_get(g_ctrl_obj->viewer, "elm.swallow.controller");
+                       if (view == NULL) {
+                               view = evas_object_data_get(g_ctrl_obj->viewer, "view.controller");
+                       }
+               }
+       }
+
+       return view;
+}
+
+static void _controller_view_set(Evas_Object *wrapper, Evas_Object *view)
+{
+       retif(wrapper == NULL, , "invalid data");
+       retif(view == NULL, , "invalid data");
+
+       elm_object_part_content_set(wrapper, "elm.swallow.controller", view);
+       evas_object_data_set(wrapper, "view.controller", view);
+}
+
+static char *_brightness_access_state_cb(void *data, Evas_Object *obj)
+{
+       char buf[512] = {0,};
+       brightness_ctrl_obj *ctrl_obj = data;
+       retif(NULL == ctrl_obj, NULL, "invalid data");
+
+       snprintf(buf, sizeof(buf) - 1, _NOT_LOCALIZED("Position %1$d of %2$d"),
+                       ctrl_obj->last_requested_level, ctrl_obj->max_level);
+
+       return strdup(buf);
+}
+
+#ifdef QP_SCREENREADER_ENABLE
+static void _set_slider_accessiblity_state(Evas_Object *obj)
+{
+       Evas_Object *ao = NULL;
+       brightness_ctrl_obj *ctrl_obj = g_ctrl_obj;
+       retif(ctrl_obj == NULL, , "Invalid parameter!");
+       retif(ctrl_obj->viewer == NULL, , "Invalid parameter!");
+
+       ao = quickpanel_accessibility_screen_reader_object_get(obj,
+                       SCREEN_READER_OBJ_TYPE_ELM_OBJECT, NULL, NULL);
+       if (ao != NULL) {
+               elm_access_info_set(ao, ELM_ACCESS_INFO, _NOT_LOCALIZED("Brightness"));
+               elm_access_info_set(ao, ELM_ACCESS_TYPE, _NOT_LOCALIZED("Slider"));
+               elm_access_info_cb_set(ao, ELM_ACCESS_STATE, _brightness_access_state_cb, ctrl_obj);
+       }
+}
+#endif
+
+static Evas_Object *_check_duplicated_loading(Evas_Object *obj, const char *part)
+{
+       Evas_Object *old_content = NULL;
+       retif(obj == NULL, NULL, "Invalid parameter!");
+       retif(part == NULL, NULL, "Invalid parameter!");
+
+       old_content = elm_object_part_content_get(obj, part);
+       if (old_content != NULL) {
+               return old_content;
+       }
+
+       return NULL;
+}
+
+static void _brightness_vconf_cb(keynode_t *key, void* data)
+{
+       brightness_ctrl_obj *ctrl_obj = NULL;
+
+       retif(data == NULL, , "Data parameter is NULL");
+       ctrl_obj = data;
+
+       if (ctrl_obj->viewer != NULL) {
+               _brightness_view_update();
+       }
+}
+
+static int _brightness_set_level(int level)
+{
+       int ret = DEVICE_ERROR_NONE;
+
+       ret = device_display_set_brightness(0, level);
+       if (ret != DEVICE_ERROR_NONE) {
+               ERR("failed to set brightness");
+       }
+
+       return level;
+}
+
+static int _brightness_get_level(void) {
+
+       int level = 0;
+
+       if (vconf_get_int(VCONFKEY_SETAPPL_LCD_BRIGHTNESS, &level) == 0) {
+               return level;
+       } else {
+               return SETTING_BRIGHTNESS_LEVEL5;
+       }
+}
+
+Evas_Object *_slider_get(Evas_Object *view, brightness_ctrl_obj *ctrl_obj) {
+
+       retif(view == NULL, NULL, "Data parameter is NULL");
+
+       Evas_Object *obj = elm_object_part_content_get(view, "elm.swallow.slider");
+
+       if (obj) {
+               return obj;
+       } else {
+               return ctrl_obj->brighntess_slider;
+       }
+}
+
+static void _slider_changed_job_cb(void *data)
+{
+       int value = 0;
+       double val = 0.0;
+       Evas_Object *obj = NULL;
+       brightness_ctrl_obj *ctrl_obj = data;
+       double time_current = 0.0;
+       static double time_before = 0.0;
+
+       retif(ctrl_obj == NULL, , "Data parameter is NULL");
+       obj = _slider_get(_controller_view_get(), ctrl_obj);
+       retif(obj == NULL, , "obj is NULL");
+
+       val = elm_slider_value_get(obj);
+       value = (int)(val + 0.5);
+
+       time_current = ecore_loop_time_get();
+
+       if (value != ctrl_obj->last_requested_level) {
+               if (value >= ctrl_obj->min_level && value <= ctrl_obj->max_level) {
+                       ctrl_obj->last_requested_level = value;
+                       if (time_current - time_before >= 0.045) {
+                               _brightness_set_level(value);
+                               time_before = time_current;
+                       }
+                       _brightness_set_image(value);
+               }
+       }
+
+
+}
+
+static void _brightness_ctrl_slider_changed_cb(void *data, Evas_Object *obj, void *event_info)
+{
+       int pos_new = (long)event_info;
+       LOGI("SLIDER_NEW_POS: %d", pos_new);
+
+       _slider_changed_job_cb(data);
+}
+
+static void _brightness_ctrl_overheat_check(Evas_Object *slider, void *data, int is_display_popup)
+{
+       int value = 0;
+       int max_brightness = BRIGHTNESS_MAX;
+       brightness_ctrl_obj *ctrl_obj = data;
+       retif(slider == NULL, , "slider is NULL");
+       retif(ctrl_obj == NULL, , "Data parameter is NULL");
+
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "invalid data.");
+
+       value = ctrl_obj->last_requested_level;
+
+       device_display_get_max_brightness(0, &max_brightness);
+       if (value > max_brightness && max_brightness != BRIGHTNESS_MAX) {
+               DBG("max brightness is limited");
+               if (is_display_popup == 1) {
+                       if (ad->popup == NULL) {
+                               quickpanel_setting_create_timeout_popup(ad->win,
+                                               _("IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"));
+                       }
+               }
+               elm_slider_value_set(slider, (double)max_brightness);
+               ctrl_obj->last_requested_level = max_brightness;
+               _brightness_set_level(max_brightness);
+               _brightness_set_image(max_brightness);
+               return;
+       }
+}
+
+static void _slider_delayed_changed_job_cb(void *data)
+{
+       int value = 0;
+       brightness_ctrl_obj *ctrl_obj = data;
+       Evas_Object *obj = NULL;
+       retif(ctrl_obj == NULL, , "Data parameter is NULL");
+       obj = _slider_get(_controller_view_get(), ctrl_obj);
+       retif(obj == NULL, , "obj is NULL");
+
+       value = ctrl_obj->last_requested_level;
+
+       if (value >= ctrl_obj->min_level && value <= ctrl_obj->max_level) {
+               _brightness_set_level(value);
+               _brightness_set_image(value);
+       }
+}
+
+static void _brightness_ctrl_slider_delayed_changed_cb(void *data, Evas_Object *obj, void *event_info)
+{
+       LOGI("");
+       ecore_job_add(_slider_delayed_changed_job_cb, data);
+}
+
+static void _brightness_slider_drag_start_cb(void *data, Evas_Object *obj, void *event_info)
+{
+       is_sliding = EINA_TRUE;
+       slider_drag_start = _brightness_get_level();
+}
+
+static void _brightness_slider_drag_stop_cb(void *data, Evas_Object *obj, void *event_info)
+{
+       is_sliding = EINA_FALSE;
+}
+
+/*!
+ * workaround to avoid focus jump to other pages
+ */
+static void _frame_focused(void *data, Evas_Object * obj, void *event_info)
+{
+       quickpanel_page_setting_all_focus_allow_set(EINA_FALSE);
+}
+
+static void _frame_unfocused(void *data, Evas_Object * obj, void *event_info)
+{
+       quickpanel_page_setting_all_focus_allow_set(EINA_TRUE);
+}
+
+static void _brightness_view_pos_set()
+{
+       struct appdata *ad = quickpanel_get_app_data();
+
+       Evas_Coord base_y;
+       //      Evas_Coord settings_y;
+       Evas_Coord brightness_y;
+
+       Eina_Bool ret = EINA_FALSE;
+
+       edje_object_part_geometry_get(_EDJ(ad->view_root), "qp.root.swallow", NULL, &base_y, NULL, NULL);
+       //      edje_object_part_geometry_get(ad->ly, QP_SETTING_BASE_PART, NULL, &settings_y, NULL, NULL);
+
+       Evas_Object *settings_swallow = quickpanel_setting_layout_get(ad->ly, QP_SETTING_BASE_PART);
+       ret = edje_object_part_geometry_get(_EDJ(settings_swallow), QP_SETTING_BRIGHTNESS_PART_WVGA, NULL, &brightness_y, NULL, NULL);
+       msgif(!ret, "ret is EINA_FALSE");
+
+       evas_object_move(g_ctrl_obj->viewer, 0, base_y + /*settings_y */+ brightness_y);
+}
+
+static Evas_Object *_brightness_view_create(Evas_Object *list)
+{
+       Eina_Bool ret = EINA_TRUE;
+       Evas_Object *view_wrapper = NULL;
+       Evas_Object *view = NULL;
+
+       retif(list == NULL, NULL, "list parameter is NULL");
+
+       view_wrapper = elm_layout_add(list);
+       if (view_wrapper != NULL) {
+               ret = elm_layout_file_set(view_wrapper, DEFAULT_EDJ,
+                               "quickpanel/brightness_controller/wrapper");
+               if (ret == EINA_FALSE) {
+                       ERR("failed to load brightness wapper layout");
+               }
+               evas_object_size_hint_weight_set(view_wrapper, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+               evas_object_size_hint_align_set(view_wrapper, EVAS_HINT_FILL, EVAS_HINT_FILL);
+
+               view = elm_layout_add(view_wrapper);
+               if (view != NULL) {
+                       ret = elm_layout_file_set(view, DEFAULT_EDJ,
+                                       "quickpanel/brightness_controller/default");
+
+                       if (ret == EINA_FALSE) {
+                               ERR("failed to load brightness layout");
+                       }
+                       evas_object_size_hint_weight_set(view, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+                       evas_object_size_hint_align_set(view, EVAS_HINT_FILL, EVAS_HINT_FILL);
+
+                       Evas_Object *focus = quickpanel_accessibility_ui_get_focus_object(view);
+                       elm_access_info_cb_set(focus, ELM_ACCESS_TYPE, quickpanel_accessibility_info_cb_s, _NOT_LOCALIZED("Brightness"));
+                       elm_object_part_content_set(view, "focus", focus);
+
+                       evas_object_smart_callback_add(focus, "focused", _frame_focused, NULL);
+                       evas_object_smart_callback_add(focus, "unfocused", _frame_unfocused, NULL);
+                       evas_object_show(view);
+                       _brightness_view_pos_set();
+
+                       g_ctrl_obj->brighntess_slider = view;
+                       _controller_view_set(view_wrapper, view);
+                       evas_object_show(view_wrapper);
+               }
+       }
+
+       return view_wrapper;
+}
+
+static void _brightness_set_image(int level)
+{
+       int mapped_level;
+
+       if (!g_ctrl_obj) {
+               ERR("Ctrl Obj is not defined");
+               return;
+       }
+
+       if (level <= 1) {
+               mapped_level = 0;
+       } else if (level >= 100) {
+               mapped_level = 11;
+       } else if (level > 1 && level <= 9){
+               mapped_level = 1;
+       } else {
+               mapped_level = (level / 10);
+       }
+
+       if (g_ctrl_obj->level_before != mapped_level ) {
+               char buf[128] = {0,};
+               Evas_Object *view;
+
+               view = _controller_view_get();
+               snprintf(buf, sizeof(buf) - 1, "icon.state.%d", mapped_level);
+               elm_object_signal_emit(view, buf, "prog");
+               g_ctrl_obj->level_before = mapped_level;
+       }
+}
+
+static void _brightness_set_slider(void)
+{
+       int value = 0;
+       Evas_Object *slider = NULL;
+       Evas_Object *old_obj = NULL;
+       brightness_ctrl_obj *ctrl_obj = g_ctrl_obj;
+       Evas_Object *view = _controller_view_get();
+       retif(ctrl_obj == NULL, , "Invalid parameter!");
+       retif(view == NULL, , "Invalid parameter!");
+
+       old_obj = _check_duplicated_loading(view, "elm.swallow.slider");
+
+       if (old_obj == NULL) {
+               slider = elm_slider_add(view);
+
+               if (slider != NULL) {
+                       evas_object_size_hint_weight_set(slider, EVAS_HINT_EXPAND, 0.0);
+                       evas_object_size_hint_align_set(slider, EVAS_HINT_FILL, 0.5);
+                       elm_slider_min_max_set(slider, ctrl_obj->min_level, ctrl_obj->max_level);
+                       evas_object_smart_callback_add(slider, "changed", _brightness_ctrl_slider_changed_cb, ctrl_obj);
+                       evas_object_smart_callback_add(slider, "delay,changed", _brightness_ctrl_slider_delayed_changed_cb, ctrl_obj);
+                       evas_object_smart_callback_add(slider, "slider,drag,start", _brightness_slider_drag_start_cb, ctrl_obj);
+                       evas_object_smart_callback_add(slider, "slider,drag,stop", _brightness_slider_drag_stop_cb, ctrl_obj);
+                       elm_object_part_content_set(view, "elm.swallow.slider", slider);
+               } else {
+                       ERR("failed to create slider");
+                       return;
+               }
+       } else {
+               slider = old_obj;
+       }
+
+       elm_object_style_set(slider, "quickpanel_style");
+
+       elm_slider_indicator_format_set(slider, NULL);
+       elm_slider_indicator_format_function_set(slider, NULL, NULL);
+       elm_slider_indicator_show_set(slider, EINA_FALSE);
+
+#ifdef QP_SCREENREADER_ENABLE
+       _set_slider_accessiblity_state(slider);
+#endif
+
+       value = _brightness_get_level();
+       elm_slider_value_set(slider, value);
+       _brightness_set_image(value);
+}
+
+static void _focus_pair_set()
+{
+       brightness_ctrl_obj *ctrl_obj = g_ctrl_obj;
+       Evas_Object *focus = NULL;
+       Evas_Object *slider = NULL;
+       Evas_Object *view = _controller_view_get();
+       retif(ctrl_obj == NULL, , "Invalid parameter!");
+       retif(view == NULL, , "Invalid parameter!");
+
+       focus = elm_object_part_content_get(view, "focus");
+       slider = elm_object_part_content_get(view, "elm.swallow.slider");
+
+       if (focus != NULL && slider != NULL) {
+               /* focus */
+               elm_object_focus_next_object_set(focus, slider, ELM_FOCUS_RIGHT);
+               elm_object_focus_next_object_set(focus, slider, ELM_FOCUS_DOWN);
+
+               /* slider */
+               elm_object_focus_next_object_set(slider, focus, ELM_FOCUS_LEFT);
+               elm_object_focus_next_object_set(slider, focus, ELM_FOCUS_UP);
+       }
+}
+
+static void _brightness_view_update(void)
+{
+       _brightness_set_slider();
+       _focus_pair_set();
+}
+
+static void _brightness_add(brightness_ctrl_obj *ctrl_obj, void *data)
+{
+       struct appdata *ad = data;
+       retif(!ad, , "list is NULL");
+       retif(!ad->list, , "list is NULL");
+       retif(ctrl_obj == NULL, , "ctrl_obj is null");
+       retif(ctrl_obj->viewer != NULL, , "viewer is already created");
+
+       ctrl_obj->viewer = _brightness_view_create(ad->list);
+       ctrl_obj->data = data;
+
+       _brightness_set_image(BRIGHTNESS_MIN);
+       _refresh(ad);
+}
+
+static void _brightness_remove(brightness_ctrl_obj *ctrl_obj, void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, , "list is NULL");
+       retif(ad->list == NULL, , "list is NULL");
+
+       if (g_ctrl_obj != NULL) {
+               if (g_ctrl_obj->viewer != NULL) {
+                       quickpanel_list_util_item_unpack_by_object(ad->list
+                                       , g_ctrl_obj->viewer, 0, 0);
+                       quickpanel_list_util_item_del_tag(g_ctrl_obj->viewer);
+                       evas_object_del(g_ctrl_obj->viewer);
+                       g_ctrl_obj->viewer = NULL;
+               }
+               DBG("brightness controller is removed");
+               free(g_ctrl_obj);
+               g_ctrl_obj = NULL;
+       }
+}
+
+static void _brightness_register_event_cb(brightness_ctrl_obj *ctrl_obj)
+{
+       int ret = 0;
+       retif(ctrl_obj == NULL, , "Data parameter is NULL");
+
+       if (ctrl_obj->is_event_registered == 0) {
+               ret = vconf_notify_key_changed(VCONFKEY_SETAPPL_LCD_BRIGHTNESS,
+                               _brightness_vconf_cb, ctrl_obj);
+               if (ret != 0) {
+                       ERR("failed to register a cb key:%s err:%d",
+                                       "VCONFKEY_SETAPPL_LCD_BRIGHTNESS", ret);
+               }
+               ctrl_obj->is_event_registered = 1;
+       }
+}
+
+static void _brightness_deregister_event_cb(brightness_ctrl_obj *ctrl_obj)
+{
+       int ret = 0;
+       retif(ctrl_obj == NULL, , "Data parameter is NULL");
+
+       if (ctrl_obj->is_event_registered == 1) {
+               ret = vconf_ignore_key_changed(VCONFKEY_SETAPPL_LCD_BRIGHTNESS, _brightness_vconf_cb);
+               if (ret != 0) {
+                       ERR("failed to register a cb key:%s err:%d", "VCONFKEY_SETAPPL_LCD_BRIGHTNESS", ret);
+               }
+               ctrl_obj->is_event_registered = 0;
+       }
+}
+
+static void _brightness_create(void *data)
+{
+       if (g_ctrl_obj == NULL) {
+               g_ctrl_obj = (brightness_ctrl_obj *)calloc(1, sizeof(brightness_ctrl_obj));
+               if (g_ctrl_obj != NULL) {
+                       g_ctrl_obj->min_level = BRIGHTNESS_MIN;
+                       g_ctrl_obj->max_level = BRIGHTNESS_MAX;
+                       g_ctrl_obj->last_requested_level = _brightness_get_level();
+
+                       _brightness_add(g_ctrl_obj, data);
+                       _brightness_view_update();
+                       _brightness_register_event_cb(g_ctrl_obj);
+
+                       g_ctrl_obj->brighntess_slider = NULL;
+
+                       DBG("brightness controller is created");
+               }
+       }
+}
+
+static void _brightness_destroy(void *data)
+{
+       if (g_ctrl_obj != NULL) {
+               _brightness_deregister_event_cb(g_ctrl_obj);
+               _brightness_remove(g_ctrl_obj, data);
+
+               DBG("brightness controller is removed");
+       }
+
+       g_ctrl_obj = NULL;
+}
+
+static void _handler_brightness(void *data, DBusMessage *msg)
+{
+       int ret = 0;
+       DBusError err;
+       char *key = NULL;
+       char *value = NULL;
+       retif(data == NULL || msg == NULL, , "Invalid parameter!");
+
+       dbus_error_init(&err);
+       ret = dbus_message_get_args(msg, &err,
+                       DBUS_TYPE_STRING, &key,
+                       DBUS_TYPE_STRING, &value,
+                       DBUS_TYPE_INVALID);
+       retif(ret == 0, , "dbus_message_get_args error");
+       retif(key == NULL, , "Failed to get key");
+       retif(value == NULL, , "Failed to get value");
+
+       if (dbus_error_is_set(&err)) {
+               ERR("dbus err: %s", err.message);
+               dbus_error_free(&err);
+               return;
+       }
+
+       if (strcmp(key, "visibility") == 0) {
+               if (strcmp(value, PREF_BRIGHTNESS_ON) == 0) {
+                       _brightness_create(data);
+                       quickpanel_preference_set(PREF_BRIGHTNESS, PREF_BRIGHTNESS_ON);
+               } else if (strcmp(value, PREF_BRIGHTNESS_OFF) == 0) {
+                       _brightness_destroy(data);
+                       quickpanel_preference_set(PREF_BRIGHTNESS, PREF_BRIGHTNESS_OFF);
+               }
+       }
+}
+
+static void _ipc_init(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+       retif(ad->dbus_connection == NULL, , "Invalid parameter!");
+
+       g_hdl_brightness =
+               e_dbus_signal_handler_add(ad->dbus_connection, NULL,
+                               QP_DBUS_PATH,
+                               QP_DBUS_NAME,
+                               BRIGHTNESS_SIG_ACTIVITY,
+                               _handler_brightness, data);
+       msgif(g_hdl_brightness == NULL, "fail to add size signal");
+}
+
+static void _ipc_fini(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+       retif(ad->dbus_connection == NULL, , "Invalid parameter!");
+
+       if (g_hdl_brightness != NULL) {
+               e_dbus_signal_handler_del(ad->dbus_connection, g_hdl_brightness);
+               g_hdl_brightness = NULL;
+       }
+}
+
+static int _init(void *data)
+{
+       char buf[PREF_LEN_VALUE_MAX] = {0,};
+       retif(data == NULL, QP_FAIL, "Invalid parameter!");
+
+#ifdef QP_EMERGENCY_MODE_ENABLE
+       if (quickpanel_emergency_mode_is_on()) {
+               return QP_OK;
+       }
+#endif
+
+       quickpanel_preference_get(PREF_BRIGHTNESS, buf);
+       _brightness_create(data);
+
+       _ipc_init(data);
+
+       return QP_OK;
+}
+
+static int _fini(void *data)
+{
+       retif(data == NULL, QP_FAIL, "Invalid parameter!");
+
+       _ipc_fini(data);
+       _brightness_destroy(data);
+
+       return QP_OK;
+}
+
+static void _lang_changed(void *data)
+{
+       retif(data == NULL, , "Invalid parameter!");
+
+       if (g_ctrl_obj != NULL && g_ctrl_obj->viewer != NULL) {
+               _brightness_view_update();
+       }
+}
+
+static void _qp_opened(void *data)
+{
+       Evas_Object *slider = NULL;
+       Evas_Object *view = _controller_view_get();
+       retif(g_ctrl_obj == NULL, , "Invalid parameter!");
+       retif(view == NULL, , "Invalid parameter!");
+
+       if (view != NULL) {
+               _brightness_view_update();
+               slider = elm_object_part_content_get(view, "elm.swallow.slider");
+               if (slider != NULL) {
+                       DBG("quickpanel opened");
+                       _brightness_ctrl_overheat_check(slider, g_ctrl_obj, 0);
+               }
+       }
+}
+
+static void _qp_closed(void *data)
+{
+       retif(g_ctrl_obj == NULL, , "Invalid parameter!");
+
+       if (g_ctrl_obj->viewer != NULL) {
+               _brightness_view_update();
+       }
+}
+
+static void _refresh(void *data)
+{
+       int h = 0;
+       struct appdata *ad = data;
+       Evas_Object *view = _controller_view_get();
+       retif(ad == NULL, , "Invalid parameter!");
+       retif(g_ctrl_obj == NULL, , "Invalid parameter!");
+       retif(g_ctrl_obj->viewer == NULL, , "Invalid parameter!");
+       retif(view == NULL, , "Invalid parameter!");
+
+       evas_object_geometry_get(g_ctrl_obj->viewer, NULL, NULL, NULL, &h);
+
+       if (ad->angle == 90 || ad->angle == 270) {
+               evas_object_resize(g_ctrl_obj->viewer, ad->win_height, h);
+               evas_object_resize(view, ad->win_height, h);
+               _brightness_view_pos_set();
+
+       } else {
+               evas_object_resize(g_ctrl_obj->viewer, ad->win_width, h);
+               evas_object_resize(view, ad->win_width, h);
+               _brightness_view_pos_set();
+       }
+}
diff --git a/daemon/handler_controller.c b/daemon/handler_controller.c
new file mode 100755 (executable)
index 0000000..8ad2401
--- /dev/null
@@ -0,0 +1,86 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#include <Elementary.h>
+
+#include <dlog.h>
+#include <vconf.h>
+
+#include <tapi_common.h>
+#include <ITapiSim.h>
+#include <TelCall.h>
+#include <ITapiCall.h>
+
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "handler_controller.h"
+#include "setting_utils.h"
+#include "list_util.h"
+#include "quickpanel-ui.h"
+#include "common.h"
+
+HAPI void quickpanel_handler_text_set(char *text)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+       if (!ad) {
+               ERR("Could not get application data");
+               return;
+       }
+
+       Evas_Object *layout = ad->view_root;
+       if (!layout) {
+               ERR("Could not get view_root");
+               return;
+       }
+
+       if (text) {
+               elm_object_part_text_set(layout, "qp.handler.text", text);
+               elm_object_signal_emit(layout, "show", "qp.handler.text");
+       } else {
+               elm_object_part_text_set(layout, "qp.handler.text", " ");
+               elm_object_signal_emit(layout, "hide", "qp.handler.text");
+       }
+}
+
+HAPI void quickpanel_handler_set_visibility(Eina_Bool visible)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+       if (!ad) {
+               ERR("Could not get application data");
+               return;
+       }
+
+       Evas_Object *layout = ad->view_root;
+       if (!layout) {
+               ERR("Could not get view_root");
+               return;
+       }
+
+       if (visible == EINA_FALSE) {
+               elm_object_signal_emit(layout, "qp.handler.text,hide", "qp.handler.text");
+       } else {
+               elm_object_signal_emit(layout, "qp.handler.text,show", "qp.handler.text");
+       }
+}
+
+
+
+
+
diff --git a/daemon/handler_controller.h b/daemon/handler_controller.h
new file mode 100755 (executable)
index 0000000..eec2530
--- /dev/null
@@ -0,0 +1,25 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef HANDLER_CONTROLLER_H_
+#define HANDLER_CONTROLLER_H_
+
+extern void quickpanel_handler_text_set(char *text);
+extern void quickpanel_handler_set_visibility(Eina_Bool visible);
+
+#endif /* HANDLER_CONTROLLER_H_ */
diff --git a/daemon/list_util.c b/daemon/list_util.c
new file mode 100755 (executable)
index 0000000..ad40a9e
--- /dev/null
@@ -0,0 +1,744 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#include <Elementary.h>
+#include <stdlib.h>
+
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "quickpanel-ui.h"
+#include "common.h"
+#include "list_util.h"
+#include "vi_manager.h"
+
+#define E_DATA_ITEM_LABEL_H "QP_ITEM_DATA"
+
+struct _qp_item_data {
+       qp_item_type_e type;
+       void *data;
+};
+
+static Eina_Bool _anim_init_cb(void *data);
+static Eina_Bool _anim_job_cb(void *data);
+static Eina_Bool _anim_done_cb(void *data);
+
+static void _viewer_freeze(Evas_Object *viewer)
+{
+       int freezed_count = 0;
+       retif(viewer == NULL, , "Invalid parameter!");
+
+       freezed_count = elm_object_scroll_freeze_get(viewer);
+
+       if (freezed_count <= 0) {
+               elm_object_scroll_freeze_push(viewer);
+       }
+}
+
+static void _viewer_unfreeze(Evas_Object *viewer)
+{
+       int i = 0, freezed_count = 0;
+       retif(viewer == NULL, , "Invalid parameter!");
+
+       freezed_count = elm_object_scroll_freeze_get(viewer);
+
+       for (i = 0 ; i < freezed_count; i++) {
+               elm_object_scroll_freeze_pop(viewer);
+       }
+}
+
+HAPI qp_item_data *quickpanel_list_util_item_new(qp_item_type_e type, void *data)
+{
+       qp_item_data *qid;
+
+       qid = malloc(sizeof(*qid));
+       if (!qid) {
+               ERR("fail to alloc qid");
+               return NULL;
+       }
+
+       qid->type = type;
+       qid->data = data;
+
+       return qid;
+}
+
+HAPI void quickpanel_list_util_item_del(qp_item_data *qid)
+{
+       free(qid);
+}
+
+HAPI void quickpanel_list_util_item_set_tag(Evas_Object *item, qp_item_data *qid)
+{
+       retif(item == NULL, , "invalid parameter");
+       retif(qid == NULL, , "invalid parameter");
+
+       evas_object_data_set(item, E_DATA_ITEM_LABEL_H, qid);
+}
+
+HAPI void quickpanel_list_util_item_del_tag(Evas_Object *item)
+{
+       retif(item == NULL, , "invalid parameter");
+
+       qp_item_data *qid = evas_object_data_get(item, E_DATA_ITEM_LABEL_H);
+
+       if (qid != NULL) {
+               evas_object_data_del(item, E_DATA_ITEM_LABEL_H);
+               free(qid);
+       }
+}
+
+HAPI void *quickpanel_list_util_item_get_data(qp_item_data *qid)
+{
+       void *user_data = NULL;
+
+       if (!qid) {
+               return NULL;
+       }
+
+       user_data = qid->data;
+
+       return user_data;
+}
+
+HAPI void quickpanel_list_util_item_set_data(qp_item_data *qid, void *data)
+{
+       if (!qid) {
+               return;
+       }       
+
+       qid->data = data;
+}
+
+HAPI int quickpanel_list_util_item_compare(const void *data1, const void *data2)
+{
+       int diff = 0;
+       qp_item_data *qid1 = NULL;
+       qp_item_data *qid2 = NULL;
+       const Evas_Object *eo1 = data1;
+       const Evas_Object *eo2 = data2;
+
+       if (!eo1) {
+               INFO("eo1 is NULL");
+               return -1;
+       }
+
+       if (!eo2) {
+               INFO("eo2 is NULL");
+               return 1;
+       }
+
+       qid1 = evas_object_data_get(eo1, E_DATA_ITEM_LABEL_H);
+       qid2 = evas_object_data_get(eo2, E_DATA_ITEM_LABEL_H);
+
+       if (!qid1) {
+               INFO("qid1 is NULL");
+               return -1;
+       }
+
+       if (!qid2) {
+               INFO("qid2 is NULL");
+               return 1;
+       }
+
+       /* elm_genlist sort is not working as i expected */
+       if (qid1->type == qid2->type) {
+               return 1;
+       }
+
+
+       diff = qid1->type - qid2->type;
+       return diff;
+}
+
+static qp_item_type_e _get_item_type(qp_item_data *item_data)
+{
+       retif(item_data == NULL, QP_ITEM_TYPE_NONE, "a invalid data");
+
+       return item_data->type;
+}
+
+static int _item_compare(const void *data1, const void *data2)
+{
+       int diff = 0;
+       const Evas_Object *eo1 = data1;
+       const qp_item_data *qid1 = NULL;
+       const qp_item_data *qid2 = data2;
+
+       if (!data1) {
+               INFO("data1 is NULL");
+               return -1;
+       }
+
+       if (!data2) {
+               INFO("data2 is NULL");
+               return 1;
+       }
+
+       qid1 = evas_object_data_get(eo1, E_DATA_ITEM_LABEL_H);
+
+       if (!qid1) {
+               INFO("qid1 is NULL");
+               return -1;
+       }
+
+       diff = qid1->type - qid2->type;
+
+       return diff;
+}
+
+static void _list_util_layout_get_coord(Evas_Object *container, Evas_Object *first, int *coord_x, int *coord_y)
+{
+       int x = 0;
+       int y = 0;
+       int h = 0;
+       int off_y = 0;
+       qp_item_type_e item_type = QP_ITEM_TYPE_NONE;
+       struct appdata *ad = quickpanel_get_app_data();
+
+       retif(container == NULL, , "invalid parameter");
+       retif(ad == NULL, , "invalid data.");
+
+       Eina_List *list_tmp = NULL;
+       Eina_List *l = NULL;
+       Eina_List *l_next = NULL;
+       Evas_Object *obj = NULL;
+       Eina_List *item_list = elm_box_children_get(container);
+
+       EINA_LIST_FOREACH_SAFE(item_list, l, l_next, obj) {
+               if (obj != NULL) {
+                       item_type = quickpanel_list_util_item_type_get(obj);
+                       if (item_type == QP_ITEM_TYPE_ONGOING_NOTI
+                                       || item_type == QP_ITEM_TYPE_NOTI) {
+                               list_tmp = elm_box_children_get(obj);
+                               if (list_tmp != NULL) {
+                                       if (eina_list_count(list_tmp) != 0 ) {
+                                               evas_object_geometry_get(obj, NULL, NULL, NULL, &h);
+                                       }
+                                       eina_list_free(list_tmp);
+                               }
+                       } else {
+                               evas_object_geometry_get(obj, NULL, NULL, NULL, &h);
+                       }
+
+                       off_y += h;
+                       h = 0;
+                       if (obj == first) {
+                               break;
+                       }
+               }
+       }
+
+       evas_object_geometry_get(container, &x, &y, NULL, &h);
+       if (off_y == 0 || y == 0) {
+               ERR("Failed get a valid height offset : %d %d", off_y, y);
+       }
+
+       if (coord_x != NULL) {
+               *coord_x = x;
+       }
+       if (coord_y != NULL) {
+               *coord_y = y + off_y;
+       }
+
+       if (item_list != NULL) {
+               eina_list_free(item_list);
+       }
+}
+
+Evas_Object *_list_util_get_first(Evas_Object *list, Evas_Object *new_obj)
+{
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *obj = NULL;
+       Evas_Object *first = NULL;
+       Eina_List *item_list = elm_box_children_get(list);
+
+       qp_item_data *item_data = NULL;
+
+       retif(list == NULL, NULL, "invalid parameter");
+       retif(new_obj == NULL, NULL, "invalid parameter");
+
+       item_data = evas_object_data_get(new_obj, E_DATA_ITEM_LABEL_H);
+       retif(item_data == NULL, NULL, "invalid parameter");
+
+       EINA_LIST_FOREACH_SAFE(item_list, l, l_next, obj) {
+               if (obj != NULL) {
+                       if (_item_compare(obj, item_data) > 0) {
+                               break;
+                       }
+               }
+
+               first = obj;
+       }
+
+       if (item_list != NULL) {
+               eina_list_free(item_list);
+       }
+
+       return first;
+}
+
+HAPI qp_item_type_e quickpanel_list_util_item_type_get(Evas_Object *item)
+{
+       qp_item_data *qid = NULL;
+       retif(item == NULL, QP_ITEM_TYPE_NONE, "invalid parameter");
+
+       qid = evas_object_data_get(item, E_DATA_ITEM_LABEL_H);
+       if (qid != NULL) {
+               return _get_item_type(qid);
+       }
+
+       return QP_ITEM_TYPE_NONE;
+}
+
+HAPI void quickpanel_list_util_item_unpack_by_object(Evas_Object *list , Evas_Object *item, int is_unpack_only, int is_hide)
+{
+       QP_VI *vi = NULL;
+       qp_item_data *qid = NULL;
+       retif(list == NULL, , "invalid parameter");
+       retif(item == NULL, , "invalid parameter");
+
+       qid = evas_object_data_get(item, E_DATA_ITEM_LABEL_H);
+       vi = quickpanel_vi_new_with_data(
+                       VI_OP_DELETE,
+                       _get_item_type(qid),
+                       list,
+                       item,
+                       _anim_init_cb,
+                       _anim_job_cb,
+                       _anim_done_cb,
+                       _anim_done_cb,
+                       vi,
+                       NULL,
+                       is_unpack_only,
+                       is_hide);
+       quickpanel_vi_start(vi);
+}
+
+HAPI void quickpanel_list_util_sort_insert(Evas_Object *list, Evas_Object *new_obj)
+{
+
+       QP_VI *vi = NULL;
+       qp_item_data *qid = NULL;
+       retif(list == NULL, , "invalid parameter");
+       retif(new_obj == NULL, , "invalid parameter");
+
+       qid = evas_object_data_get(new_obj, E_DATA_ITEM_LABEL_H);
+       vi = quickpanel_vi_new_with_data(
+                       VI_OP_INSERT,
+                       _get_item_type(qid),
+                       list,
+                       new_obj,
+                       _anim_init_cb,
+                       _anim_job_cb,
+                       _anim_done_cb,
+                       _anim_done_cb,
+                       vi,
+                       NULL,
+                       0,
+                       0);
+       quickpanel_vi_start(vi);
+}
+
+HAPI Elm_Transit *quickpanel_list_util_get_reorder_transit(Evas_Object *item, Elm_Transit *transit, int distance)
+{
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *obj = NULL;
+       Eina_List *item_list = NULL;
+       int is_start_relayout = 0;
+       Elm_Transit *transit_layout = NULL;
+       Evas_Object *container = NULL;
+
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, NULL, "invalid parameter");
+
+       container = ad->list;
+       retif(container == NULL, NULL, "invalid parameter");
+       retif(item == NULL, NULL, "invalid parameter");
+
+       item_list = elm_box_children_get(container);
+
+       EINA_LIST_FOREACH_SAFE(item_list, l, l_next, obj) {
+               if (obj == item) {
+                       is_start_relayout = 1;
+               } else if (obj != NULL && is_start_relayout == 1) {
+                       transit_layout = elm_transit_add();
+                       if (transit_layout != NULL) {
+                               elm_transit_effect_translation_add(transit_layout, 0, 0, 0, distance);
+                               elm_transit_object_add(transit_layout, obj);
+                               elm_transit_duration_set(transit_layout,
+                                               quickpanel_vim_get_duration(VI_OP_REORDER));
+                               elm_transit_tween_mode_set(transit_layout,
+                                               quickpanel_vim_get_tweenmode(VI_OP_REORDER));
+                               elm_transit_objects_final_state_keep_set(transit_layout, EINA_TRUE);
+                               elm_transit_event_enabled_set(transit_layout, EINA_TRUE);
+                               if (transit != NULL) {
+                                       elm_transit_chain_transit_add(transit, transit_layout);
+                               } else {
+                                       elm_transit_go(transit_layout);
+                               }
+                       }
+               }
+       }
+
+       if (item_list != NULL) {
+               eina_list_free(item_list);
+       }
+
+       return transit_layout;
+}
+
+static void _anim_init_insert(void *data)
+{
+       QP_VI *vi = data;
+       int coord_x = 0, coord_y = 0;
+       retif(vi == NULL, , "invalid parameter");
+
+       retif(vi->container == NULL, , "invalid parameter");
+       retif(vi->target == NULL, , "invalid parameter");
+
+       Evas_Object *container = vi->container;
+       Evas_Object *item = vi->target;
+       Evas_Object *first = NULL;
+
+       evas_object_clip_set(item, evas_object_clip_get(container));
+       evas_object_color_set(item, 0, 0, 0, 0);
+
+       first = _list_util_get_first(container, item);
+       _list_util_layout_get_coord(container, first, &coord_x, &coord_y);
+       evas_object_move(item, coord_x, coord_y);
+}
+
+static void _anim_job_insert(void *data)
+{
+
+       QP_VI *vi = data;
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *obj = NULL;
+       Eina_List *item_list = NULL;
+       int is_start_relayout = 0;
+       int item_width, item_height = 0;
+       int coord_x = 0, coord_y = 0;
+       Elm_Transit *transit_layout = NULL;
+       Elm_Transit *transit_fadein = NULL;
+       Evas_Object *container = NULL;
+       Evas_Object *item = NULL;
+       Evas_Object *first = NULL;
+
+       retif(vi == NULL, , "invalid parameter");
+       retif(vi->container == NULL, , "invalid parameter");
+       retif(vi->target == NULL, , "invalid parameter");
+
+       container = vi->container;
+       item = vi->target;
+       item_list = elm_box_children_get(container);
+
+       first = _list_util_get_first(container, item);
+       _list_util_layout_get_coord(container, first, &coord_x, &coord_y);
+       evas_object_move(item, coord_x, coord_y);
+       is_start_relayout = (first == NULL) ? 1 : 0;
+
+       evas_object_geometry_get(item, NULL, NULL, &item_width, &item_height);
+       if (item_width == 0 && item_height == 0) {
+               ERR("failed to get a size of item %d %d", item_width, item_height);
+               evas_object_size_hint_min_get (item, &item_width, &item_height);
+       }
+
+       if (vi->item_type == QP_ITEM_TYPE_ONGOING_NOTI) {
+               if (item_list != NULL) {
+                       eina_list_free(item_list);
+               }
+               return;
+       }
+
+       EINA_LIST_FOREACH_SAFE(item_list, l, l_next, obj) {
+               if (obj == first) {
+                       is_start_relayout = 1;
+               } else if (obj != NULL && is_start_relayout == 1) {
+                       transit_layout = elm_transit_add();
+                       if (transit_layout != NULL) {
+                               elm_transit_effect_translation_add(transit_layout, 0, 0, 0, item_height);
+                               elm_transit_object_add(transit_layout, obj);
+                               elm_transit_duration_set(transit_layout,
+                                               quickpanel_vim_get_duration(VI_OP_REORDER));
+                               elm_transit_tween_mode_set(transit_layout,
+                                               quickpanel_vim_get_tweenmode(VI_OP_REORDER));
+                               elm_transit_objects_final_state_keep_set(transit_layout, EINA_TRUE);
+                               elm_transit_go(transit_layout);
+                       } else {
+                               ERR("Failed to create a transit");
+                       }
+               }
+       }
+
+       if (item_list != NULL) {
+               eina_list_free(item_list);
+       }
+
+       transit_fadein = elm_transit_add();
+       if (transit_fadein != NULL) {
+               elm_transit_object_add(transit_fadein, item);
+               elm_transit_effect_color_add(transit_fadein, 0, 0, 0, 0, 255, 255, 255, 255);
+               elm_transit_duration_set(transit_fadein,
+                               quickpanel_vim_get_duration(VI_OP_INSERT));
+               elm_transit_tween_mode_set(transit_fadein,
+                               quickpanel_vim_get_tweenmode(VI_OP_INSERT));
+               elm_transit_del_cb_set(transit_fadein, quickpanel_vi_done_cb_for_transit, vi);
+
+               if (transit_layout != NULL) {
+                       elm_transit_chain_transit_add(transit_layout, transit_fadein);
+               } else {
+                       elm_transit_go(transit_fadein);
+               }
+       } else {
+               if (transit_layout != NULL) elm_transit_del(transit_layout);
+               quickpanel_vi_done(vi);
+               ERR("Failed to create all the transit");
+       }
+}
+
+static void _anim_done_insert(void *data)
+{
+       QP_VI *vi = data;
+       retif(data == NULL, , "invalid parameter");
+       retif(vi->container == NULL, , "invalid parameter");
+       retif(vi->target == NULL, , "invalid parameter");
+
+       Evas_Object *container = vi->container;
+       Evas_Object *item = vi->target;
+       Evas_Object *first = _list_util_get_first(container, item);
+
+       evas_object_color_set(item, 255, 255, 255, 255);
+
+       if (first == NULL) {
+               elm_box_pack_start(container, item);
+       } else {
+               elm_box_pack_after(container, item, first);
+       }
+}
+
+static void _anim_job_delete(void *data)
+{
+       QP_VI *vi = data;
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *obj = NULL;
+       Eina_List *item_list = NULL;
+       int is_start_relayout = 0;
+       int item_width, item_height = 0;
+       Elm_Transit *transit_layout = NULL;
+       Elm_Transit *transit_fadeout = NULL;
+       Evas_Object *container = NULL;
+       Evas_Object *item = NULL;
+
+       retif(vi == NULL, , "invalid parameter");
+       retif(vi->container == NULL, , "invalid parameter");
+       retif(vi->target == NULL, , "invalid parameter");
+
+       container = vi->container;
+       item = vi->target;
+       item_list = elm_box_children_get(container);
+
+       evas_object_geometry_get(item, NULL, NULL, &item_width, &item_height);
+       if (item_width == 0 && item_height == 0) {
+               ERR("failed to get a size of item %d %d", item_width, item_height);
+               evas_object_size_hint_min_get (item, &item_width, &item_height);
+       }
+
+       transit_fadeout = elm_transit_add();
+       if (transit_fadeout != NULL) {
+               elm_transit_object_add(transit_fadeout, item);
+               elm_transit_effect_color_add(transit_fadeout, 255, 255, 255, 255, 0, 0, 0, 0);
+               elm_transit_objects_final_state_keep_set(transit_fadeout, EINA_TRUE);
+               elm_transit_tween_mode_set(transit_fadeout,
+                               quickpanel_vim_get_tweenmode(VI_OP_DELETE));
+               elm_transit_duration_set(transit_fadeout,
+                               quickpanel_vim_get_duration(VI_OP_DELETE));
+               elm_transit_go(transit_fadeout);
+
+               EINA_LIST_FOREACH_SAFE(item_list, l, l_next, obj) {
+                       if (obj == item) {
+                               is_start_relayout = 1;
+                       } else if (obj != NULL && is_start_relayout == 1) {
+                               transit_layout = elm_transit_add();
+                               if (transit_layout != NULL) {
+                                       elm_transit_effect_translation_add(transit_layout, 0, 0, 0, -item_height);
+                                       elm_transit_object_add(transit_layout, obj);
+                                       elm_transit_duration_set(transit_layout,
+                                                       quickpanel_vim_get_duration(VI_OP_REORDER));
+                                       elm_transit_tween_mode_set(transit_layout,
+                                                       quickpanel_vim_get_tweenmode(VI_OP_REORDER));
+                                       elm_transit_objects_final_state_keep_set(transit_layout, EINA_TRUE);
+                                       elm_transit_chain_transit_add(transit_fadeout, transit_layout);
+                               } else {
+                                       ERR("Failed to create a transit");
+                               }
+                       }
+               }
+       }
+
+       if (item_list != NULL) {
+               eina_list_free(item_list);
+       }
+
+       if (transit_layout != NULL) {
+               elm_transit_del_cb_set(transit_layout, quickpanel_vi_done_cb_for_transit,
+                               vi);
+       } else if (transit_fadeout != NULL) {
+               elm_transit_del_cb_set(transit_fadeout, quickpanel_vi_done_cb_for_transit,
+                               vi);
+       } else {
+               ERR("Failed to create all the transit");
+               quickpanel_vi_done(vi);
+       }
+}
+
+static void _anim_done_delete(void *data)
+{
+       QP_VI *vi = data;
+
+       retif(vi == NULL, , "invalid parameter");
+       retif(vi->container == NULL, , "invalid parameter");
+       retif(vi->target == NULL, , "invalid parameter");
+
+       Evas_Object *container = vi->container;
+       Evas_Object *item = vi->target;
+
+       elm_box_unpack(container, item);
+
+       if (vi->extra_flag_2 == 1) {
+               evas_object_move(item, -10000, -10000);
+               quickpanel_vi_object_event_freeze_set(item, EINA_FALSE);
+       }
+       if (vi->extra_flag_1 == 0 && item != NULL) {
+               evas_object_del(item);
+               item = NULL;
+       }
+}
+
+static Eina_Bool _anim_init_cb(void *data)
+{
+       int i = 0;
+       QP_VI *vi = data;
+       retif(vi == NULL, EINA_FALSE, "invalid parameter");
+
+       static qp_vi_op_table anim_init_table[] = {
+               {
+                       .op_type = VI_OP_INSERT,
+                       .handler = _anim_init_insert,
+               },
+               {
+                       .op_type = VI_OP_NONE,
+                       .handler = NULL,
+               },
+       };
+
+       for (i = 0; anim_init_table[i].op_type != VI_OP_NONE; i++) {
+               if (anim_init_table[i].op_type != vi->op_type) {
+                       continue;
+               }
+
+               anim_init_table[i].handler(vi);
+               break;
+       }
+
+       return EINA_TRUE;
+}
+
+static Eina_Bool _anim_job_cb(void *data)
+{
+       int i = 0;
+       QP_VI *vi = data;
+       retif(vi == NULL, EINA_FALSE, "invalid parameter");
+
+       static qp_vi_op_table anim_job_table[] = {
+               {
+                       .op_type = VI_OP_INSERT,
+                       .handler = _anim_job_insert,
+               },
+               {
+                       .op_type = VI_OP_DELETE,
+                       .handler = _anim_job_delete,
+               },
+               {
+                       .op_type = VI_OP_NONE,
+                       .handler = NULL,
+               },
+       };
+
+       for (i = 0; anim_job_table[i].op_type != VI_OP_NONE; i++) {
+               if (anim_job_table[i].op_type != vi->op_type) {
+                       continue;
+               }
+
+               anim_job_table[i].handler(vi);
+               break;
+       }
+
+       return EINA_TRUE;
+}
+
+static Eina_Bool _anim_done_cb(void *data)
+{
+       int i = 0;
+       QP_VI *vi = data;
+       retif(vi == NULL, EINA_FALSE, "invalid parameter");
+
+       static qp_vi_op_table anim_done_table[] = {
+               {
+                       .op_type = VI_OP_INSERT,
+                       .handler = _anim_done_insert,
+               },
+               {
+                       .op_type = VI_OP_DELETE,
+                       .handler = _anim_done_delete,
+               },
+               {
+                       .op_type = VI_OP_NONE,
+                       .handler = NULL,
+               },
+       };
+
+       for (i = 0; anim_done_table[i].op_type != VI_OP_NONE; i++) {
+               if (anim_done_table[i].op_type != vi->op_type) {
+                       continue;
+               }
+
+               anim_done_table[i].handler(vi);
+               break;
+       }
+
+       return EINA_TRUE;
+}
+
+HAPI void quickpanel_list_util_scroll_freeze_set(Eina_Bool is_freeze)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "invalid data.");
+       retif(ad->scroller == NULL, , "invalid data.");
+
+       if (is_freeze == EINA_TRUE) {
+               _viewer_freeze(ad->scroller);
+       } else {
+               _viewer_unfreeze(ad->scroller);
+       }
+}
diff --git a/daemon/list_util.h b/daemon/list_util.h
new file mode 100755 (executable)
index 0000000..342e365
--- /dev/null
@@ -0,0 +1,65 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef _QP_LIST_UTIL_DEF_
+#define _QP_LIST_UTIL_DEF_
+
+typedef enum {
+       QP_ITEM_TYPE_NONE = -1,
+       QP_ITEM_TYPE_SETTING = 0,
+       QP_ITEM_TYPE_BRIGHTNESS,
+       QP_ITEM_TYPE_VOICE_CONTOL,
+       QP_ITEM_TYPE_FACTORY,
+       QP_ITEM_TYPE_MULTIWINDOW,
+       QP_ITEM_TYPE_EARJACK,
+       QP_ITEM_TYPE_MINICTRL_ONGOING,
+       QP_ITEM_TYPE_MINICTRL_MIDDLE,
+       QP_ITEM_TYPE_ONGOING_NOTI_GROUP,
+       QP_ITEM_TYPE_ONGOING_NOTI,
+       QP_ITEM_TYPE_NOTI_GROUP,
+       QP_ITEM_TYPE_NOTI,
+       QP_ITEM_TYPE_BAR,
+       QP_ITEM_TYPE_MAX,
+} qp_item_type_e;
+
+typedef struct _qp_item_data qp_item_data;
+typedef struct _qp_item_count {
+       int group;
+       int ongoing;
+       int noti;
+       int minicontrol;
+} qp_item_count;
+
+extern qp_item_data *quickpanel_list_util_item_new(qp_item_type_e type, void *data);
+extern void quickpanel_list_util_item_del(qp_item_data *qid);
+extern void quickpanel_list_util_item_set_tag(Evas_Object *item, qp_item_data *qid);
+extern void quickpanel_list_util_item_del_tag(Evas_Object *item);
+
+extern void *quickpanel_list_util_item_get_data(qp_item_data *qid);
+extern void quickpanel_list_util_item_set_data(qp_item_data *qid, void *data);
+extern int quickpanel_list_util_item_compare(const void *data1, const void *data2);
+extern qp_item_type_e quickpanel_list_util_item_type_get(Evas_Object *item);
+
+extern void quickpanel_list_util_item_unpack_by_object(Evas_Object *list , Evas_Object *item, int is_unpack_only, int is_hide);
+extern void quickpanel_list_util_sort_insert(Evas_Object *list, Evas_Object *new_obj);
+
+extern Elm_Transit *quickpanel_list_util_get_reorder_transit(Evas_Object *item, Elm_Transit *transit, int distance);
+extern void quickpanel_list_util_scroll_freeze_set(Eina_Bool is_freeze);
+
+#endif /* _QP_LIST_UTIL_DEF_ */
+
diff --git a/daemon/media.c b/daemon/media.c
new file mode 100755 (executable)
index 0000000..916d391
--- /dev/null
@@ -0,0 +1,509 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <stdio.h>
+#include <unistd.h>
+#include <glib.h>
+#include <unistd.h>
+
+#include <Elementary.h>
+
+#include <vconf.h>
+#include <metadata_extractor.h>
+#include <feedback.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <player.h>
+#include <E_DBus.h>
+
+#include "common.h"
+#include "quickpanel-ui.h"
+#include "media.h"
+
+#define NEED_TO_DEBUG_LOCKUP_ISSUE
+
+static struct info {
+       int id;
+       int is_feedback_initialized;
+       player_h player;
+       sound_stream_info_h stream_info;
+       Ecore_Timer *playing_timer;
+} s_info = {
+       .player = NULL,
+       .playing_timer = NULL,
+       .stream_info = NULL,
+       .id = 0,
+       .is_feedback_initialized = 0,
+};
+
+static void _quickpanel_player_free(player_h *sound_player);
+
+static void _quickpanel_player_del_timeout_timer(void)
+{
+       if (s_info.playing_timer) {
+               ecore_timer_del(s_info.playing_timer);
+               s_info.playing_timer = NULL;
+       }
+}
+
+static Eina_Bool _quickpanel_player_timeout_cb(void *data)
+{
+       s_info.playing_timer = NULL;
+
+       retif(data == NULL, ECORE_CALLBACK_CANCEL, "invalid parameter");
+       player_h *sound_player = data;
+
+       _quickpanel_player_free(sound_player);
+       s_info.playing_timer = NULL;
+
+       return ECORE_CALLBACK_CANCEL;
+}
+
+static void _quickpanel_player_free_job_cb(void *data)
+{
+       player_h sound_player = data;
+       player_state_e state = PLAYER_STATE_NONE;
+       sound_stream_focus_state_e state_for_playback;
+
+       int ret = PLAYER_ERROR_NONE;
+       retif(sound_player == NULL, , "invalid parameter");
+
+#ifdef NEED_TO_DEBUG_LOCKUP_ISSUE
+       SERR("before stopping media");
+#endif
+       if (player_get_state(sound_player, &state) == PLAYER_ERROR_NONE) {
+
+               INFO("the state of sound player %d", state);
+
+               if (state == PLAYER_STATE_PLAYING) {
+                       player_stop(sound_player);
+                       player_unprepare(sound_player);
+               }
+               if (state == PLAYER_STATE_READY) {
+                       player_unprepare(sound_player);
+               }
+       }
+       player_destroy(sound_player);
+#ifdef NEED_TO_DEBUG_LOCKUP_ISSUE
+       SERR("after stopping media");
+#endif
+
+       ret = sound_manager_get_focus_state(s_info.stream_info, &state_for_playback, NULL);
+
+       if (state_for_playback == SOUND_STREAM_FOCUS_STATE_ACQUIRED) {
+               ret = sound_manager_release_focus(s_info.stream_info, SOUND_STREAM_FOCUS_FOR_PLAYBACK, NULL);
+               if (ret != SOUND_MANAGER_ERROR_NONE) {
+                       ERR("sound_manager_release_focus() get failed : %d", ret);
+               }
+       }
+
+       ret = sound_manager_destroy_stream_information(s_info.stream_info);
+       if (ret != SOUND_MANAGER_ERROR_NONE) {
+               ERR("sound_manager_destroy_stream_information() get failed : %d", ret);
+       }
+
+       s_info.stream_info = NULL;
+
+       DBG("");
+}
+
+static void _quickpanel_player_free(player_h *sound_player)
+{
+       retif(sound_player == NULL, , "invalid parameter");
+       retif(*sound_player == NULL, , "invalid parameter");
+
+       ecore_job_add(_quickpanel_player_free_job_cb, *sound_player);
+       *sound_player = NULL;
+}
+
+static void _quickpanel_player_start_job_cb(void *data)
+{
+       int ret = PLAYER_ERROR_NONE;
+       player_h *sound_player = data;
+
+#ifdef NEED_TO_DEBUG_LOCKUP_ISSUE
+       SERR("before playing media");
+#endif
+       ret = player_start(*sound_player);
+       if (ret != PLAYER_ERROR_NONE) { /* if directly return retor.. */
+               ERR("player_start [%d]", ret);
+               _quickpanel_player_free(sound_player);
+               return;
+       }
+       s_info.playing_timer = ecore_timer_add(QP_PLAY_DURATION_LIMIT,
+                       _quickpanel_player_timeout_cb, sound_player);
+#ifdef NEED_TO_DEBUG_LOCKUP_ISSUE
+       SERR("after playing media");
+#endif
+}
+
+static void _quickpanel_player_completed_cb(void *user_data)
+{
+       retif(user_data == NULL, , "invalid parameter");
+       player_h *sound_player = user_data;
+
+       DBG("Media player completed");
+
+       _quickpanel_player_del_timeout_timer();
+       _quickpanel_player_free(sound_player);
+}
+
+static void _quickpanel_player_error_cb(int error_code, void *user_data)
+{
+       retif(user_data == NULL, , "invalid parameter");
+       player_h *sound_player = user_data;
+
+       ERR("Error code [%d]", (int)error_code);
+
+       _quickpanel_player_del_timeout_timer();
+       _quickpanel_player_free(sound_player);
+}
+
+HAPI int quickpanel_media_player_is_drm_error(int error_code)
+{
+       if (error_code == PLAYER_ERROR_DRM_EXPIRED
+                       || error_code == PLAYER_ERROR_DRM_NO_LICENSE
+                       || error_code == PLAYER_ERROR_DRM_FUTURE_USE
+                       || error_code == PLAYER_ERROR_DRM_NOT_PERMITTED) {
+               return 1;
+       }
+
+       return 0;
+}
+
+
+static void _quickpanel_sound_stream_focus_state_changed_cb(sound_stream_info_h stream_info, sound_stream_focus_change_reason_e reason_for_change, const char *additional_info, void *user_data)
+{
+       DBG("_quickpanel_sound_stream_focus_state_changed_cb called, reason_for_change [%d], additional_info [%s]", reason_for_change, additional_info);
+
+       retif(user_data == NULL, , "invalid parameter");
+       player_h *sound_player = user_data;
+
+       _quickpanel_player_del_timeout_timer();
+       _quickpanel_player_free(sound_player);
+}
+
+HAPI int quickpanel_media_player_play(sound_type_e sound_type, const char *sound_file)
+{
+       player_h *sound_player = &s_info.player;
+       sound_stream_info_h *stream_info = &s_info.stream_info;
+
+       int ret = PLAYER_ERROR_NONE;
+       int sndRet = SOUND_MANAGER_ERROR_NONE;
+       player_state_e state = PLAYER_STATE_NONE;
+
+#ifdef NEED_TO_DEBUG_LOCKUP_ISSUE
+       SERR("Start player");
+#endif
+       _quickpanel_player_del_timeout_timer();
+
+       if (*sound_player != NULL) {
+               _quickpanel_player_free(sound_player);
+       }
+
+#ifdef NEED_TO_DEBUG_LOCKUP_ISSUE
+       SERR("setting sound session start");
+#endif
+
+       if (*stream_info != NULL) {
+               sndRet = sound_manager_destroy_stream_information(*stream_info);
+               if (sndRet != SOUND_MANAGER_ERROR_NONE) {
+                       ERR("sound_manager_destroy_stream_information() get failed : %x", ret);
+               }
+       }
+
+       if (sound_type == SOUND_TYPE_NOTIFICATION) {
+               sndRet = sound_manager_create_stream_information(SOUND_STREAM_TYPE_NOTIFICATION, _quickpanel_sound_stream_focus_state_changed_cb, (void*)sound_player, stream_info);
+               if (sndRet != SOUND_MANAGER_ERROR_NONE) {
+                       ERR("sound_manager_create_stream_information() get failed :%x", sndRet);
+                       return PLAYER_ERROR_INVALID_PARAMETER;
+               }
+
+               sndRet = sound_manager_set_focus_reacquisition(*stream_info, false);
+               if (sndRet != SOUND_MANAGER_ERROR_NONE) {
+                       ERR("sound_manager_set_focus_reacquisition() set failed : %d", ret);
+                       return sndRet;
+               }
+
+               sndRet = sound_manager_acquire_focus(*stream_info, SOUND_STREAM_FOCUS_FOR_PLAYBACK, NULL);
+               if (sndRet != SOUND_MANAGER_ERROR_NONE) {
+                       ERR("sound_manager_acquire_focus() get failed : %d", ret);
+                       return sndRet;
+               }
+       }
+
+#ifdef NEED_TO_DEBUG_LOCKUP_ISSUE
+       SERR("setting sound session finished");
+#endif
+
+#ifdef NEED_TO_DEBUG_LOCKUP_ISSUE
+       SERR("player_create start");
+#endif
+       ret = player_create(sound_player);
+       if (ret != PLAYER_ERROR_NONE) {
+               ERR("creating the player handle failed[%d]", ret);
+               *sound_player = NULL;
+               return ret;
+       }
+#ifdef NEED_TO_DEBUG_LOCKUP_ISSUE
+       SERR("player_create finished");
+#endif
+
+       player_get_state(*sound_player, &state);
+       if (state > PLAYER_STATE_READY) {
+               _quickpanel_player_free(sound_player);
+               return ret;
+       }
+
+       ret = player_set_uri(*sound_player, sound_file);
+       if (ret != PLAYER_ERROR_NONE) {
+               ERR("set attribute---profile_uri[%d]", ret);
+               _quickpanel_player_free(sound_player);
+               return ret;
+       }
+
+       if (*stream_info != NULL) {
+               ret = player_set_audio_policy_info(*sound_player, *stream_info);
+               if (ret != PLAYER_ERROR_NONE) {
+                       ERR("player_set_audio_policy_info failed : %d", ret);
+                       _quickpanel_player_free(sound_player);
+                       return ret;
+               }
+       }
+
+       ret = player_prepare(*sound_player);
+       if (ret != PLAYER_ERROR_NONE) {
+               ERR("realizing the player handle failed[%d]", ret);
+               _quickpanel_player_free(sound_player);
+               return ret;
+       }
+
+       player_get_state(*sound_player, &state);
+       if (state != PLAYER_STATE_READY) {
+               ERR("state of player is invalid %d", state);
+               _quickpanel_player_free(sound_player);
+               return ret;
+       }
+
+       /* register callback */
+       ret = player_set_completed_cb(*sound_player, _quickpanel_player_completed_cb, sound_player);
+       if (ret != PLAYER_ERROR_NONE) {
+               ERR("player_set_completed_cb() ERR: %x!!!!", ret);
+               _quickpanel_player_free(sound_player);
+               return ret;
+       }
+
+       ret = player_set_error_cb(*sound_player, _quickpanel_player_error_cb, sound_player);
+       if (ret != PLAYER_ERROR_NONE) {
+               _quickpanel_player_free(sound_player);
+               return ret;
+       }
+
+       ecore_job_add(_quickpanel_player_start_job_cb, sound_player);
+#ifdef NEED_TO_DEBUG_LOCKUP_ISSUE
+       SERR("playing request");
+#endif
+
+       return ret;
+}
+
+static Eina_Bool _playable_check(const char *file_path)
+{
+       char *value = NULL;
+       int ret_meta =  METADATA_EXTRACTOR_ERROR_NONE;
+       metadata_extractor_h metadata = NULL;
+       Eina_Bool ret = EINA_FALSE;
+
+       ret_meta = metadata_extractor_create(&metadata);
+       if (ret_meta != METADATA_EXTRACTOR_ERROR_NONE) {
+               ERR("Failed to create metadata extractor:%d", ret_meta);
+               return ret;
+       }
+
+       if (metadata == NULL) {
+               ERR("Failed to create metadata extractor:%d", ret_meta);
+               return ret;
+       }
+
+       ret_meta = metadata_extractor_set_path(metadata, file_path);
+       if (ret_meta != METADATA_EXTRACTOR_ERROR_NONE) {
+               ERR("Failed to set path to meta extractor:%d", ret_meta);
+               metadata_extractor_destroy(metadata);
+               return ret;
+       }
+       ret_meta = metadata_extractor_get_metadata(metadata, METADATA_HAS_AUDIO, &value);
+       if (ret_meta != METADATA_EXTRACTOR_ERROR_NONE) {
+               ERR("Failed to get metadata:%d", ret_meta);
+               metadata_extractor_destroy(metadata);
+               return ret;
+       }
+
+       if(value && g_strcmp0(value, "0")) {
+               ret = EINA_TRUE;
+       }
+
+       free(value);
+
+       DBG("%s :: playable[%d]", file_path, ret);
+       metadata_extractor_destroy(metadata);
+       return ret;
+}
+
+HAPI Eina_Bool quickpanel_media_playable_check(const char *file_path)
+{
+       Eina_Bool ret = EINA_FALSE;
+
+       /* Check file exist or not */
+       ret = ecore_file_exists(file_path);
+       if (ret == EINA_FALSE) {
+               ERR("%s file does not exist", file_path);
+               return ret;
+       }
+
+       /* Check file playable or not */
+       ret = _playable_check(file_path);
+       if (ret == EINA_FALSE) {
+               ERR("%s file does not playable", file_path);
+               return ret;
+       }
+
+       return ret;
+}
+
+
+HAPI void quickpanel_media_player_stop(void)
+{
+       _quickpanel_player_del_timeout_timer();
+
+       if (s_info.player != NULL) {
+               _quickpanel_player_free(&s_info.player);
+       }
+
+       quickpanel_media_player_id_set(0);
+}
+
+HAPI void quickpanel_media_player_id_set(int id)
+{
+       s_info.id = id;
+}
+
+HAPI int quickpanel_media_player_id_get(void)
+{
+       return s_info.id;
+}
+
+HAPI int quickpanel_media_is_sound_enabled(void)
+{
+       int snd_status = 0, ret = -1;
+
+#ifdef VCONFKEY_SETAPPL_ACCESSIBILITY_TURN_OFF_ALL_SOUNDS
+       int snd_disabled_status = 0;
+
+       ret = vconf_get_bool(VCONFKEY_SETAPPL_ACCESSIBILITY_TURN_OFF_ALL_SOUNDS, &snd_disabled_status);
+       msgif(ret != 0, "failed to get VCONFKEY_SETAPPL_ACCESSIBILITY_TURN_OFF_ALL_SOUNDS");
+       ret = vconf_get_bool(VCONFKEY_SETAPPL_SOUND_STATUS_BOOL, &snd_status);
+       msgif(ret != 0, "failed to get VCONFKEY_SETAPPL_SOUND_STATUS_BOOL");
+
+       if (snd_disabled_status == 0 && snd_status == 1) {
+               return 1;
+       }
+#else
+       ret = vconf_get_bool(VCONFKEY_SETAPPL_SOUND_STATUS_BOOL, &snd_status);
+       msgif(ret != 0, "failed to get VCONFKEY_SETAPPL_SOUND_STATUS_BOOL");
+
+       if (snd_status == 1) {
+               return 1;
+       }
+#endif
+
+       return 0;
+}
+
+HAPI int quickpanel_media_is_vib_enabled(void)
+{
+       int vib_status = 0, ret = -1;
+
+       ret = vconf_get_bool(VCONFKEY_SETAPPL_VIBRATION_STATUS_BOOL, &vib_status);
+       if (ret == 0) {
+               if (vib_status == 1)
+                       return 1;
+       } else {
+               ERR("failed to get a value of VCONFKEY_SETAPPL_VIBRATION_STATUS_BOOL");
+       }
+
+       return 0;
+}
+
+HAPI void quickpanel_media_play_feedback(void)
+{
+       int snd_enabled = quickpanel_media_is_sound_enabled();
+       int vib_enabled = quickpanel_media_is_vib_enabled();
+
+       quickpanel_media_init();
+
+       if (snd_enabled == 1) {
+               feedback_play_type(FEEDBACK_TYPE_SOUND, FEEDBACK_PATTERN_TAP);
+       } else  if (vib_enabled == 1) {
+               feedback_play_type(FEEDBACK_TYPE_VIBRATION, FEEDBACK_PATTERN_TAP);
+       }
+}
+
+HAPI int quickpanel_media_set_mute_toggle(void)
+{
+       int ret = -1;
+
+       if (quickpanel_media_is_sound_enabled() == 1 ||
+                       quickpanel_media_is_vib_enabled() == 1) {
+               ret = vconf_set_bool(VCONFKEY_SETAPPL_SOUND_STATUS_BOOL, 0);
+               msgif(ret != 0, "failed to set VCONFKEY_SETAPPL_SOUND_STATUS_BOOL");
+
+               ret = vconf_set_bool(VCONFKEY_SETAPPL_VIBRATION_STATUS_BOOL, 0);
+               msgif(ret != 0, "failed to set VCONFKEY_SETAPPL_VIBRATION_STATUS_BOOL");
+
+               return 0;
+       } else {
+               ret = vconf_set_bool(VCONFKEY_SETAPPL_SOUND_STATUS_BOOL, 1);
+               msgif(ret != 0, "failed to set VCONFKEY_SETAPPL_SOUND_STATUS_BOOL");
+
+               ret = vconf_set_bool(VCONFKEY_SETAPPL_VIBRATION_STATUS_BOOL, 0);
+               msgif(ret != 0, "failed to set VCONFKEY_SETAPPL_VIBRATION_STATUS_BOOL");
+
+               return 1;
+       }
+}
+
+HAPI void quickpanel_media_init(void)
+{
+       if (s_info.is_feedback_initialized == 0) {
+               if (feedback_initialize() == FEEDBACK_ERROR_NONE) {
+                       s_info.is_feedback_initialized = 1;
+               } else {
+                       ERR("failed to init feedback API");
+               }
+       }
+}
+
+HAPI void quickpanel_media_fini(void)
+{
+       if (s_info.is_feedback_initialized == 1) {
+               if (feedback_deinitialize() == FEEDBACK_ERROR_NONE) {
+                       s_info.is_feedback_initialized = 0;
+               } else {
+                       ERR("failed to deinit feedback API");
+               }
+       }
+}
diff --git a/daemon/media.h b/daemon/media.h
new file mode 100755 (executable)
index 0000000..ae011c3
--- /dev/null
@@ -0,0 +1,36 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#ifndef __QUICKPANEL_MEDIA_H__
+#define __QUICKPANEL_MEDIA_H__
+
+#define QP_PLAY_DURATION_LIMIT 15
+
+extern int quickpanel_media_player_play(sound_type_e sound_type, const char *sound_file);
+extern void quickpanel_media_player_stop(void);
+extern int quickpanel_media_is_sound_enabled(void);
+extern int quickpanel_media_is_vib_enabled(void);
+extern void quickpanel_media_play_feedback(void);
+extern int quickpanel_media_set_mute_toggle(void);
+extern void quickpanel_media_player_id_set(int id);
+extern int quickpanel_media_player_id_get(void);
+extern Eina_Bool quickpanel_media_playable_check(const char *file_path);
+extern int quickpanel_media_player_is_drm_error(int error_code);
+extern void quickpanel_media_init(void);
+extern void quickpanel_media_fini(void);
+
+#endif
diff --git a/daemon/minictrl/minictrl.c b/daemon/minictrl/minictrl.c
new file mode 100755 (executable)
index 0000000..5c5ccf5
--- /dev/null
@@ -0,0 +1,1182 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#include <Elementary.h>
+#include <glib.h>
+#include <string.h>
+#include <stdbool.h>
+
+#include <minicontrol-viewer.h>
+#include <minicontrol-internal.h>
+#include <bundle.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "common.h"
+#include "common_uic.h"
+#include "quickpanel-ui.h"
+#include "quickpanel_def.h"
+#include "list_util.h"
+#include "quickpanel_debug_util.h"
+#include "minictrl.h"
+#include "vi_manager.h"
+
+#ifdef QP_SCREENREADER_ENABLE
+#include "accessibility.h"
+#endif
+
+#define MINICONTROL_TYPE_STR_VIEWER "::[viewer="
+#define MINICONTROL_TYPE_STR_QUICKPANEL "QUICKPANEL"
+#define MINICONTROL_TYPE_STR_LOCKSCREEN "LOCKSCREEN"
+#define MINICONTROL_TYPE_STR_ONGOING "_ongoing]"
+#define MINICONTROL_VIEW_DATA "MINICONTROL_VIEW_DATA"
+
+#define THRESHOLD_DELETE_START 30
+#define THRESHOLD_DELETE_START_Y_LIMIT 60
+#define THRESHOLD_DISTANCE (200)
+#define THRESHOLD_DISTANCE_LOCK (500)
+
+#define MINICONTROL_BUNDLE_KEY_WIDTH "width"
+#define MINICONTROL_BUNDLE_KEY_HEIGHT "height"
+
+#define BUNDLE_BUFFER_LENGTH 100
+
+typedef enum _gesture_state_type {
+       STATE_NORMAL = 0,
+       STATE_GESTURE_WAIT,
+       STATE_GESTURE_CANCELED,
+       STATE_DELETED,
+} gesture_state_type;
+
+struct _viewer_item {
+       char *name;
+       unsigned int width;
+       unsigned int height;
+       Evas_Object *viewer;
+       void *data;
+
+       //for flick gesture
+       QP_VI *vi;
+       int obj_w;
+       int obj_h;
+       int press_x;
+       int press_y;
+       int distance;
+       int need_to_cancel_press;
+       gesture_state_type state;
+       int deletable;
+};
+
+static struct _info {
+       GHashTable *prov_table;
+} s_info = {
+       .prov_table = NULL,
+};
+
+void _minictrl_sendview_rotation_event(const char* name, int angle);
+
+static int _viewer_check(const char *name)
+{
+       char *pos_start = NULL;
+
+       if (!name) {
+               ERR("Name is NULL");
+               return 0;
+       }
+
+       if ((pos_start = strstr(name, MINICONTROL_TYPE_STR_VIEWER)) != NULL) {
+               if (strstr(pos_start, MINICONTROL_TYPE_STR_QUICKPANEL) != NULL) {
+                       return 1;
+               } else {
+                       return 0;
+               }
+       } else if (strstr(name, MINICONTROL_TYPE_STR_LOCKSCREEN) != NULL) {
+               return 0;
+       }
+
+       return 1;
+}
+
+static void _viewer_unfreeze(Evas_Object *viewer)
+{
+       int i = 0, freezed_count = 0;
+
+       if (!viewer) {
+               ERR("Invalid parameter");
+               return;
+       }
+
+       freezed_count = elm_object_scroll_freeze_get(viewer);
+
+       for (i = 0 ; i < freezed_count; i++) {
+               elm_object_scroll_freeze_pop(viewer);
+       }
+}
+
+static Evas_Object *_get_minictrl_obj(Evas_Object *layout)
+{
+       if (!layout) {
+               ERR("Invalid parameter");
+               return NULL;
+       }
+
+       return elm_object_part_content_get(layout, "elm.icon");
+}
+
+static void _viewer_set_size(Evas_Object *layout, void *data, int width, int height)
+{
+       Evas_Object *viewer;
+       struct appdata *ad;
+       int max_width;
+       int resized_width;
+       int is_landscape;
+
+       if (!layout || !data || width < 0 || height < 0) {
+               ERR("Invalid parameters (%p, %p, %d, %d)", layout, data, width, height);
+               return;
+       }
+
+       viewer = _get_minictrl_obj(layout);
+       if (!viewer) {
+               ERR("Unable to get the 'viewer'");
+               return;
+       }
+
+       ad = data;
+
+       if (ad->angle == 0 || ad->angle == 180) {
+               is_landscape = 0;
+       } else {
+               is_landscape = 1;
+       }
+
+       if (width > ad->win_width) {
+               ERR("MC Size is not valid. it is larger than window size: %dx%d (%dx%d) %d", width, height, ad->win_width, ad->win_height, ad->angle);
+       }
+
+       max_width  = is_landscape ? ad->win_height : ad->win_width;
+       resized_width = (width > max_width) ? max_width : width;
+
+       SERR("minicontroller view is resized to w:%d/%d(%d) h:%d Landscape[%d]", resized_width, max_width, width, height, is_landscape);
+
+       evas_object_size_hint_min_set(viewer, resized_width, height);
+       evas_object_size_hint_max_set(viewer, resized_width, height);
+}
+
+static void _viewer_item_free(struct _viewer_item *item)
+{
+       struct appdata *ad;
+
+       ad = quickpanel_get_app_data();
+       if (!ad || !ad->list || !item) {
+               ERR("Invalid paramter %p, %p, %p", ad, ad ? ad->list : NULL, item);
+               return;
+       }
+
+       free(item->name);
+
+       if (item->viewer) {
+               quickpanel_list_util_item_unpack_by_object(ad->list, item->viewer, 0, 0);
+               quickpanel_list_util_item_del_tag(item->viewer);
+               evas_object_del(item->viewer);
+       }
+
+       free(item);
+}
+
+static bool _check_deletable(Evas_Object *obj)
+{
+       struct _viewer_item *vit;
+
+       vit = evas_object_data_get(obj, MINICONTROL_VIEW_DATA);
+       if (vit) {
+               return vit->deletable;
+       }
+
+       return TRUE;
+}
+
+static void _mouse_down_cb(void *data, Evas *e, Evas_Object *obj, void *event_info)
+{
+       Evas_Event_Mouse_Down *ev;
+       struct _viewer_item *vit;
+
+       vit = evas_object_data_get(obj, MINICONTROL_VIEW_DATA);
+       ev = (Evas_Event_Mouse_Down *)event_info;
+
+       if (!ev || !vit) {
+               ERR("ev %p, vit %p");
+               return;
+       }
+
+       evas_object_geometry_get(obj, NULL, NULL, &vit->obj_w, &vit->obj_h);
+
+       vit->press_x = ev->canvas.x;
+       vit->press_y = ev->canvas.y;
+       vit->state = STATE_NORMAL;
+
+       SDBG("mouse down:%d %d %d", vit->obj_w, vit->obj_h, vit->state);
+
+       if (vit->vi != NULL) {
+               quickpanel_vi_user_event_del(vit->vi);
+               vit->vi = NULL;
+       }
+
+       vit->need_to_cancel_press = 0;
+}
+
+static void _mouse_move_cb(void* data, Evas* e, Evas_Object* obj, void* event_info)
+{
+       static int vi_start_x = 0;
+       static int delta_prev = -1;
+       int delta_x;
+       int x;
+       int y;
+       int w;
+       int h;
+       Evas_Event_Mouse_Move* ev;
+       struct _viewer_item *vit;
+       struct appdata *ad;
+
+       ad = data;
+       ev = event_info;
+       vit = evas_object_data_get(obj, MINICONTROL_VIEW_DATA);
+       if (!ev || !vit || !ad) {
+               ERR("ev: %p, vit: %p, ad: %p", ev, vit, ad);
+               return;
+       }
+
+       if (vit->state == STATE_GESTURE_CANCELED) {
+               DBG("deletion has been canceled");
+               return;
+       }
+
+       if (!_check_deletable(obj)) {
+               DBG("vit->deletable is false");
+               return;
+       }
+
+       evas_object_geometry_get(obj, &x, &y, &w, &h);
+       delta_x = (ev->cur.output.x - vit->press_x) / 2;
+
+       switch (vit->state) {
+       case STATE_NORMAL:
+               if (abs(delta_x) >= THRESHOLD_DELETE_START) {
+                       QP_VI *vi;
+
+                       DBG("start a deletion");
+                       vit->state = STATE_GESTURE_WAIT;
+
+                       vi_start_x = delta_x;
+
+                       vi = quickpanel_vi_new_with_data(
+                                       VI_OP_DELETE,
+                                       QP_ITEM_TYPE_NOTI,
+                                       NULL,
+                                       obj,
+                                       NULL,
+                                       NULL,
+                                       NULL,
+                                       NULL, /* _drag_cancel_cb, */
+                                       NULL, /* vi == null */
+                                       NULL,
+                                       0,
+                                       0);
+
+                       if (vi) {
+                               vit->vi = vi;
+                               quickpanel_vi_user_event_add(vi);
+                       } else {
+                               ERR("Unable to create a 'vi'");
+                       }
+
+                       vit->need_to_cancel_press = 1;
+               }
+               break;
+       case STATE_GESTURE_WAIT:
+               if (delta_prev != delta_x) {
+                       Evas_Map *map;
+
+                       map = evas_map_new(4);
+                       if (map != NULL) {
+                               evas_map_util_points_populate_from_object(map, obj);
+                               evas_map_util_points_populate_from_geometry(map, x + delta_x - vi_start_x, y, w, h, 0);
+                               evas_object_map_enable_set(obj, EINA_TRUE);
+                               evas_object_map_set(obj, map);
+                               evas_map_free(map);
+                               _viewer_unfreeze(ad->scroller);
+                       }
+                       delta_prev = delta_x;
+               }
+               break;
+       default:
+               break;
+       }
+
+       vit->distance = delta_x;
+}
+
+static void _minictrl_remove(const char *name, void *data)
+{
+       DBG("_minictrl_remove [%s]", name);
+
+       minicontrol_viewer_send_event(name, MINICONTROL_EVENT_REQUEST_HIDE, NULL);
+
+       if (s_info.prov_table) {
+               if (g_hash_table_remove(s_info.prov_table, name)) {
+                       DBG("success to remove %s", name);
+                       if (!data) {
+                               ERR("data is NULL");
+                               /**
+                                * @todo
+                                * Oh, this function doesn't handles "data".
+                                * Why does this has to check its existence??
+                                */
+                               return;
+                       }
+               } else {
+                       WARN("unknown provider name : %s", name);
+               }
+       }
+}
+
+static void _mouse_up_cb(void *data, Evas *e, Evas_Object *obj, void *event_info)
+{
+       struct _viewer_item *vit;
+       struct appdata *ad;
+       int swipe_distance;
+
+       ad = data;
+       vit = evas_object_data_get(obj, MINICONTROL_VIEW_DATA);
+       if (!vit || !ad) {
+               ERR("vit: %p, ad: %p", vit, ad);
+               return;
+       }
+
+       _viewer_unfreeze(ad->scroller);
+
+       if (!_check_deletable(obj)) {
+               swipe_distance = THRESHOLD_DISTANCE_LOCK;
+       } else {
+               swipe_distance = THRESHOLD_DISTANCE;
+       }
+
+       switch (vit->state) {
+       case STATE_GESTURE_WAIT:
+               if (abs(vit->distance) >= (swipe_distance - 10)) {
+                       Elm_Transit *transit_flick;
+                       int x;
+
+                       x = abs(vit->distance) - THRESHOLD_DELETE_START;
+
+                       if (vit->distance > 0) {
+                               evas_object_map_set(obj, NULL);
+                               transit_flick = elm_transit_add();
+                               if (transit_flick != NULL) {
+                                       elm_transit_effect_translation_add(transit_flick, x, 0, 480, 0);
+                                       elm_transit_object_add(transit_flick, obj);
+                                       elm_transit_duration_set(transit_flick, 0.25 * (480 - x ) / 480);
+                                       elm_transit_tween_mode_set(transit_flick, ELM_TRANSIT_TWEEN_MODE_LINEAR);
+                                       elm_transit_objects_final_state_keep_set(transit_flick, EINA_TRUE);
+                                       elm_transit_go(transit_flick);
+                                       _minictrl_remove(vit->name, vit->data);
+                               }
+                       } else if (vit->distance < 0) {
+                               evas_object_map_set(obj, NULL);
+                               transit_flick = elm_transit_add();
+                               if (transit_flick != NULL) {
+                                       elm_transit_effect_translation_add(transit_flick, -x, 0, -480, 0);
+                                       elm_transit_object_add(transit_flick, obj);
+                                       elm_transit_duration_set(transit_flick, 0.25 * ( 480 - x ) / 480);
+                                       elm_transit_tween_mode_set(transit_flick, ELM_TRANSIT_TWEEN_MODE_LINEAR);
+                                       elm_transit_objects_final_state_keep_set(transit_flick, EINA_TRUE);
+                                       elm_transit_go(transit_flick);
+                                       _minictrl_remove(vit->name, vit->data);
+                               }
+                       }
+               } else {
+                       evas_object_map_enable_set(obj, EINA_FALSE);
+               }
+
+               if (vit->vi != NULL) {
+                       quickpanel_vi_user_event_del(vit->vi);
+                       vit->vi = NULL;
+               }
+               break;
+       case STATE_GESTURE_CANCELED:
+               evas_object_map_enable_set(obj, EINA_FALSE);
+
+               if (vit->vi != NULL) {
+                       quickpanel_vi_user_event_del(vit->vi);
+                       vit->vi = NULL;
+               }
+               break;
+       default:
+               break;
+       }
+
+       vit->state = STATE_NORMAL;
+}
+
+static Evas_Object *_minictrl_create_view(struct appdata *ad, const char *name)
+{
+       Evas_Object *layout;
+       Evas_Object *viewer;
+       Evas_Object *focus;
+
+       if (!ad || !ad->list || !name) {
+               ERR("Invalid parameters: %p %p %p", ad, ad ? ad->list : NULL, name);
+               return NULL;
+       }
+
+       layout = elm_layout_add(ad->list);
+       if (!layout) {
+               ERR("Unable to create a layout");
+               return NULL;
+       }
+
+       elm_layout_file_set(layout, DEFAULT_EDJ, "quickpanel/minictrl/default");
+       evas_object_size_hint_weight_set(layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       evas_object_size_hint_align_set(layout, EVAS_HINT_FILL, EVAS_HINT_FILL);
+       evas_object_show(layout);
+
+       viewer = minicontrol_viewer_add(layout, name);
+       if (!viewer) {
+               ERR("fail to add viewer - %s", name);
+               evas_object_del(layout);
+               return NULL;
+       }
+       elm_object_focus_allow_set(viewer, EINA_TRUE);
+       elm_object_part_content_set(layout, "elm.icon", viewer);
+
+       evas_object_event_callback_add(viewer, EVAS_CALLBACK_MOUSE_DOWN, _mouse_down_cb, ad);
+       evas_object_event_callback_add(viewer, EVAS_CALLBACK_MOUSE_MOVE, _mouse_move_cb, ad);
+       evas_object_event_callback_add(viewer, EVAS_CALLBACK_MOUSE_UP, _mouse_up_cb, ad);
+
+       focus = quickpanel_accessibility_ui_get_focus_object(layout);
+       elm_object_part_content_set(layout, "focus", focus);
+#ifdef QP_SCREENREADER_ENABLE
+       Evas_Object *ao;
+       ao = quickpanel_accessibility_screen_reader_object_get(layout, SCREEN_READER_OBJ_TYPE_ELM_OBJECT, "focus", layout);
+       if (ao != NULL) {
+               elm_access_info_cb_set(ao, ELM_ACCESS_TYPE, quickpanel_accessibility_info_cb, _NOT_LOCALIZED("Mini controller"));
+       }
+#endif
+
+       return layout;
+}
+
+static int _minictrl_is_ongoing(const char *str)
+{
+       if (str == NULL) {
+               return 0;
+       }
+
+       if (strstr(str, MINICONTROL_TYPE_STR_ONGOING) != NULL) {
+               return 1;
+       } else {
+               return 0;
+       }
+}
+
+static void _minictrl_add(const char *name, unsigned int width, unsigned int height, void *data)
+{
+       qp_item_data *qid = NULL;
+       struct _viewer_item *vit = NULL;
+       qp_item_type_e type;
+       struct appdata *ad;
+       Evas_Object *viewer = NULL;
+
+       if (!name || !data) {
+               ERR("name: %p, data: %p", name, data);
+               return;
+       }
+
+       ad = data;
+       if (!ad->list) {
+               ERR("List is null");
+               return;
+       }
+
+       if (s_info.prov_table) {
+               struct _viewer_item *found;
+
+               found = g_hash_table_lookup(s_info.prov_table, name);
+               if (found) {
+                       ERR("already have it : %s", name);
+                       return;
+               }
+       } else {
+               ERR("s_info.prov_table is NULL");
+               return;
+       }
+
+       /* elm_plug receives 'server_del' event,
+        * if it repeats connect and disconnect frequently.
+        *
+        */
+       viewer = _minictrl_create_view(ad, name);
+       if (!viewer) {
+               ERR("Failed to create view[%s]", name);
+               return;
+       }
+
+       _viewer_set_size(viewer, ad, width, height);
+       quickpanel_uic_initial_resize(viewer,
+                       (height > QP_THEME_LIST_ITEM_MINICONTRL_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT)
+                       ? height : QP_THEME_LIST_ITEM_MINICONTRL_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT);
+
+       vit = malloc(sizeof(*vit));
+       if (!vit) {
+               ERR("fail to alloc vit");
+               evas_object_del(viewer);
+               return;
+       }
+
+       if (_minictrl_is_ongoing(name) == 1) {
+               type = QP_ITEM_TYPE_MINICTRL_ONGOING;
+       } else {
+               type = QP_ITEM_TYPE_MINICTRL_MIDDLE;
+       }
+
+       qid = quickpanel_list_util_item_new(type, vit);
+       if (!qid) {
+               ERR("fail to alloc vit");
+               evas_object_del(viewer);
+               free(vit);
+               return;
+       }
+
+       vit->name = strdup(name);
+       if (!vit->name) {
+               ERR("strdup: %d", errno);
+               quickpanel_list_util_item_del(qid);
+               evas_object_del(viewer);
+               free(vit);
+               return;
+       }
+       vit->width = width;
+       vit->height = height;
+       vit->viewer = viewer;
+       vit->data = data;
+       vit->deletable = 1;
+       quickpanel_list_util_item_set_tag(vit->viewer, qid);
+       quickpanel_list_util_sort_insert(ad->list, vit->viewer);
+       evas_object_data_set(_get_minictrl_obj(viewer), MINICONTROL_VIEW_DATA, vit);
+
+       g_hash_table_insert(s_info.prov_table, g_strdup(name), vit);
+
+       DBG("success to add minicontrol %s", name);
+       _minictrl_sendview_rotation_event(vit->name, ad->angle);
+}
+
+static void _anim_init_resize(void *data)
+{
+       QP_VI *vi;
+       Evas_Object *item;
+
+       vi = data;
+       if (!vi) {
+               ERR("Invalid parameter");
+               return;
+       }
+
+       item = vi->target;
+       if (!item) {
+               ERR("Invalid target");
+               return;
+       }
+
+       evas_object_color_set(item, 0, 0, 0, 0);
+}
+
+static Eina_Bool _anim_init_cb(void *data)
+{
+       QP_VI *vi;
+       int i;
+       static qp_vi_op_table anim_init_table[] = {
+               {
+                       .op_type = VI_OP_RESIZE,
+                       .handler = _anim_init_resize,
+               },
+               {
+                       .op_type = VI_OP_NONE,
+                       .handler = NULL,
+               },
+       };
+       
+       vi = data;
+       if (!vi) {
+               ERR("Invalid parameter");
+               return EINA_FALSE;
+       }
+
+       for (i = 0; anim_init_table[i].op_type != VI_OP_NONE; i++) {
+               if (anim_init_table[i].op_type != vi->op_type) {
+                       continue;
+               }
+
+               anim_init_table[i].handler(vi);
+               break;
+       }
+
+       return EINA_TRUE;
+}
+
+static void _reorder_transit_del_cb(void *data, Elm_Transit *transit)
+{
+       QP_VI *vi;
+       Evas_Object *item;
+       struct appdata *ad;
+
+       vi = data;
+       if (!vi) {
+               ERR("vi is null");
+               return;
+       }
+
+       item = vi->target;
+       if (!item) {
+               ERR("Target is null");
+               return;
+       }
+
+       ad = quickpanel_get_app_data();
+       if (!ad) {
+               ERR("ad is null");
+               return;
+       }
+
+       _viewer_set_size(item, ad, vi->extra_flag_1, vi->extra_flag_2);
+       quickpanel_uic_initial_resize(item,
+                       (vi->extra_flag_2 > QP_THEME_LIST_ITEM_MINICONTRL_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT)
+                       ? vi->extra_flag_2 : QP_THEME_LIST_ITEM_MINICONTRL_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT);
+}
+
+static void _anim_job_resize(void *data)
+{
+       Elm_Transit *transit_layout_parent;
+       struct _viewer_item *viewer_item;
+       Elm_Transit *transit_fadein;
+       struct appdata *ad;
+       Evas_Object *item;
+       int to_w, to_h;
+       QP_VI *vi;
+
+       vi = data;
+       ad = quickpanel_get_app_data();
+       if (!ad || !vi || !vi->target || !vi->extra_data_2) {
+               ERR("Invalid parameters: %p %p %p %p", ad, vi, vi ? vi->target : NULL, vi ? vi->extra_data_2 : NULL);
+               return;
+       }
+
+       item = vi->target;
+       to_w = vi->extra_flag_1;
+       to_h = vi->extra_flag_2;
+       viewer_item = vi->extra_data_2;
+
+       transit_layout_parent = quickpanel_list_util_get_reorder_transit(viewer_item->viewer, NULL, to_h - viewer_item->height);
+       if (transit_layout_parent != NULL) {
+               elm_transit_del_cb_set(transit_layout_parent, _reorder_transit_del_cb, vi);
+       } else {
+               _viewer_set_size(item, ad, to_w, to_h);
+               quickpanel_uic_initial_resize(item,
+                               (to_h > QP_THEME_LIST_ITEM_MINICONTRL_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT)
+                               ? to_h : QP_THEME_LIST_ITEM_MINICONTRL_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT);
+       }
+
+       transit_fadein = elm_transit_add();
+       if (transit_fadein != NULL) {
+               elm_transit_object_add(transit_fadein, item);
+               elm_transit_effect_color_add(transit_fadein, 0, 0, 0, 0, 255, 255, 255, 255);
+               elm_transit_duration_set(transit_fadein, 0.35);
+               elm_transit_tween_mode_set(transit_fadein, quickpanel_vim_get_tweenmode(VI_OP_INSERT));
+               elm_transit_del_cb_set(transit_fadein, quickpanel_vi_done_cb_for_transit, vi);
+               elm_transit_objects_final_state_keep_set(transit_fadein, EINA_TRUE);
+
+               if (transit_layout_parent != NULL) {
+                       elm_transit_chain_transit_add(transit_layout_parent, transit_fadein);
+                       elm_transit_go(transit_layout_parent);
+               } else {
+                       elm_transit_go(transit_fadein);
+               }
+       } else {
+               ERR("Failed to create all the transit");
+               quickpanel_vi_done(vi);
+       }
+}
+
+static Eina_Bool _anim_job_cb(void *data)
+{
+       QP_VI *vi;
+       int i;
+       static qp_vi_op_table anim_job_table[] = {
+               {
+                       .op_type = VI_OP_RESIZE,
+                       .handler = _anim_job_resize,
+               },
+               {
+                       .op_type = VI_OP_NONE,
+                       .handler = NULL,
+               },
+       };
+
+       vi = data;
+       if (!vi) {
+               ERR("Invalid parameter");
+               return EINA_FALSE;
+       }
+
+       for (i = 0; anim_job_table[i].op_type != VI_OP_NONE; i++) {
+               if (anim_job_table[i].op_type != vi->op_type) {
+                       continue;
+               }
+
+               anim_job_table[i].handler(vi);
+               break;
+       }
+
+       return EINA_TRUE;
+}
+
+static void _anim_done_resize(void *data)
+{
+       QP_VI *vi;
+       struct _viewer_item *viewer_item;
+       struct appdata *ad;
+       Evas_Object *item;
+
+       vi = data;
+       if (!vi) {
+               ERR("Invalid parameter");
+               return;
+       }
+
+       ad = quickpanel_get_app_data();
+       if (!ad) {
+               ERR("Invalid ad");
+               return;
+       }
+
+       item = vi->target;
+       if (!item) {
+               ERR("Invalid target");
+               return;
+       }
+
+       viewer_item = vi->extra_data_2;
+       if (!viewer_item) {
+               ERR("viewer_item is null");
+               return;
+       }
+
+       viewer_item->width = vi->extra_flag_1;
+       viewer_item->height = vi->extra_flag_2;
+
+       _viewer_set_size(item, ad, viewer_item->width, viewer_item->height);
+       quickpanel_uic_initial_resize(item,
+                       (viewer_item->height > QP_THEME_LIST_ITEM_MINICONTRL_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT)
+                       ? viewer_item->height : QP_THEME_LIST_ITEM_MINICONTRL_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT);
+       evas_object_color_set(item, 255, 255, 255, 255);
+}
+
+static Eina_Bool _anim_done_cb(void *data)
+{
+       QP_VI *vi;
+       int i;
+       static qp_vi_op_table anim_done_table[] = {
+               {
+                       .op_type = VI_OP_RESIZE,
+                       .handler = _anim_done_resize,
+               },
+               {
+                       .op_type = VI_OP_NONE,
+                       .handler = NULL,
+               },
+       };
+
+       vi = data;
+       if (!vi) {
+               ERR("Invalid parameter");
+               return EINA_FALSE;
+       }
+
+       for (i = 0; anim_done_table[i].op_type != VI_OP_NONE; i++) {
+               if (anim_done_table[i].op_type != vi->op_type) {
+                       continue;
+               }
+
+               anim_done_table[i].handler(vi);
+               break;
+       }
+
+       return EINA_TRUE;
+}
+
+static void _minictrl_resize_vi(Evas_Object *list, struct _viewer_item *item, int to_w, int to_h)
+{
+       QP_VI *vi;
+
+       if (!list || !item) {
+               ERR("Invalid parameter: list: %p, item: %p", list, item);
+               return;
+       }
+
+       vi = quickpanel_vi_new_with_data(
+                       VI_OP_RESIZE,
+                       QP_ITEM_TYPE_MINICTRL_MIDDLE,
+                       list,
+                       item->viewer,
+                       _anim_init_cb,
+                       _anim_job_cb,
+                       _anim_done_cb,
+                       _anim_done_cb,
+                       NULL, /* vi == NULL */
+                       item,
+                       to_w,
+                       to_h);
+
+       if (vi) {
+               quickpanel_vi_start(vi);
+       } else {
+               ERR("Unable to create 'vi'");
+       }
+}
+
+static void _minictrl_update(const char *name, unsigned int width, unsigned int height, void *data)
+{
+       struct appdata *ad = data;
+       struct _viewer_item *found = NULL;
+
+       if (!s_info.prov_table || !ad) {
+               ERR("name: %s, table: %p, ad: %p", name, s_info.prov_table, ad);
+               return;
+       }
+
+       found = g_hash_table_lookup(s_info.prov_table, name);
+       if (!found) {
+               WARN("unknown provider name : %s", name);
+               return;
+       }
+
+       if (found->viewer) {
+               if (found->height != height || found->width != width) {
+                       _minictrl_resize_vi(ad->list, found, width, height);
+               } else {
+                       _viewer_set_size(found->viewer, ad, width, height);
+                       quickpanel_uic_initial_resize(found->viewer,
+                                       (height > QP_THEME_LIST_ITEM_MINICONTRL_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT)
+                                       ? height : QP_THEME_LIST_ITEM_MINICONTRL_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT);
+               }
+       }
+}
+
+static void _minictrl_lock(const char *name)
+{
+       struct _viewer_item *found;
+
+       if (!s_info.prov_table) {
+               ERR("table is empty: %s", name);
+               return;
+       }
+
+       DBG("minictrl_lock %s", name);
+       found = g_hash_table_lookup(s_info.prov_table, name);
+       if (!found) {
+               WARN("unknown provider name : %s", name);
+               return;
+       }
+
+       if (found->viewer) {
+               struct _viewer_item *vit;
+
+               vit = evas_object_data_del(_get_minictrl_obj(found->viewer), MINICONTROL_VIEW_DATA);
+               if (vit) {
+                       vit->deletable = 0;
+                       evas_object_data_set(_get_minictrl_obj(found->viewer), MINICONTROL_VIEW_DATA, vit);
+               } else {
+                       WARN("vit is NULL");
+               }
+       }
+}
+
+static void _mctrl_viewer_event_cb(minicontrol_event_e event, const char *name, bundle *event_arg, void *data)
+{
+       struct appdata *ad;
+       int ret;
+       int *width;
+       int *height;
+       int _width;
+       int _height;
+       size_t bundle_size;
+
+       if (!data || !name) {
+               ERR("Invalid parameter");
+               return;
+       }
+
+       ad = data;
+
+       if (_viewer_check(name) == 0) {
+               ERR("%s: ignored", name);
+               return;
+       }
+
+       if ((int)event == MINICONTROL_EVENT_REQUEST_LOCK) {
+               /**
+                * This event type is extra one. not in the enumeration list.
+                */
+               _minictrl_lock(name);
+       } else {
+               switch (event) {
+               case MINICONTROL_EVENT_START:
+                       ret = bundle_get_byte(event_arg, MINICONTROL_BUNDLE_KEY_WIDTH, (void **)&width, &bundle_size);
+                       if (ret != BUNDLE_ERROR_NONE || bundle_size != sizeof(int)) {
+                               ERR("Failed to get bundle value(width) %d : %d", ret, bundle_size);
+                               _width = 0;
+                               width = &_width;
+                       }
+
+                       ret = bundle_get_byte(event_arg, MINICONTROL_BUNDLE_KEY_HEIGHT, (void **)&height, &bundle_size);
+                       if (ret != BUNDLE_ERROR_NONE || bundle_size != sizeof(int)) {
+                               ERR("Failed to get bundle value(height) : %d", ret);
+                               _height = 0;
+                               height = &_height;
+                       }
+
+                       DBG("Name: %s, Size: %dx%d", name, *width, *height);
+                       _minictrl_add(name, *width, *height, data);
+                       break;
+               case MINICONTROL_EVENT_RESIZE:
+                       ret = bundle_get_byte(event_arg, MINICONTROL_BUNDLE_KEY_WIDTH, (void **)&width, &bundle_size);
+                       if (ret != BUNDLE_ERROR_NONE || bundle_size != sizeof(int)) {
+                               ERR("Failed to get bundle value(width) %d : %d", ret, bundle_size);
+                               _width = 0;
+                               width = &_width;
+                       }
+
+                       ret = bundle_get_byte(event_arg, MINICONTROL_BUNDLE_KEY_HEIGHT, (void **)&height, &bundle_size);
+                       if (ret != BUNDLE_ERROR_NONE || bundle_size != sizeof(int)) {
+                               ERR("Failed to get bundle value(height) : %d", ret);
+                               _height = 0;
+                               height = &_height;
+                       }
+
+                       DBG("Name: %s, Size: %dx%d", name, *width, *height);
+                       _minictrl_update(name, *width, *height, data);
+                       break;
+               case MINICONTROL_EVENT_STOP:
+                       _minictrl_remove(name, data);
+                       break;
+               case MINICONTROL_EVENT_REQUEST_HIDE:
+                       quickpanel_uic_close_quickpanel(true, 0);
+                       break;
+               case MINICONTROL_EVENT_REQUEST_ANGLE:
+                       if (ad->list != NULL) {
+                               SERR("need to broadcasting angle by %s ", name, event);
+                               _minictrl_sendview_rotation_event(name, ad->angle);
+                       }
+                       break;
+               default:
+                       break;
+               }
+       }
+}
+
+static int _init(void *data)
+{
+       minicontrol_error_e ret;
+
+       if (!data) {
+               ERR("Invalid parameter");
+               return QP_FAIL;
+       }
+
+       s_info.prov_table = g_hash_table_new_full(g_str_hash, g_str_equal,
+                       (GDestroyNotify)g_free,
+                       (GDestroyNotify)_viewer_item_free);
+
+       ret = minicontrol_viewer_set_event_cb(_mctrl_viewer_event_cb, data);
+       if (ret != MINICONTROL_ERROR_NONE) {
+               ERR("fail to minicontrol_viewer_set_event_cb()- %d", ret);
+               return QP_FAIL;
+       }
+
+       return QP_OK;
+}
+
+static int _fini(void *data)
+{
+       minicontrol_error_e ret;
+
+       ret = minicontrol_viewer_unset_event_cb();
+
+       if (ret != MINICONTROL_ERROR_NONE) {
+               ERR("fail to minicontrol_viewer_unset_event_cb()- %d", ret);
+       }
+
+       if (s_info.prov_table) {
+               g_hash_table_destroy(s_info.prov_table);
+               s_info.prov_table = NULL;
+       }
+
+       return QP_OK;
+}
+
+static int _suspend(void *data)
+{
+       struct appdata *ad;
+
+       ad = data;
+       if (!ad) {
+               ERR("Invalid parameter");
+               return QP_FAIL;
+       }
+
+       if (ad->list != NULL) {
+               _viewer_unfreeze(ad->scroller);
+       }
+
+       return QP_OK;
+}
+
+static int _resume(void *data)
+{
+       struct appdata *ad;
+
+       ad = data;
+       if (!ad) {
+               ERR("Invalid parameter");
+               return QP_FAIL;
+       }
+
+       if (ad->list != NULL) {
+               _viewer_unfreeze(ad->scroller);
+       }
+
+       return QP_OK;
+}
+
+HAPI void quickpanel_minictrl_rotation_report(int angle)
+{
+       bundle *event_arg_bundle;
+
+       if (s_info.prov_table == NULL) {
+               return;
+       }
+
+       if (g_hash_table_size(s_info.prov_table) <= 0) {
+               return;
+       }
+
+       GHashTableIter iter;
+       gpointer key, value;
+
+       g_hash_table_iter_init (&iter, s_info.prov_table);
+       while (g_hash_table_iter_next (&iter, &key, &value))
+       {
+               SINFO("minicontrol name:%s rotation:%d", key, angle);
+               event_arg_bundle = bundle_create();
+               if (event_arg_bundle) {
+                       char bundle_value_buffer[BUNDLE_BUFFER_LENGTH] = { 0, };
+                       snprintf(bundle_value_buffer, sizeof(bundle_value_buffer) - 1, "%d", angle);
+                       bundle_add_str(event_arg_bundle, "angle", bundle_value_buffer);
+                       minicontrol_viewer_send_event(key, MINICONTROL_EVENT_REPORT_ANGLE, event_arg_bundle);
+                       bundle_free(event_arg_bundle);
+               }
+       }
+}
+
+void _minictrl_sendview_rotation_event(const char* name, int angle)
+{
+       bundle *event_arg_bundle;
+
+       if (!name) {
+               ERR("Invalid parameter");
+               return;
+       }
+
+       if (s_info.prov_table == NULL) {
+               return;
+       }
+
+       if (g_hash_table_size(s_info.prov_table) <= 0) {
+               return;
+       }
+
+       SINFO("minicontrol name:%s rotation:%d", name, angle);
+       event_arg_bundle = bundle_create();
+       if (event_arg_bundle) {
+               char bundle_value_buffer[BUNDLE_BUFFER_LENGTH] = { 0, };
+
+               snprintf(bundle_value_buffer, sizeof(bundle_value_buffer) - 1, "%d", angle);
+               bundle_add_str(event_arg_bundle, "angle", bundle_value_buffer);
+               minicontrol_viewer_send_event(name, MINICONTROL_EVENT_REPORT_ANGLE, event_arg_bundle);
+               bundle_free(event_arg_bundle);
+       }
+}
+
+static void _minictrl_send_view_event_cb(gpointer key, gpointer value, gpointer user_data)
+{
+       if (!key) {
+               ERR("Key is null");
+               return;
+       }
+
+       bundle *event_arg_bundle;
+
+       event_arg_bundle = bundle_create();
+       if (event_arg_bundle) {
+               minicontrol_viewer_event_e event;
+
+               event = (minicontrol_viewer_event_e)user_data;
+               minicontrol_viewer_send_event(key, event, event_arg_bundle);
+               bundle_free(event_arg_bundle);
+       }
+}
+
+static void _minictrl_opened(void *data)
+{
+       DBG("");
+
+       g_hash_table_foreach(s_info.prov_table, _minictrl_send_view_event_cb, (gpointer)MINICONTROL_VIEWER_EVENT_SHOW);
+}
+
+static void _minictrl_closed(void *data)
+{
+       DBG("");
+       g_hash_table_foreach(s_info.prov_table, _minictrl_send_view_event_cb, (gpointer)MINICONTROL_VIEWER_EVENT_HIDE);
+}
+
+QP_Module minictrl = {
+       .name = "minictrl",
+       .init = _init,
+       .fini = _fini,
+       .suspend = _suspend,
+       .resume = _resume,
+       .hib_enter = NULL,
+       .hib_leave = NULL,
+       .lang_changed = NULL,
+       .refresh = NULL,
+       .get_height = NULL,
+       .qp_opened = _minictrl_opened,
+       .qp_closed = _minictrl_closed,
+};
+
+/* End of a file */
diff --git a/daemon/minictrl/minictrl.h b/daemon/minictrl/minictrl.h
new file mode 100755 (executable)
index 0000000..a95fa6a
--- /dev/null
@@ -0,0 +1,24 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef _QP_MINICONTROL_DEF_
+#define _QP_MINICONTROL_DEF_
+
+extern void quickpanel_minictrl_rotation_report(int angle);
+
+#endif
diff --git a/daemon/modules.c b/daemon/modules.c
new file mode 100755 (executable)
index 0000000..0b43a61
--- /dev/null
@@ -0,0 +1,252 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+
+#include "common.h"
+#include "quickpanel-ui.h"
+#include "modules.h"
+
+/*******************************************************************
+ *
+ * MODULES
+ *
+ *****************************************************************/
+
+#ifdef QP_SETTING_ENABLE
+/* setting */
+extern QP_Module settings;
+extern QP_Module settings_view_featured;
+extern QP_Module settings_view_all;
+#endif /* QP_SETTING_ENABLE */
+
+#ifdef QP_MINICTRL_ENABLE
+extern QP_Module minictrl;
+#endif /* QP_MINICTRL_ENABLE */
+
+#ifdef QP_BRIGHTNESS_ENABLE
+/* brightness */
+extern QP_Module brightness_ctrl;
+#endif /* QP_BRIGHTNESS_ENABLE */
+
+#ifdef QP_ANIMATED_IMAGE_ENABLE
+extern QP_Module animated_image;
+#endif
+
+extern QP_Module vi_manager;
+extern QP_Module pager;
+
+/* notification */
+extern QP_Module noti;
+extern QP_Module activenoti;
+extern QP_Module qp_datetime_controller;
+extern QP_Module qp_datetime_view;
+
+/* voice control */
+#ifdef QP_VOICE_CONTROL_ENABLE
+extern QP_Module voice_control;
+#endif
+
+/* do not change the order of modules, result may be changed up to order */
+static QP_Module *modules[] = {
+       &vi_manager,
+       &pager,
+       &qp_datetime_controller,
+       &qp_datetime_view,
+#ifdef QP_SETTING_ENABLE
+       &settings,
+       &settings_view_featured,
+       &settings_view_all,
+#endif /* QP_SETTING_ENABLE */
+#ifdef QP_MINICTRL_ENABLE
+       &minictrl,
+#endif /* QP_MINICTRL_ENABLE */
+#ifdef QP_BRIGHTNESS_ENABLE
+       &brightness_ctrl,
+#endif /* QP_BRIGHTNESS_ENABLE */
+       &noti,
+       &activenoti,
+#ifdef QP_ANIMATED_IMAGE_ENABLE
+       &animated_image,
+#endif
+#ifdef QP_VOICE_CONTROL_ENABLE
+       &voice_control,
+#endif
+};
+
+HAPI int quickpanel_modules_init(void *data)
+{
+       int i;
+
+       retif(data == NULL, QP_FAIL, "Invalid parameter!");
+
+       for (i = 0; i < sizeof(modules) / sizeof(modules[0]); i++) {
+               if (modules[i]->init) {
+                       modules[i]->init(data);
+               }
+
+               if (modules[i]->init_job_cb) {
+                       ecore_job_add(modules[i]->init_job_cb, data);
+               }
+       }
+
+       return QP_OK;
+}
+
+HAPI int quickpanel_modules_fini(void *data)
+{
+       int i;
+
+       retif(data == NULL, QP_FAIL, "Invalid parameter!");
+
+       for (i = 0; i < sizeof(modules) / sizeof(modules[0]); i++) {
+               if (modules[i]->fini) {
+                       modules[i]->fini(data);
+               }
+       }
+
+       return QP_OK;
+}
+
+HAPI int quickpanel_modules_suspend(void *data)
+{
+       int i;
+
+       retif(data == NULL, QP_FAIL, "Invalid parameter!");
+
+       for (i = 0; i < sizeof(modules) / sizeof(modules[0]); i++) {
+               if (modules[i]->suspend) {
+                       modules[i]->suspend(data);
+               }
+       }
+
+       return QP_OK;
+}
+
+HAPI int quickpanel_modules_resume(void *data)
+{
+       int i;
+
+       retif(data == NULL, QP_FAIL, "Invalid parameter!");
+
+       for (i = 0; i < sizeof(modules) / sizeof(modules[0]); i++) {
+               if (modules[i]->resume) {
+                       modules[i]->resume(data);
+               }
+       }
+
+       return QP_OK;
+}
+
+HAPI int quickpanel_modules_hib_enter(void *data)
+{
+       int i;
+
+       retif(data == NULL, QP_FAIL, "Invalid parameter!");
+
+       for (i = 0; i < sizeof(modules) / sizeof(modules[0]); i++) {
+               if (modules[i]->hib_enter) {
+                       modules[i]->hib_enter(data);
+               }
+       }
+
+       return QP_OK;
+}
+
+HAPI int quickpanel_modules_hib_leave(void *data)
+{
+       int i;
+
+       retif(data == NULL, QP_FAIL, "Invalid parameter!");
+
+       for (i = 0; i < sizeof(modules) / sizeof(modules[0]); i++) {
+               if (modules[i]->hib_leave) {
+                       modules[i]->hib_leave(data);
+               }
+       }
+
+       return QP_OK;
+}
+
+/******************************************************************
+ *
+ * LANGUAGE
+ *
+ ****************************************************************/
+
+HAPI void quickpanel_modules_lang_change(void *data)
+{
+       int i;
+       retif(data == NULL, , "Invalid parameter!");
+
+       for (i = 0; i < sizeof(modules) / sizeof(modules[0]); i++) {
+               if (modules[i]->lang_changed) {
+                       modules[i]->lang_changed(data);
+               }
+       }
+}
+
+HAPI void quickpanel_modules_refresh(void *data)
+{
+       int i;
+       retif(data == NULL, , "Invalid parameter!");
+
+       for (i = 0; i < sizeof(modules) / sizeof(modules[0]); i++) {
+               if (modules[i]->refresh) {
+                       modules[i]->refresh(data);
+               }
+       }
+}
+
+/******************************************************************
+ *
+ * Quickpanel open/close Events
+ *
+ ****************************************************************/
+HAPI int quickpanel_modules_opened(void *data)
+{
+       int i;
+
+       retif(data == NULL, QP_FAIL, "Invalid parameter!");
+
+       for (i = 0; i < sizeof(modules) / sizeof(modules[0]); i++) {
+               if (modules[i]->qp_opened) {
+                       modules[i]->qp_opened(data);
+               }
+       }
+
+       return QP_OK;
+}
+
+HAPI int quickpanel_modules_closed(void *data)
+{
+       int i;
+
+       retif(data == NULL, QP_FAIL, "Invalid parameter!");
+
+       for (i = 0; i < sizeof(modules) / sizeof(modules[0]); i++) {
+               if (modules[i]->qp_closed) {
+                       modules[i]->qp_closed(data);
+               }
+       }
+
+       return QP_OK;
+}
diff --git a/daemon/modules.h b/daemon/modules.h
new file mode 100755 (executable)
index 0000000..1ce0180
--- /dev/null
@@ -0,0 +1,33 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __QP_MODULES_H__
+#define __QP_MODULES_H__
+
+extern int quickpanel_modules_init(void *data);
+extern int quickpanel_modules_fini(void *data);
+extern int quickpanel_modules_suspend(void *data);
+extern int quickpanel_modules_resume(void *data);
+extern int quickpanel_modules_hib_enter(void *data);
+extern int quickpanel_modules_hib_leave(void *data);
+extern void quickpanel_modules_lang_change(void *data);
+extern void quickpanel_modules_refresh(void *data);
+extern int quickpanel_modules_opened(void *data);
+extern int quickpanel_modules_closed(void *data);
+
+#endif /* __QP_MODULES_H__ */
diff --git a/daemon/notifications/activenoti.c b/daemon/notifications/activenoti.c
new file mode 100755 (executable)
index 0000000..f3674c2
--- /dev/null
@@ -0,0 +1,1595 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#include <Elementary.h>
+#include <glib.h>
+
+#include <vconf.h>
+#include <app_control.h>
+#include <notification.h>
+#include <feedback.h>
+#include <system_settings.h>
+#include <notification_internal.h>
+#include <notification_setting_internal.h>
+#include <notification_text_domain.h>
+#include <player.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "quickpanel-ui.h"
+#include "common_uic.h"
+#include "common.h"
+#include "media.h"
+#include "noti_node.h"
+#include "noti.h"
+#include "noti_win.h"
+#include "noti_util.h"
+#include "animated_icon.h"
+
+#ifdef QP_EMERGENCY_MODE_ENABLE
+#include "emergency_mode.h"
+#endif
+
+#define QP_ACTIVENOTI_DURATION 3
+#define QP_ACTIVENOTI_DETAIL_DURATION 6
+
+#define ACTIVENOTI_MSG_LEN 100
+#define DEFAULT_ICON RESDIR"/quickpanel_icon_default.png"
+
+#define DELAY_TIMER_VALUE 0.480
+#define DEL_TIMER_VALUE        8.0
+#define SHOW_MIN_TIMER_VALUE   1.0
+#define RELEASE_TIME 8.0
+
+#define NOTI_START_Y ELM_SCALE_SIZE(36)
+
+static struct info {
+       Evas_Object *activenoti;
+       Evas_Object *layout;
+       Evas_Object *btnbox;
+       Evas_Object *gesture;
+       Ecore_Timer *delay_timer;
+       Ecore_Timer *close_timer;
+       Ecore_Timer *show_min_timer;
+
+       Eina_List *auto_remove_list;
+       Eina_List *non_auto_remove_list;
+       notification_h current_noti;
+
+} s_info = {
+       .activenoti = NULL,
+       .layout = NULL,
+       .btnbox = NULL,
+       .gesture = NULL,
+       .delay_timer = NULL,
+       .close_timer = NULL,
+       .show_min_timer = NULL,
+       .auto_remove_list = NULL,
+       .non_auto_remove_list = NULL,
+       .current_noti = NULL,
+};
+
+struct noti_info {
+       notification_h noti;
+       Ecore_Timer *timer;
+};
+
+static inline char *_get_text(notification_h noti, notification_text_type_e text_type);
+
+static int _activenoti_init(void *data);
+static int _activenoti_fini(void *data);
+static int _activenoti_enter_hib(void *data);
+static int _activenoti_leave_hib(void *data);
+static void _activenoti_reflesh(void *data);
+static void _activenoti_qp_opened(void *data);
+
+static void _activenoti_update_activenoti();
+static void _activenoti_create_activenoti();
+static void _activenoti_win_rotated(void *data, int need_hide);
+
+static void _activenoti_destroy_activenoti();
+static void _media_feedback_sound(notification_h noti);
+static notification_h _activenoti_get_in_list();
+static bool _activenoti_remove_in_list(notification_h noti);
+static void _activenoti_delete_current_noti(void);
+static bool _activenoti_has_pending_noti(void);
+static void _activenoti_hide(void *data, int delay);
+
+QP_Module activenoti = {
+       .name = "activenoti",
+       .init = _activenoti_init,
+       .fini = _activenoti_fini,
+       .hib_enter = _activenoti_enter_hib,
+       .hib_leave = _activenoti_leave_hib,
+       .lang_changed = NULL,
+       .qp_opened = _activenoti_qp_opened,
+       .qp_closed = NULL,
+       .refresh = _activenoti_reflesh
+};
+
+static void _app_control_del_cb(void *data, Evas *e, Evas_Object *obj, void *event_info)
+{
+       if (data) {
+               DBG("_app_control_del_cb %p", data);
+               app_control_destroy(data);
+       }
+}
+
+static inline int _is_text_exist(const char *text)
+{
+       if (text != NULL) {
+               if (strlen(text) > 0) {
+                       return 1;
+               }
+       }
+       return 0;
+}
+
+static int _is_sound_playable(void)
+{
+       int status = 0, ret = 0;
+
+       ret = vconf_get_int(VCONFKEY_CAMERA_STATE, &status);
+       if (ret == VCONF_OK && status == VCONFKEY_CAMERA_STATE_RECORDING) {
+               ERR("camcorder is working, don't play notification sound %d %d", ret, status);
+               return 0;
+       }
+
+       return 1;
+}
+
+static int _is_security_lockscreen_launched(void)
+{
+       int ret = 0;
+       int is_idle_lock = 0;
+
+       ret = vconf_get_int(VCONFKEY_IDLE_LOCK_STATE, &is_idle_lock);
+       retif(ret != 0, 0,"failed to get VCONFKEY_IDLE_LOCK_STATE %d %d", ret, is_idle_lock);
+
+       if (is_idle_lock  == VCONFKEY_IDLE_LOCK ) {
+               DBG("Lock screen is launched");
+               return 1; //don't show on lock screen
+       }
+
+       return 0;
+}
+
+static Eina_Bool _activenoti_hide_timer_cb(void *data)
+{
+       DBG("");
+
+       s_info.delay_timer = NULL;
+
+       _activenoti_hide(data, 0);
+       return ECORE_CALLBACK_CANCEL;
+}
+
+static void _activenoti_hide(void *data, int delay)
+{
+       DBG("delay : %d", delay);
+       if (delay == 1) {
+               if (s_info.delay_timer == NULL) {
+                       s_info.delay_timer = ecore_timer_add(DELAY_TIMER_VALUE, _activenoti_hide_timer_cb, NULL);
+                       if (!s_info.delay_timer) {
+                               ERR("Failed to create a new timer for hide activenoti");
+                       }
+               }
+       } else {
+               _activenoti_delete_current_noti();
+
+               if (s_info.delay_timer != NULL) {
+                       ecore_timer_del(s_info.delay_timer);
+                       s_info.delay_timer = NULL;
+               }
+
+               if (s_info.close_timer != NULL) {
+                       ecore_timer_del(s_info.close_timer);
+                       s_info.close_timer = NULL;
+               }
+
+               if (s_info.activenoti) {
+                       if (_activenoti_has_pending_noti()) {
+                               _activenoti_update_activenoti();
+                       } else {
+                               DBG("pending noti is null. called evas_object_hide");
+                               evas_object_hide(s_info.activenoti);
+                       }
+               }
+       }
+       DBG("");
+}
+
+static Evas_Event_Flags __flick_end_cb(void *data, void *event_info)
+{
+       Elm_Gesture_Line_Info *line_info = (Elm_Gesture_Line_Info *)event_info;
+
+       DBG("line_info->momentum.my : %d", line_info->momentum.my);
+
+       /* Flick Up */
+       if (line_info->momentum.my < 0) {
+               DBG("HIDE ACTIVE NOTI");
+               if (_activenoti_has_pending_noti() == false) {
+                       _activenoti_hide(NULL, 0);
+               } else {
+                       _activenoti_delete_current_noti();
+                       _activenoti_update_activenoti();
+               }
+       } else {
+               DBG("HOLD ACTIVE NOTI");
+       }
+       return EVAS_EVENT_FLAG_ON_HOLD;
+}
+
+static Evas_Object *_gesture_create(Evas_Object *layout)
+{
+       Evas_Object *gesture_layer = NULL;
+
+       gesture_layer = elm_gesture_layer_add(layout);
+       retif(!gesture_layer, NULL,);
+
+       elm_gesture_layer_attach(gesture_layer, layout);
+       evas_object_show(gesture_layer);
+
+       elm_gesture_layer_cb_set(gesture_layer, ELM_GESTURE_N_FLICKS, ELM_GESTURE_STATE_END, __flick_end_cb, NULL);
+
+       return gesture_layer;
+}
+
+static int _check_sound_off(notification_h noti)
+{
+       notification_system_setting_h system_setting = NULL;
+       notification_setting_h setting = NULL;
+       char *pkgname = NULL;
+       bool do_not_disturb = false;
+       bool do_not_disturb_except = false;
+       int err = NOTIFICATION_ERROR_NONE;
+       int ret = 0;
+
+       retif(noti == NULL, 0, "Invalid parameter!");
+
+       err = notification_system_setting_load_system_setting(&system_setting);
+       if (err != NOTIFICATION_ERROR_NONE || system_setting == NULL) {
+               DBG("notification_system_setting_load_system_setting failed [%d]\n", err);
+               goto out;
+       }
+
+       err = notification_system_setting_get_do_not_disturb(system_setting, &do_not_disturb);
+       if (err != NOTIFICATION_ERROR_NONE) {
+               DBG("notification_system_setting_get_do_not_disturb failed [%d]", err);
+               goto out;
+       }
+
+       DBG("do_not_disturb [%d]\n", do_not_disturb);
+
+       if (do_not_disturb) {
+               err = notification_get_pkgname(noti, &pkgname);
+               if (err != NOTIFICATION_ERROR_NONE || pkgname == NULL) {
+                       DBG("notification_get_pkgname failed [%d]", err);
+                       goto out;
+               }
+
+               err = notification_setting_get_setting_by_package_name(pkgname, &setting);
+               if (err != NOTIFICATION_ERROR_NONE || setting == NULL) {
+                       DBG("notification_setting_get_setting_by_package_name failed [%d]", err);
+                       goto out;
+               }
+
+               notification_setting_get_do_not_disturb_except(setting, &do_not_disturb_except);
+               if (err != NOTIFICATION_ERROR_NONE) {
+                       DBG("notification_setting_get_do_not_disturb_except failed [%d]", err);
+                       goto out;
+               }
+
+               if (do_not_disturb_except) {
+                       ret = 0;
+               } else {
+                       ret = 1;
+               }
+       }
+
+out:
+       if (system_setting) {
+               notification_system_setting_free_system_setting(system_setting);
+       }
+
+       if (setting) {
+               notification_setting_free_notification(setting);
+       }
+
+       return ret;
+}
+
+static void _gesture_destroy(void)
+{
+       if (s_info.gesture) {
+               evas_object_del(s_info.gesture);
+               s_info.gesture = NULL;
+       } else {
+               ERR("s_info.gesture is NULL");
+       }
+}
+
+static inline void _activenoti_only_noti_del(notification_h noti)
+{
+       retif(noti == NULL, ,"Invalid parameter!");
+       int applist = NOTIFICATION_DISPLAY_APP_ALL;
+
+       notification_get_display_applist(noti, &applist);
+       if (applist & NOTIFICATION_DISPLAY_APP_ACTIVE) {
+               if (!(applist & NOTIFICATION_DISPLAY_APP_NOTIFICATION_TRAY)) {
+                       char *pkgname = NULL;
+                       int priv_id = 0;
+
+                       notification_get_pkgname(noti, &pkgname);
+                       notification_get_id(noti, NULL, &priv_id);
+                       notification_delete_by_priv_id(pkgname, NOTIFICATION_TYPE_NONE, priv_id);
+               }
+       }
+}
+
+static Eina_Bool _activenoti_close_timer_cb(void *data)
+{
+       DBG("%d", _activenoti_has_pending_noti());
+
+       s_info.close_timer = NULL;
+
+       _activenoti_hide(data, 0);
+
+       return ECORE_CALLBACK_CANCEL;
+}
+
+static void _activenoti_delete_current_noti(void)
+{
+       if (!s_info.current_noti) {
+               DBG("There is no displaying notification");
+               return;
+       }
+
+       DBG("");
+       notification_free(s_info.current_noti);
+       s_info.current_noti = NULL;
+}
+
+static Evas_Object *_activenoti_create_badge(Evas_Object *parent, notification_h noti)
+{
+       DBG("");
+       retif(noti == NULL || parent == NULL, NULL, "Invalid parameter!");
+
+       char *icon_path = NULL;
+       Evas_Object *icon = NULL;
+       int ret = NOTIFICATION_ERROR_NONE;
+
+       ret = notification_get_image(noti, NOTIFICATION_IMAGE_TYPE_ICON_SUB, &icon_path);
+       if (ret != NOTIFICATION_ERROR_NONE || icon_path == NULL) {
+               DBG("notification_get_image failed [%d]", ret);;
+               return NULL;
+       }
+
+       DBG("NOTIFICATION_IMAGE_TYPE_ICON_SUB :  %s", icon_path);
+
+       icon = elm_image_add(parent);
+       if (icon == NULL) {
+               //              free(icon_path);
+               DBG("icon error");
+               return NULL;
+       }
+
+       elm_image_resizable_set(icon, EINA_FALSE, EINA_TRUE);
+
+       ret = elm_image_file_set(icon, icon_path, NULL);
+       //free(icon_path);
+
+       if (ret == EINA_FALSE) {
+               evas_object_del(icon);
+               return NULL;
+       }
+
+       return icon;
+}
+
+static void _image_press_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
+{
+       DBG("");
+       app_control_h app_control = data;
+
+       if (app_control) {
+               int ret = APP_CONTROL_ERROR_NONE;
+               ret = app_control_send_launch_request(app_control, NULL, NULL);
+               DBG("app_control_send_launch_request return [%d]", ret);
+       }
+
+       _activenoti_hide(NULL, 1);
+}
+
+static Eina_Bool _delete_timer_cb(void *data)
+{
+       DBG("");
+       struct noti_info *noti = data;
+
+       s_info.auto_remove_list = eina_list_remove(s_info.auto_remove_list, noti);
+       notification_free(noti->noti);
+       free(noti);
+
+       return ECORE_CALLBACK_CANCEL;
+}
+
+static int _compare_noti_time(notification_h noti1, notification_h noti2)
+{
+       time_t noti_time1 = 0;
+       time_t noti_time2 = 0;
+       int ret;
+
+       ret = notification_get_time(noti1, &noti_time1);
+       if (ret != NOTIFICATION_ERROR_NONE || noti_time1 == 0)  {
+               notification_get_insert_time(noti1, &noti_time1);
+       }
+
+       ret = notification_get_time(noti2, &noti_time2);
+       if (ret != NOTIFICATION_ERROR_NONE || noti_time2 == 0)  {
+               notification_get_insert_time(noti2, &noti_time2);
+       }
+
+       DBG("not_time1 : %d noti_time2 : %d", noti_time1, noti_time2);
+
+       return (int)(noti_time1 - noti_time2);
+}
+
+static int _compare_time_cb(const void *data1, const void *data2)
+{
+       struct noti_info *info1 = (struct noti_info *)data1;
+       struct noti_info *info2 = (struct noti_info *)data2;
+
+       return _compare_noti_time(info1->noti, info2->noti);
+}
+
+static void _activenoti_remove_list(void)
+{
+       struct noti_info *info;
+       char *tmp;
+
+       EINA_LIST_FREE(s_info.auto_remove_list, info) {
+               /**
+                * For debugging
+                */
+               tmp = _get_text(info->noti, NOTIFICATION_TEXT_TYPE_TITLE);
+               DBG("auto remove %s", tmp);
+               free(tmp);
+
+               free(info->noti);
+               free(info->timer);
+       }
+
+       EINA_LIST_FREE(s_info.non_auto_remove_list, info) {
+               /**
+                * For debugging
+                */
+               tmp = _get_text(info->noti, NOTIFICATION_TEXT_TYPE_TITLE);
+               DBG("nont auto remove %s", tmp);
+               free(tmp);
+
+               free(info->noti);
+       }
+}
+
+static bool _activenoti_add_in_list(notification_h noti)
+{
+       DBG("");
+       bool auto_remove;
+       struct noti_info *info;
+       int     ret;
+       time_t noti_time = 0;
+
+       ret = notification_get_auto_remove( noti, &auto_remove);
+       if (ret != NOTIFICATION_ERROR_NONE) {
+               DBG("notification_get_auto_remove return [%d]", ret);
+               return false;
+       }
+
+       info = malloc(sizeof(*info));
+       if (!info) {
+               DBG("malloc error, can't make noti_info");
+               return false;
+       }
+
+       ret = notification_clone(noti, &info->noti);
+       if (ret != NOTIFICATION_ERROR_NONE || !info->noti) {
+               free(info);
+               ERR("failed to create a cloned notification");
+               return false;
+       }
+
+       if (auto_remove == true) {
+               ret = notification_get_time(info->noti, &noti_time);
+               if (ret!=NOTIFICATION_ERROR_NONE || noti_time == 0) {
+                       ret = notification_get_insert_time(info->noti, &noti_time);
+                       if (ret != NOTIFICATION_ERROR_NONE || noti_time == 0) {
+                               DBG("notification_get_insert_time failed. time is 0 ret %d", ret);
+                       }
+               }
+
+               noti_time -= time(NULL);
+
+               if (noti_time > 8.0f) {
+                       DBG("remove noti");
+                       info->timer = NULL;
+                       _delete_timer_cb(info);
+               } else {
+                       info->timer = ecore_timer_add(8.0f - noti_time, _delete_timer_cb, info);
+                       DBG("timer add");
+                       if(!info->timer) {
+                               DBG("ecore_timer_add failed");
+                       }
+                       /**
+                        * @todo
+                        * Revise this.
+                        * Do we need to replace this with eina_list_prepend?
+                        */
+                       s_info.auto_remove_list = eina_list_sorted_insert(s_info.auto_remove_list, _compare_time_cb, info);
+               }
+       } else {
+               info->timer = NULL;
+               s_info.non_auto_remove_list = eina_list_sorted_insert(s_info.non_auto_remove_list, _compare_time_cb, info);
+       }
+
+       return 1;
+}
+
+static bool _activenoti_has_pending_noti(void)
+{
+
+       return s_info.non_auto_remove_list || s_info.auto_remove_list;
+}
+
+static bool _activenoti_remove_in_list(notification_h noti)
+{
+       DBG("");
+
+       bool auto_remove;
+       int ret;
+       Eina_List *l;
+       Eina_List *n;
+       struct noti_info *info;
+
+       ret = notification_get_auto_remove(noti, &auto_remove);
+       if (ret != NOTIFICATION_ERROR_NONE) {
+               DBG("notification_get_auto_remove return [%d]", ret);
+               return false;
+       }
+
+       if (auto_remove) {
+               DBG("remove in auto remove list");
+               EINA_LIST_FOREACH_SAFE(s_info.auto_remove_list, l, n, info) {
+                       if (info->noti != noti) {
+                               int priv_id_from_list;
+                               int priv_id_from_arg;
+
+                               notification_get_id(info->noti, NULL, &priv_id_from_list);
+                               notification_get_id(noti, NULL, &priv_id_from_arg);
+
+                               if (priv_id_from_list != priv_id_from_arg) {
+                                       continue;
+                               }
+                       }
+                       s_info.auto_remove_list = eina_list_remove(s_info.auto_remove_list, info);
+                       ecore_timer_del(info->timer);
+                       notification_free(info->noti);
+                       free(info);
+                       break;
+               }
+       } else {
+               DBG("remove in non auto remove list");
+               EINA_LIST_FOREACH_SAFE(s_info.non_auto_remove_list, l, n, info) {
+                       if (info->noti != noti) {
+                               int priv_id_from_list;
+                               int priv_id_from_arg;
+
+                               notification_get_id(info->noti, NULL, &priv_id_from_list);
+                               notification_get_id(noti, NULL, &priv_id_from_arg);
+
+                               if (priv_id_from_list != priv_id_from_arg) {
+                                       continue;
+                               }
+                       }
+                       s_info.non_auto_remove_list = eina_list_remove(s_info.non_auto_remove_list, info);
+                       notification_free(info->noti);
+                       free(info);
+                       break;
+               }
+       }
+       return 1;
+}
+
+static notification_h _activenoti_get_in_list(notification_h cur_noti)
+{
+       DBG("");
+       notification_h noti = NULL;
+       struct noti_info *info;
+       bool auto_remove = true;
+       int ret;
+
+       if (cur_noti != NULL) {
+               ret = notification_get_auto_remove(cur_noti, &auto_remove);
+               if (ret != NOTIFICATION_ERROR_NONE) {
+                       DBG("notification_get_auto_remove return [%d]", ret);
+                       return NULL;
+               }
+       }
+
+       info = eina_list_nth(s_info.non_auto_remove_list, 0);
+       if (info) {
+               if (!auto_remove) {
+                       ret = _compare_noti_time(cur_noti, info->noti);
+
+                       if (ret > 0) {
+                               return NULL;
+                       }
+               }
+               s_info.non_auto_remove_list = eina_list_remove(s_info.non_auto_remove_list, info);
+               // .....
+               noti = info->noti;
+               free(info);
+               return noti;
+       }
+
+       if (auto_remove == false) {
+               return noti;
+       }
+
+       info = eina_list_nth(s_info.auto_remove_list, 0);
+       if (info) {
+               s_info.auto_remove_list = eina_list_remove(s_info.auto_remove_list, info);
+               // .....
+               noti = info->noti;
+               ecore_timer_del(info->timer);
+               free(info);
+               return noti;
+       }
+
+       return noti;
+}
+
+static Evas_Object *_activenoti_create_icon(Evas_Object *parent, notification_h noti)
+{
+       DBG("");
+       retif(noti == NULL || parent == NULL , NULL, "Invalid parameter!");
+
+       char *icon_path;
+       char *tmp;
+       Evas_Object *icon;
+       int ret;
+       app_control_h app_control;
+
+       retif(noti == NULL || parent == NULL, NULL, "Invalid parameter!");
+
+       tmp = NULL;
+       ret = notification_get_image(noti, NOTIFICATION_IMAGE_TYPE_ICON, &tmp);
+       if (ret == NOTIFICATION_ERROR_NONE && tmp != NULL) {
+               icon_path = strdup(tmp);
+               if (!icon_path) {
+                       ERR("strdup: %s", tmp);
+               }
+
+               app_control = NULL;
+               ret = notification_get_event_handler(noti, NOTIFICATION_EVENT_TYPE_CLICK_ON_ICON, &app_control);
+               if (ret != NOTIFICATION_ERROR_NONE) {
+                       ERR("Failed to get handler");
+               }
+
+               DBG("icon_path :  %s app_control = %p", icon_path, app_control);
+       } else {
+               tmp = NULL;
+               ret = notification_get_image(noti, NOTIFICATION_IMAGE_TYPE_THUMBNAIL, &tmp);
+               if (ret == NOTIFICATION_ERROR_NONE && tmp != NULL) {
+                       icon_path = strdup(tmp);
+                       if (!icon_path) {
+                               ERR("strdup: %s", tmp);
+                       }
+
+                       app_control = NULL;
+                       ret = notification_get_event_handler(noti, NOTIFICATION_EVENT_TYPE_CLICK_ON_THUMBNAIL, &app_control);
+                       if (ret != NOTIFICATION_ERROR_NONE) {
+                               ERR("Failed to get handler");
+                       }
+
+                       DBG("thumb_path :  %s app_control = %p", icon_path, app_control);
+               } else  {
+                       char *pkgname;
+
+                       icon_path = NULL;
+                       pkgname = NULL;
+                       ret = notification_get_pkgname(noti, &pkgname);
+                       if (ret == NOTIFICATION_ERROR_NONE && pkgname != NULL) {
+                               icon_path = quickpanel_common_ui_get_pkginfo_icon(pkgname);
+                               DBG("default_pkgicon_path :  %s", icon_path);
+                       }
+
+                       if (!icon_path) {
+                               icon_path = strdup(DEFAULT_ICON);
+                               DBG("default_path :  %s", icon_path);
+                       }
+
+                       app_control = NULL;
+               }
+       }
+
+       icon = elm_image_add(parent);
+       if (!icon) {
+               ERR("Failed to create an image object");
+               free(icon_path);
+               if (app_control) {
+                       app_control_destroy(app_control);
+               }
+               return NULL;
+       }
+
+       ret = elm_image_file_set(icon, icon_path, NULL);
+       free(icon_path);
+       if (ret == EINA_FALSE) {
+               evas_object_del(icon);
+               if (app_control) {
+                       app_control_destroy(app_control);
+               }
+               return NULL;
+       }
+       elm_image_resizable_set(icon, EINA_FALSE, EINA_TRUE);
+
+       elm_object_signal_callback_add(icon, "image_press" , "", _image_press_cb, app_control);
+       evas_object_event_callback_add(icon, EVAS_CALLBACK_DEL, _app_control_del_cb, app_control);
+
+       return icon;
+}
+
+static inline char *_get_text(notification_h noti, notification_text_type_e text_type)
+{
+       time_t time = 0;
+       char *text = NULL;
+       char buf[ACTIVENOTI_MSG_LEN] = {0,};
+
+       if (notification_get_time_from_text(noti, text_type, &time) == NOTIFICATION_ERROR_NONE) {
+               if ((int)time > 0) {
+                       quickpanel_noti_util_get_time(time, buf, sizeof(buf));
+                       text = buf;
+               }
+       } else {
+               notification_get_text(noti, text_type, &text);
+       }
+
+       DBG("text : %s", text);
+
+       if (text != NULL) {
+               return elm_entry_utf8_to_markup(text);
+       }
+
+       return NULL;
+}
+
+static inline void _strbuf_add(Eina_Strbuf *str_buf, char *text, const char *delimiter)
+{
+       if (text != NULL) {
+               if (strlen(text) > 0) {
+                       if (delimiter != NULL) {
+                               eina_strbuf_append(str_buf, delimiter);
+                       }
+                       eina_strbuf_append(str_buf, text);
+               }
+       }
+}
+
+static inline void _check_and_add_to_buffer(Eina_Strbuf *str_buf, char *text, int is_check_phonenumber)
+{
+       char buf_number[QP_UTIL_PHONE_NUMBER_MAX_LEN * 2] = { 0, };
+
+       if (text != NULL) {
+               if (strlen(text) > 0) {
+                       if (quickpanel_common_util_is_phone_number(text) && is_check_phonenumber) {
+                               quickpanel_common_util_phone_number_tts_make(buf_number, text,
+                                               (QP_UTIL_PHONE_NUMBER_MAX_LEN * 2) - 1);
+                               eina_strbuf_append(str_buf, buf_number);
+                       } else {
+                               eina_strbuf_append(str_buf, text);
+                       }
+                       eina_strbuf_append_char(str_buf, '\n');
+               }
+       }
+}
+
+static void _activenoti_set_text(notification_h noti, int is_screenreader)
+{
+       char *domain = NULL;
+       char *dir = NULL;
+       char *tmp;
+       int ret;
+
+       if (!noti) {
+               ERR("Invalid parameter");
+               return;
+       }
+
+       ret = notification_get_text_domain(noti, &domain, &dir);
+       if (ret == NOTIFICATION_ERROR_NONE && domain != NULL && dir != NULL) {
+               bindtextdomain(domain, dir);
+       }
+
+       tmp = _get_text(noti, NOTIFICATION_TEXT_TYPE_INFO_1);
+       if (tmp != NULL) {
+               elm_object_part_text_set(s_info.layout, "subtitle_text", tmp);
+               free(tmp);
+               elm_object_signal_emit(s_info.layout, "sub_show", "subtitle_text");
+       } else {
+               elm_object_signal_emit(s_info.layout, "sub_hide", "subtitle_text");
+       }
+
+       tmp = _get_text(noti, NOTIFICATION_TEXT_TYPE_TITLE);
+       if (tmp != NULL) {
+               elm_object_part_text_set(s_info.layout, "title_text", tmp);
+               free(tmp);
+       } else {
+               elm_object_part_text_set(s_info.layout, "title_text", "");
+       }
+
+       tmp = _get_text(noti, NOTIFICATION_TEXT_TYPE_CONTENT);
+       if (tmp != NULL) {
+               elm_object_part_text_set(s_info.layout, "content_text", tmp);
+               free(tmp);
+       } else {
+               elm_object_part_text_set(s_info.layout, "content_text", "");
+       }
+}
+
+static void _handle_press_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
+{
+       DBG("");
+       _activenoti_hide(data, 0);
+}
+
+static void _noti_press_cb(void *data, Evas_Object *obj,       const char *emission, const char *source)
+{
+       DBG("");
+       int ret = APP_CONTROL_ERROR_NONE;
+       char *caller_pkgname = NULL;
+       bundle *responding_service_handle = NULL;
+       bundle *single_service_handle = NULL;
+       bundle *multi_service_handle = NULL;
+       int flags = 0, group_id = 0, priv_id = 0, count = 0, flag_launch = 0;
+       notification_type_e type = NOTIFICATION_TYPE_NONE;
+       notification_h noti = NULL;
+
+       retif(s_info.activenoti == NULL, , "Invalid parameter!");
+       retif(s_info.current_noti == NULL, , "Invalid parameter!");
+
+       noti = s_info.current_noti;
+       notification_get_pkgname(noti, &caller_pkgname);
+       notification_get_id(noti, &group_id, &priv_id);
+       notification_get_property(noti, &flags);
+       notification_get_type(noti, &type);
+
+       if (flags & NOTIFICATION_PROP_DISABLE_APP_LAUNCH) {
+               flag_launch = 0;
+       } else {
+               flag_launch = 1;
+       }
+
+       ret = notification_get_execute_option(noti, NOTIFICATION_EXECUTE_TYPE_RESPONDING,       NULL, &responding_service_handle);
+       if (ret != NOTIFICATION_ERROR_NONE || responding_service_handle == NULL) {
+               DBG("NOTIFICATION_EXECUTE_TYPE_RESPONDING failed [%d]", ret);
+       }
+
+       ret = notification_get_execute_option(noti, NOTIFICATION_EXECUTE_TYPE_SINGLE_LAUNCH, NULL, &single_service_handle);
+       if (ret != NOTIFICATION_ERROR_NONE || single_service_handle == NULL) {
+               DBG("NOTIFICATION_EXECUTE_TYPE_SINGLE_LAUNCH failed [%d]", ret);
+       }
+
+       ret = notification_get_execute_option(noti, NOTIFICATION_EXECUTE_TYPE_MULTI_LAUNCH, NULL, &multi_service_handle);
+       if (ret != NOTIFICATION_ERROR_NONE || multi_service_handle == NULL) {
+               DBG("NOTIFICATION_EXECUTE_TYPE_MULTI_LAUNCH failed [%d]", ret);
+       }
+
+       if (responding_service_handle != NULL) {
+               DBG("responding_service_handle : %s", responding_service_handle);
+               ret = quickpanel_uic_launch_app(NULL, responding_service_handle);
+       } else if (flag_launch == 1) {
+               char *text_count = NULL;
+               notification_get_text(noti, NOTIFICATION_TEXT_TYPE_EVENT_COUNT, &text_count);
+
+               if (text_count != NULL) {
+                       count = atoi(text_count);
+               } else {
+                       count = 1;
+               }
+
+               if (single_service_handle != NULL && multi_service_handle == NULL) {
+                       ret = quickpanel_uic_launch_app(NULL, single_service_handle);
+               } else if (single_service_handle == NULL && multi_service_handle != NULL) {
+                       ret = quickpanel_uic_launch_app(NULL, multi_service_handle);
+               } else if (single_service_handle != NULL && multi_service_handle != NULL) {
+                       if (count <= 1) {
+                               ret = quickpanel_uic_launch_app(NULL, single_service_handle);
+                       } else {
+                               ret = quickpanel_uic_launch_app(NULL, multi_service_handle);
+                       }
+               } else { //single_service_handle == NULL && multi_service_handle == NULL
+                       DBG("there is no execution option in notification");
+               }
+               quickpanel_uic_launch_app_inform_result(caller_pkgname, ret);
+       }
+
+       _activenoti_hide(data , 1);
+
+}
+
+static void _button_press_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
+{
+       app_control_h app_control = data;
+       int ret = APP_CONTROL_ERROR_NONE;
+
+       ret = app_control_send_launch_request(app_control, NULL, NULL);
+       DBG("app_control_send_launch_request return [%s]", ret);
+
+       _activenoti_hide(NULL, 1);
+}
+
+static Evas_Object *_get_btn_img(Evas_Object *parent, notification_h noti, int btn_num)
+{
+       retif(noti == NULL || parent == NULL, NULL, "Invalid parameter!");
+
+       char *btn_path = NULL;
+       Evas_Object *btn_img = NULL;
+       int ret;
+
+       ret = notification_get_image(noti, btn_num + NOTIFICATION_IMAGE_TYPE_BUTTON_1, &btn_path);
+       if (ret != NOTIFICATION_ERROR_NONE || btn_path == NULL) {
+               DBG("notification_get_image return [%d]", ret);
+               return NULL;
+       }
+
+       btn_img = elm_image_add(parent);
+       if (!btn_img) {
+               //free(btn_path);
+               return NULL;
+       }
+
+       evas_object_size_hint_weight_set(btn_img, EVAS_HINT_EXPAND,     EVAS_HINT_EXPAND);
+       evas_object_size_hint_align_set(btn_img, EVAS_HINT_FILL, EVAS_HINT_FILL);
+       elm_image_resizable_set(btn_img, EINA_TRUE, EINA_TRUE);
+
+       ret = elm_image_file_set(btn_img, btn_path, NULL);
+       //free(btn_path);
+       if (ret == EINA_FALSE) {
+               evas_object_del(btn_img);
+               return NULL;
+       }
+
+       return btn_img;
+}
+
+static Evas_Object *_get_bg_img(Evas_Object *parent, notification_h noti)
+{
+       char *bg_path = NULL;
+       Evas_Object *bg_img = NULL;
+       int ret;
+
+       if (!parent || !noti) {
+               ERR("Invalid parameters %p %p", parent, noti);
+               return NULL;
+       }
+
+       ret = notification_get_image(noti, NOTIFICATION_IMAGE_TYPE_BACKGROUND, &bg_path);
+       if (ret != NOTIFICATION_ERROR_NONE || bg_path == NULL) {
+               DBG("bg_path is null ret = %d", ret);
+               return NULL;
+       }
+
+       bg_img = elm_image_add(parent);
+       if (!bg_img) {
+               return NULL;
+       }
+
+       evas_object_size_hint_weight_set(bg_img, EVAS_HINT_EXPAND,      EVAS_HINT_EXPAND);
+       evas_object_size_hint_align_set(bg_img, EVAS_HINT_FILL, EVAS_HINT_FILL);
+       elm_image_resizable_set(bg_img, EINA_TRUE, EINA_TRUE);
+
+       ret = elm_image_file_set(bg_img, bg_path, NULL);
+       if (ret == EINA_FALSE) {
+               evas_object_del(bg_img);
+               return NULL;
+       }
+
+       return bg_img;
+}
+
+static int _activenoti_create_button(Evas_Object *obj, notification_h noti)
+{
+       int btn_cnt;
+       int ret;
+       app_control_h app_control;
+
+       if (!obj || !noti) {
+               ERR("Invalid parameters");
+               return 0;
+       }
+
+       if (s_info.btnbox) { //if exist, delete and create
+               evas_object_del(s_info.btnbox);
+               s_info.btnbox = NULL;
+       }
+
+       Evas_Object *box;
+       box = elm_box_add(obj);
+
+       if(box == NULL) {
+               ERR("box is null");
+               return 0;
+       }
+
+       evas_object_size_hint_weight_set(box, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       evas_object_size_hint_align_set(box, EVAS_HINT_FILL, EVAS_HINT_FILL);
+       elm_box_horizontal_set(box, EINA_TRUE);
+       evas_object_show(box);
+       s_info.btnbox = box;
+
+       for (btn_cnt = 0; btn_cnt < 3; btn_cnt++) {
+               app_control = NULL;
+               ret = notification_get_event_handler(noti, btn_cnt + NOTIFICATION_EVENT_TYPE_CLICK_ON_BUTTON_1, &app_control);
+               DBG("appcontrol %p", app_control);
+               if(ret != NOTIFICATION_ERROR_NONE || app_control == NULL) {
+                       INFO("no more button, button count is %d", btn_cnt);
+                       INFO("ret is %d", ret);
+
+                       /**
+                        * @note
+                        * In this case,
+                        * The app_control is not used and no one cares it.
+                        * So we have to release it from here if it is allocated.
+                        */
+                       if (app_control) {
+                               app_control_destroy(app_control);
+                       }
+
+                       if (btn_cnt == 0) { // noti doesn't have button
+                               evas_object_del(s_info.btnbox);
+                               s_info.btnbox = NULL;
+                               return 0;
+                       }
+               } else {
+                       Evas_Object *bt_layout;
+                       char *btn_text;
+                       Evas_Object *image;
+
+                       bt_layout = elm_layout_add(s_info.btnbox);
+                       if(bt_layout == NULL) {
+                               ERR("bt_layout is null");
+                               evas_object_del(s_info.btnbox);
+                               app_control_destroy(app_control);
+                               s_info.btnbox = NULL;
+                               return 0;
+                       }
+
+                       elm_layout_file_set(bt_layout, ACTIVENOTI_EDJ, "button_layout");
+                       evas_object_size_hint_weight_set (bt_layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+                       evas_object_size_hint_align_set(bt_layout, EVAS_HINT_FILL, EVAS_HINT_FILL);
+
+                       image = _get_btn_img(bt_layout, noti, btn_cnt);
+                       if (image != NULL) {
+                               elm_object_part_content_set(bt_layout, "content.button.image", image);
+                       }
+
+                       btn_text = _get_text(noti, btn_cnt + NOTIFICATION_TEXT_TYPE_BUTTON_1);
+                       if (btn_text != NULL) {
+                               elm_object_part_text_set(bt_layout, "content.button.text", btn_text);
+                               free(btn_text);
+                       }
+                       elm_object_signal_callback_add(bt_layout, "button_clicked" , "", _button_press_cb, app_control);
+                       evas_object_event_callback_add(bt_layout, EVAS_CALLBACK_DEL, _app_control_del_cb, app_control);
+
+                       evas_object_show(bt_layout);
+                       elm_box_pack_end(s_info.btnbox,bt_layout);
+               }
+       }
+
+       elm_object_part_content_set(obj, "button.swallow", s_info.btnbox);
+       return btn_cnt;
+}
+
+static void _activenoti_create_activenoti(void)
+{
+       DBG("");
+       Eina_Bool ret = EINA_FALSE;
+       Evas_Object *base = NULL;
+       int w, h;
+
+       if (s_info.activenoti != NULL) {
+               ERR("Instant notification exists");
+               return;
+       }
+
+       s_info.activenoti = quickpanel_noti_win_add(NULL);
+       retif(s_info.activenoti == NULL, , "Failed to add elm activenoti.");
+
+       s_info.layout = elm_layout_add(s_info.activenoti);
+       if (!s_info.layout) {
+               ERR("Failed to get detailview.");
+               _activenoti_destroy_activenoti();
+               return;
+       }
+
+       ret = elm_layout_file_set(s_info.layout, ACTIVENOTI_EDJ, "headsup/base");
+       retif(ret == EINA_FALSE, , "failed to load layout");
+
+       elm_object_signal_callback_add(s_info.layout, "noti_press" , "", _noti_press_cb, NULL);
+       elm_object_signal_callback_add(s_info.layout, "del" , "", _handle_press_cb, NULL);
+
+       evas_object_geometry_get(s_info.activenoti, NULL, NULL, &w, &h);
+       DBG("evas_object_geometry_get x %d y %d", w, h);
+
+       elm_win_resize_object_add(s_info.activenoti, s_info.layout);
+       evas_object_show(s_info.layout);
+
+       /* create base rectangle */
+       base = evas_object_rectangle_add(evas_object_evas_get(s_info.layout));
+       if (!base) {
+               ERR("Failed to get detailview.");
+               _activenoti_destroy_activenoti();
+               return;
+       }
+
+       evas_object_size_hint_weight_set(base, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       evas_object_color_set(base, 0, 165, 198, 255);
+
+       elm_object_part_content_set(s_info.layout, "background", base);
+
+       quickpanel_noti_win_content_set(s_info.activenoti, s_info.layout);
+
+       s_info.gesture = _gesture_create(s_info.layout);
+
+       _activenoti_win_rotated(quickpanel_get_app_data(), 0);
+}
+
+static void _activenoti_update_activenoti(void)
+{
+       ERR("");
+       Eina_Bool ret = EINA_FALSE;
+       notification_h noti;
+       Evas_Object *icon = NULL;
+       Evas_Object *badge = NULL;
+       Evas_Object *bg_img = NULL;
+       int btn_cnt = 0;
+       bool auto_remove = true;
+       bool current_auto_remove = true;
+
+       if (s_info.activenoti == NULL) {
+               ERR("Active notification doesn't exist");
+               return;
+       }
+
+       if (s_info.layout == NULL) {
+               ERR("Active notification doesn't exist");
+               return;
+       }
+
+       if (s_info.delay_timer != NULL) {
+               ERR("s_info.delay_timer");
+               ecore_timer_del(s_info.delay_timer);
+               s_info.delay_timer = NULL;
+       }
+
+       if (s_info.close_timer != NULL) {
+               ERR("s_info.close_timer");
+               ecore_timer_del(s_info.close_timer);
+               s_info.close_timer = NULL;
+       }
+
+       noti = _activenoti_get_in_list(s_info.current_noti);
+       if (noti == NULL) {
+               DBG("noti is null");
+               return;
+       }
+
+       if (s_info.current_noti) {
+               ret = notification_get_auto_remove(s_info.current_noti, &current_auto_remove);
+               if (ret != NOTIFICATION_ERROR_NONE) {
+                       DBG("notification_get_auto_remove return [%s] from current_noti", ret);
+                       return;
+               }
+               if (!current_auto_remove) {
+                       DBG("!auto_remove");
+                       ret = notification_get_auto_remove(noti, &auto_remove);
+                       if (ret != NOTIFICATION_ERROR_NONE) {
+                               DBG("notification_get_auto_remove return [%s] from new noti", ret);
+                               return;
+                       }
+
+                       if (auto_remove) {
+                               DBG("auto_remove");
+                               _activenoti_add_in_list(noti); // timer
+                               return; // check!!!
+                       } else {
+                               DBG("!auto_remove");
+                               _activenoti_add_in_list(s_info.current_noti);
+                       }
+               }
+       } else {
+               ret = notification_get_auto_remove(noti, &current_auto_remove);
+               if (ret != NOTIFICATION_ERROR_NONE) {
+                       DBG("notification_get_auto_remove return [%s] from current_noti", ret);
+                       return;
+               }
+       }
+
+       s_info.current_noti = noti;
+
+       if (current_auto_remove == true) {
+               time_t noti_time = 0;
+               ret = notification_get_time(s_info.current_noti, &noti_time);
+               if (ret != NOTIFICATION_ERROR_NONE || noti_time == 0)   {
+                       notification_get_insert_time(s_info.current_noti, &noti_time);
+               }
+               noti_time = time(NULL) - noti_time;
+               s_info.close_timer = ecore_timer_add(DEL_TIMER_VALUE - noti_time, _activenoti_close_timer_cb, NULL);
+       }
+
+       bg_img = elm_object_part_content_unset(s_info.layout, "bg_img");
+       DBG("bg_img %p", bg_img);
+       if(bg_img != NULL) {
+               evas_object_del(bg_img);
+               bg_img = NULL;
+       }
+
+       bg_img = _get_bg_img(s_info.layout , s_info.current_noti);
+       if (bg_img != NULL) {
+               elm_object_part_content_set(s_info.layout, "bg_img", bg_img);
+       }
+
+       btn_cnt = _activenoti_create_button(s_info.layout, s_info.current_noti);
+       if (btn_cnt == 0) { //no button
+               elm_object_signal_emit(s_info.layout, "btn_hide", "button.space");
+       } else {
+               elm_object_signal_emit(s_info.layout, "btn_show", "button.space");
+       }
+
+       icon = elm_object_part_content_unset(s_info.layout, "icon_big");
+       DBG("icon %p", icon);
+       if(icon != NULL) {
+               evas_object_del(icon);
+               icon = NULL;
+       }
+
+       icon = _activenoti_create_icon(s_info.layout, s_info.current_noti);
+       if (icon != NULL) {
+               elm_object_part_content_set(s_info.layout, "icon_big", icon);
+
+               badge = elm_object_part_content_unset(s_info.layout, "icon_badge");
+               DBG("badget %p", badge);
+               if(badge != NULL) {
+                       evas_object_del(badge);
+               }
+
+               badge = _activenoti_create_badge(s_info.layout, s_info.current_noti);
+               if (badge != NULL) {
+                       elm_object_part_content_set(s_info.layout, "icon_badge", badge);
+               } else {
+                       INFO("badge is NULL");
+               }
+               DBG("");
+       } else {
+               INFO("icon is NULL");
+       }
+
+       _activenoti_set_text(noti, 0);
+
+       evas_object_show(s_info.activenoti);
+
+       SERR("activenoti noti is updated");
+}
+
+static void _activenoti_destroy_activenoti(void)
+{
+       retif(!s_info.activenoti,,"s_info->activenoti is null");
+
+       _gesture_destroy();
+
+       if (s_info.delay_timer != NULL) {
+               ecore_timer_del(s_info.delay_timer);
+               s_info.delay_timer = NULL;
+       }
+
+       if (s_info.close_timer != NULL) {
+               ecore_timer_del(s_info.close_timer);
+               s_info.close_timer = NULL;
+       }
+
+       if (s_info.btnbox) {
+               evas_object_del(s_info.btnbox);
+               s_info.btnbox = NULL;
+       }
+
+       if (s_info.layout) {
+               evas_object_del(s_info.layout);
+               s_info.layout = NULL;
+       }
+
+       if (s_info.activenoti) {
+               evas_object_del(s_info.activenoti);
+               s_info.activenoti = NULL;
+       }
+}
+
+static void _activenoti_win_rotated(void *data, int need_hide)
+{
+       retif(data == NULL, ,"data is NULL");
+       int angle = 0;
+       struct appdata *ad = data;
+
+       if (s_info.activenoti != NULL) {
+               angle = elm_win_rotation_get(s_info.activenoti);
+
+               if (((angle == 0 || angle == 180) && (ad->angle == 90 || ad->angle == 270))
+                               || ((angle == 90 || angle == 270) && (ad->angle == 0 || ad->angle == 180))) {
+                       if (need_hide == 1) {
+                               evas_object_hide(s_info.activenoti);
+                       }
+               }
+       }
+}
+
+static void _media_feedback_sound(notification_h noti)
+{
+       retif(noti == NULL, ,"op_list is NULL");
+       int ret = 0, priv_id = 0;
+       const char *nsound_path = NULL;
+       notification_sound_type_e nsound_type = NOTIFICATION_SOUND_TYPE_NONE;
+       char *default_msg_tone = NULL;
+
+       notification_get_id(noti, NULL, &priv_id);
+       notification_get_sound(noti, &nsound_type, &nsound_path);
+       SDBG("notification sound: %d, %s", nsound_type, nsound_path);
+
+       switch (nsound_type) {
+       case NOTIFICATION_SOUND_TYPE_USER_DATA:
+               /*
+                *  if user data file isn't playable, play the default ringtone
+                */
+               if (nsound_path != NULL) {
+                       if (quickpanel_media_playable_check(nsound_path) == EINA_TRUE) {
+                               ret = quickpanel_media_player_play(SOUND_TYPE_NOTIFICATION, nsound_path);
+                               if (quickpanel_media_player_is_drm_error(ret) == 1) {
+                                       ERR("failed to play notification sound due to DRM problem");
+                                       ret = system_settings_get_value_string(SYSTEM_SETTINGS_KEY_SOUND_NOTIFICATION, &default_msg_tone);
+                                       msgif(ret != SYSTEM_SETTINGS_ERROR_NONE, "ailed to get key(%s) : %d", SYSTEM_SETTINGS_KEY_SOUND_NOTIFICATION, ret);
+
+
+                                       if (default_msg_tone != NULL) {
+                                               SDBG("setting sound[%s]", default_msg_tone);
+                                               ret = quickpanel_media_player_play(SOUND_TYPE_NOTIFICATION, default_msg_tone);
+                                               free(default_msg_tone);
+                                       }
+                               }
+                               if (ret == PLAYER_ERROR_NONE) {
+                                       quickpanel_media_player_id_set(priv_id);
+                               } else {
+                                       ERR("failed to play notification sound");
+                               }
+                               break;
+                       } else {
+                               ERR("playable false, So unlock tone");
+                               feedback_play_type(FEEDBACK_TYPE_SOUND, FEEDBACK_PATTERN_UNLOCK);
+                       }
+               } else {
+                       ERR("sound path null");
+               }
+
+               break;
+       case NOTIFICATION_SOUND_TYPE_DEFAULT:
+               ret = system_settings_get_value_string(SYSTEM_SETTINGS_KEY_SOUND_NOTIFICATION, &default_msg_tone);
+               msgif(ret != SYSTEM_SETTINGS_ERROR_NONE, "ailed to get key(%s) : %d", SYSTEM_SETTINGS_KEY_SOUND_NOTIFICATION, ret);
+
+               if (default_msg_tone != NULL) {
+                       SDBG("Reminded setting sound[%s]", default_msg_tone);
+                       ret = quickpanel_media_player_play(SOUND_TYPE_NOTIFICATION, default_msg_tone);
+                       free(default_msg_tone);
+                       if (ret == PLAYER_ERROR_NONE) {
+                               quickpanel_media_player_id_set(priv_id);
+                       } else {
+                               ERR("failed to play notification sound(default)");
+                       }
+               }
+               break;
+       case NOTIFICATION_SOUND_TYPE_MAX:
+       case NOTIFICATION_SOUND_TYPE_NONE:
+               ERR("None type: No sound");
+               break;
+
+       default:
+               ERR("UnKnown type[%d]", (int)nsound_type);
+               break;
+       }
+}
+
+static void _media_feedback_vibration(notification_h noti)
+{
+       retif(noti == NULL, , "Invalid parameter!");
+
+       /* Play Vibration */
+       notification_vibration_type_e nvibration_type = NOTIFICATION_VIBRATION_TYPE_NONE;
+       const char *nvibration_path = NULL;
+
+       notification_get_vibration(noti, &nvibration_type, &nvibration_path);
+       DBG("notification vibration: %d, %s", nvibration_type, nvibration_path);
+       switch (nvibration_type) {
+       case NOTIFICATION_VIBRATION_TYPE_USER_DATA:
+       case NOTIFICATION_VIBRATION_TYPE_DEFAULT:
+               feedback_play_type(FEEDBACK_TYPE_VIBRATION, FEEDBACK_PATTERN_MESSAGE);
+               break;
+       case NOTIFICATION_VIBRATION_TYPE_MAX:
+       case NOTIFICATION_VIBRATION_TYPE_NONE:
+               break;
+       }
+}
+
+static void _activenoti_noti_detailed_changed_cb(void *data, notification_type_e type, notification_op *op_list, int num_op)
+{
+       DBG("");
+       retif(op_list == NULL, ,"op_list is NULL");
+
+       notification_h noti = NULL;
+       int flags = 0;
+       int applist = NOTIFICATION_DISPLAY_APP_ALL;
+       int op_type = 0;
+       int priv_id = 0;
+
+       notification_op_get_data(op_list, NOTIFICATION_OP_DATA_TYPE, &op_type);
+       notification_op_get_data(op_list, NOTIFICATION_OP_DATA_PRIV_ID, &priv_id);
+       notification_op_get_data(op_list, NOTIFICATION_OP_DATA_NOTI, &noti);
+
+       DBG("op_type:%d", op_type);
+       DBG("op_priv_id:%d", priv_id);
+       DBG("noti:%p", noti);
+
+       if( op_type == NOTIFICATION_OP_DELETE) {
+               DBG("NOTIFICATION_OP_DELETE");
+               int priv_id_current = 0;
+
+               if (s_info.current_noti) {
+                       notification_get_id(s_info.current_noti, NULL, &priv_id_current);
+                       if (s_info.current_noti == noti || priv_id_current == priv_id) {
+                               _activenoti_hide(NULL, 0);
+                               return;
+                       }
+               }
+
+               _activenoti_remove_in_list(noti);
+
+               return;
+       } else if (op_type == NOTIFICATION_OP_DELETE_ALL) {
+               if(s_info.current_noti) {
+                       _activenoti_hide(NULL, 0);
+               }
+               _activenoti_remove_list();
+       }
+
+       retif(noti == NULL, ,"noti is NULL");
+
+       if (op_type == NOTIFICATION_OP_INSERT || op_type == NOTIFICATION_OP_UPDATE) {
+               if (_is_sound_playable() == 1) {
+                       if (_check_sound_off(noti) == 0) {
+                               DBG("try to play notification sound %x", pthread_self());
+                               _media_feedback_sound(noti);
+                               if (quickpanel_media_is_vib_enabled() == 1
+                                               || quickpanel_media_is_sound_enabled() == 1) {
+                                       _media_feedback_vibration(noti);
+                               }
+                       }
+
+               }
+       }
+
+       notification_get_display_applist(noti, &applist);
+       DBG("applist : %x" ,applist);
+
+       /* Check activenoti flag */
+       notification_get_property(noti, &flags);
+
+       if (applist & NOTIFICATION_DISPLAY_APP_ACTIVE) {
+               if (_is_security_lockscreen_launched() || _check_sound_off(noti) == 1 ) {
+                       INFO("lock screen is launched");
+                       return;
+               }
+
+               if (quickpanel_uic_is_opened() && (applist & NOTIFICATION_DISPLAY_APP_NOTIFICATION_TRAY) ) {
+                       ERR("quickpanel is opened, activenoti will be not displayed");
+                       return;
+               }
+
+               /* wait if s_info.activenoti is not NULL */
+               _activenoti_add_in_list(noti);
+
+               _activenoti_create_activenoti();
+               if (s_info.activenoti == NULL) {
+                       ERR("Fail to create activenoti");
+                       _activenoti_only_noti_del(noti);
+                       return;
+               }
+
+               _activenoti_update_activenoti();
+       }
+}
+
+/*****************************************************************************
+ *
+ * Util functions
+ *
+ *****************************************************************************/
+static Eina_Bool _activenoti_callback_register_idler_cb(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, EINA_FALSE, "Invalid parameter!");
+
+       notification_register_detailed_changed_cb(_activenoti_noti_detailed_changed_cb, ad);
+
+       return EINA_FALSE;
+}
+
+static int _activenoti_init(void *data)
+{
+       struct appdata *ad = (struct appdata *)data;
+
+       /* Register notification changed cb */
+       ecore_idler_add(_activenoti_callback_register_idler_cb, ad);
+       return QP_OK;
+}
+
+static int _activenoti_fini(void *data)
+{
+       // struct appdata *ad = (struct appdata *)data;
+
+       _activenoti_destroy_activenoti();
+
+       return QP_OK;
+}
+
+static int _activenoti_enter_hib(void *data)
+{
+       return QP_OK;
+}
+
+static int _activenoti_leave_hib(void *data)
+{
+       return QP_OK;
+}
+
+static void _activenoti_reflesh(void *data)
+{
+       retif(data == NULL, , "Invalid parameter!");
+
+       if (s_info.activenoti != NULL) {
+               _activenoti_win_rotated(data, 1);
+       }
+}
+
+static void _activenoti_qp_opened(void *data)
+{
+       DBG("");
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       if (_activenoti_has_pending_noti()) {
+               _activenoti_remove_list();
+       }
+       _activenoti_hide(NULL, 0);
+}
+
diff --git a/daemon/notifications/animated_image.c b/daemon/notifications/animated_image.c
new file mode 100755 (executable)
index 0000000..4d30401
--- /dev/null
@@ -0,0 +1,154 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "common.h"
+#include "common_uic.h"
+#include "animated_image.h"
+#include "quickpanel-ui.h"
+
+static int _init(void *data);
+static int _fini(void *data);
+static int _suspend(void *data);
+static int _resume(void *data);
+
+QP_Module animated_image = {
+       .name = "animated_image",
+       .init = _init,
+       .fini = _fini,
+       .suspend = _suspend,
+       .resume = _resume,
+       .lang_changed = NULL,
+       .refresh = NULL
+};
+
+static Eina_List *g_animated_image_list = NULL;
+static char g_animated_image_group_name[32] = {0,};
+
+static void _animated_image_list_add(Evas_Object *image)
+{
+       retif(image == NULL, ,"invalid parameter");
+
+       g_animated_image_list = eina_list_append(g_animated_image_list, image);
+}
+
+static void _animated_image_play(Eina_Bool on)
+{
+       const Eina_List *l = NULL;
+       const Eina_List *ln = NULL;
+       Evas_Object *entry_obj = NULL;
+
+       retif_nomsg(g_animated_image_list == NULL, );
+
+       EINA_LIST_FOREACH_SAFE(g_animated_image_list, l, ln, entry_obj) {
+               if (entry_obj == NULL) {
+                       continue;
+               }
+
+               if (on == EINA_TRUE) {
+                       if (elm_image_animated_play_get(entry_obj) == EINA_FALSE) {
+                               elm_image_animated_play_set(entry_obj, EINA_TRUE);
+                       }
+               } else {
+                       if (elm_image_animated_play_get(entry_obj) == EINA_TRUE) {
+                               elm_image_animated_play_set(entry_obj, EINA_FALSE);
+                       }
+               }
+       }
+}
+
+static void _animated_image_deleted_cb(void *data, Evas *e, Evas_Object *obj, void *event_info)
+{
+       retif(obj == NULL, , "obj is NULL");
+       retif(g_animated_image_list == NULL, , "list is empty");
+
+       g_animated_image_list = eina_list_remove(g_animated_image_list, obj);
+}
+
+HAPI void quickpanel_animated_image_add(Evas_Object *image)
+{
+       retif(image == NULL, , "image is NULL");
+
+       if (elm_image_animated_available_get(image) == EINA_TRUE) {
+               elm_image_animated_set(image, EINA_TRUE);
+               if (quickpanel_uic_is_suspended() == 0) {
+                       elm_image_animated_play_set(image, EINA_TRUE);
+               } else {
+                       elm_image_animated_play_set(image, EINA_FALSE);
+               }
+               _animated_image_list_add(image);
+               evas_object_event_callback_add(image, EVAS_CALLBACK_DEL, _animated_image_deleted_cb, NULL);
+       }
+}
+
+HAPI char *quickpanel_animated_image_get_groupname(const char *path)
+{
+       static int s_image_index = 0;
+
+       if (path != NULL) {
+               if (strstr(path, "gif") != NULL || strstr(path, "GIF") != NULL) {
+                       snprintf(g_animated_image_group_name, sizeof(g_animated_image_group_name),
+                                       "%d:EVAS", s_image_index++);
+
+                       return g_animated_image_group_name;
+               }
+       }
+
+       return NULL;
+}
+
+/*****************************************************************************
+ *
+ * Util functions
+ *
+ *****************************************************************************/
+static int _init(void *data)
+{
+       return QP_OK;
+}
+
+static int _fini(void *data)
+{
+       return QP_OK;
+}
+
+static int _suspend(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+       SDBG("animated image going to be suspened");
+       _animated_image_play(EINA_FALSE);
+
+       return QP_OK;
+}
+
+static int _resume(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+       SDBG("animated image going to be resumed");
+       _animated_image_play(EINA_TRUE);
+
+       return QP_OK;
+}
diff --git a/daemon/notifications/animated_image.h b/daemon/notifications/animated_image.h
new file mode 100755 (executable)
index 0000000..50a458e
--- /dev/null
@@ -0,0 +1,26 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+
+#ifndef __QUICKPANEL_ANIMATED_IMAGE_H__
+#define __QUICKPANEL_ANIMATED_IMAGE_H__
+
+extern void quickpanel_animated_image_add(Evas_Object *image);
+extern char *quickpanel_animated_image_get_groupname(const char *path);
+
+#endif
diff --git a/daemon/notifications/noti.c b/daemon/notifications/noti.c
new file mode 100755 (executable)
index 0000000..f595626
--- /dev/null
@@ -0,0 +1,1532 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+#include <glib.h>
+
+#include <time.h>
+
+#include <vconf.h>
+#include <app_control.h>
+#include <notification.h>
+#include <notification_internal.h>
+#include <notification_list.h>
+#include <notification_ongoing_flag.h>
+#include <system_settings.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <sound_manager.h>
+#include <E_DBus.h>
+
+#include "media.h"
+#include "quickpanel-ui.h"
+#include "quickpanel_def.h"
+#include "common_uic.h"
+#include "common.h"
+#include "list_util.h"
+#include "noti_node.h"
+#include "vi_manager.h"
+#include "noti_listbox.h"
+#include "noti_list_item.h"
+#include "noti_section.h"
+#include "noti_view.h"
+#include "noti.h"
+#include "list_util.h"
+
+#ifdef QP_SERVICE_NOTI_LED_ENABLE
+#include "noti_led.h"
+#endif
+
+#ifdef QP_REMINDER_ENABLE
+#include "reminder.h"
+#endif
+
+#ifdef QP_EMERGENCY_MODE_ENABLE
+#include "emergency_mode.h"
+#endif
+
+#define QP_NOTI_ONGOING_DBUS_PATH      "/dbus/signal"
+#define QP_NOTI_ONGOING_DBUS_INTERFACE "notification.ongoing"
+
+static struct _info {
+       noti_node   *noti_node;
+       Evas_Object *ongoing_noti_section_view;
+       Evas_Object *noti_section_view;
+       Evas_Object *noti_box;
+
+       E_DBus_Signal_Handler *dbus_handler_size;
+       E_DBus_Signal_Handler *dbus_handler_progress;
+       E_DBus_Signal_Handler *dbus_handler_content;
+
+       struct tm last_time;
+
+       int is_ongoing_hided;
+} s_info = {
+       .noti_node = NULL,
+       .ongoing_noti_section_view = NULL,
+       .noti_section_view = NULL,
+       .noti_box = NULL,
+
+       .dbus_handler_size = NULL,
+       .dbus_handler_progress = NULL,
+       .dbus_handler_content = NULL,
+
+       .is_ongoing_hided = 0,
+
+       .last_time.tm_mday = 0,
+       .last_time.tm_mon = 0,
+       .last_time.tm_year = 0,
+};
+
+static void _ongoing_noti_section_deleted_cb(void *data, Evas *e, Evas_Object *obj, void *event_info);
+
+static notification_h _update_item_progress(const char *pkgname, int priv_id, double progress)
+{
+       char *noti_pkgname = NULL;
+       int noti_priv_id = 0;
+
+       noti_node_item *node = quickpanel_noti_node_get(s_info.noti_node, priv_id);
+
+       if (node != NULL && node->noti != NULL) {
+               notification_get_pkgname(node->noti, &noti_pkgname);
+               notification_get_id(node->noti, NULL, &noti_priv_id);
+
+               if (!pkgname || !noti_pkgname) {
+                       return NULL;
+               }
+
+               if (!strcmp(noti_pkgname, pkgname) && priv_id == noti_priv_id) {
+
+                       if (notification_set_progress(node->noti, progress) != NOTIFICATION_ERROR_NONE) {
+                               ERR("fail to set progress");
+                       }
+                       return node->noti;
+               }
+       }
+
+       return NULL;
+}
+
+static notification_h _update_item_size(const char *pkgname, int priv_id, double size)
+{
+       char *noti_pkgname = NULL;
+       int noti_priv_id = 0;
+
+       noti_node_item *node = quickpanel_noti_node_get(s_info.noti_node, priv_id);
+
+       if (node != NULL && node->noti != NULL) {
+               notification_get_pkgname(node->noti, &noti_pkgname);
+               notification_get_id(node->noti, NULL, &noti_priv_id);
+
+               if (!pkgname || !noti_pkgname) {
+                       return NULL;
+               }
+
+               if (!strcmp(noti_pkgname, pkgname)
+                               && priv_id == noti_priv_id) {
+                       notification_set_size(node->noti, size);
+                       return node->noti;
+               }
+       }
+
+       return NULL;
+}
+
+static notification_h _update_item_content(const char *pkgname, int priv_id, char *content)
+{
+       char *noti_pkgname = NULL;
+       int noti_priv_id = 0;
+       int ret = NOTIFICATION_ERROR_NONE;
+
+       noti_node_item *node = quickpanel_noti_node_get(s_info.noti_node, priv_id);
+
+       if (node != NULL && node->noti != NULL) {
+               notification_get_pkgname(node->noti, &noti_pkgname);
+               notification_get_id(node->noti, NULL, &noti_priv_id);
+
+               if (!pkgname || !noti_pkgname) {
+                       return NULL;
+               }
+
+               if (!strcmp(noti_pkgname, pkgname) && priv_id == noti_priv_id) {
+                       ret = notification_set_text(node->noti, NOTIFICATION_TEXT_TYPE_CONTENT, content, NULL, NOTIFICATION_VARIABLE_TYPE_NONE);
+                       if (ret != NOTIFICATION_ERROR_NONE) {
+                               ERR("Failed to set text[%d]", ret);
+                       }
+
+                       return node->noti;
+               }
+       }
+
+       return NULL;
+}
+
+static void _update_progressbar(void *data, notification_h update_noti)
+{
+       int priv_id = 0;
+       struct appdata *ad = data;
+       noti_node_item *node = NULL;
+       retif(ad == NULL, , "data is NULL");
+       retif(ad->list == NULL, , "ad->list is NULL");
+
+       if (notification_get_id(update_noti, NULL, &priv_id) == NOTIFICATION_ERROR_NONE) {
+               node = quickpanel_noti_node_get(s_info.noti_node, priv_id);
+       }
+       retif(node == NULL, , "fail to find node of priv_id:%d", priv_id);
+       retif(node->view == NULL, , "fail to find %p", node->view);
+
+       quickpanel_noti_listbox_update_item(ad->list, node->view);
+}
+
+static void _item_progress_update_cb(void *data, DBusMessage *msg)
+{
+       DBusError err;
+       char *pkgname = 0;
+       int priv_id = 0;
+       double progress = 0;
+       notification_h noti = NULL;
+
+       retif(data == NULL || msg == NULL, , "Invalid parameter!");
+
+       dbus_error_init(&err);
+       dbus_message_get_args(msg, &err,
+                       DBUS_TYPE_STRING, &pkgname,
+                       DBUS_TYPE_INT32, &priv_id,
+                       DBUS_TYPE_DOUBLE, &progress,
+                       DBUS_TYPE_INVALID);
+
+       if (dbus_error_is_set(&err)) {
+               ERR("dbus err: %s", err.message);
+               dbus_error_free(&err);
+               return;
+       }
+
+       if (pkgname == NULL) {
+               ERR("pkgname is null");
+               return;
+       }
+
+       /* check item on the list */
+       noti = _update_item_progress(pkgname, priv_id, progress);
+       retif(noti == NULL, , "Can not found noti data.");
+
+       SDBG("pkgname[%s], priv_id[%d], progress[%lf]", pkgname, priv_id, progress);
+       _update_progressbar(data, noti);
+}
+
+static void _item_size_update_cb(void *data, DBusMessage * msg)
+{
+       DBusError err;
+       char *pkgname = 0;
+       int priv_id = 0;
+       double size = 0;
+       notification_h noti = NULL;
+
+       retif(data == NULL || msg == NULL, , "Invalid parameter!");
+
+       dbus_error_init(&err);
+       dbus_message_get_args(msg, &err,
+                       DBUS_TYPE_STRING, &pkgname,
+                       DBUS_TYPE_INT32, &priv_id,
+                       DBUS_TYPE_DOUBLE, &size, DBUS_TYPE_INVALID);
+       if (dbus_error_is_set(&err)) {
+               ERR("dbus err: %s", err.message);
+               dbus_error_free(&err);
+               return;
+       }
+
+       if (pkgname == NULL) {
+               ERR("pkgname is null");
+               return;
+       }
+
+       /* check item on the list */
+       noti = _update_item_size(pkgname, priv_id, size);
+       retif(noti == NULL, , "Can not found noti data.");
+
+       SDBG("pkgname[%s], priv_id[%d], progress[%lf]",
+                       pkgname, priv_id, size);
+
+       _update_progressbar(data, noti);
+}
+
+static void _item_content_update_cb(void *data, DBusMessage *msg)
+{
+       DBusError err;
+       char *pkgname = NULL;
+       int priv_id = 0;
+       char *content = NULL;
+       notification_h noti = NULL;
+
+       retif(data == NULL || msg == NULL, , "Invalid parameter!");
+
+       dbus_error_init(&err);
+       dbus_message_get_args(msg, &err,
+                       DBUS_TYPE_STRING, &pkgname,
+                       DBUS_TYPE_INT32, &priv_id,
+                       DBUS_TYPE_STRING, &content, DBUS_TYPE_INVALID);
+
+       if (pkgname == NULL) {
+               ERR("pkgname  is null");
+               return;
+       }
+       if (content == NULL) {
+               ERR("content is null");
+               return;
+       }
+
+       if (dbus_error_is_set(&err)) {
+               ERR("dbus err: %s", err.message);
+               dbus_error_free(&err);
+               return;
+       }
+
+       SDBG("pkgname[%s], priv_id[%d], content[%s]",
+                       pkgname, priv_id, content);
+
+       /* check item on the list */
+       noti = _update_item_content(pkgname, priv_id, content);
+       retif(noti == NULL, , "Can not found noti data.");
+
+       _update_progressbar(data, noti);
+}
+
+static int _is_item_deletable(notification_h noti)
+{
+       notification_type_e type = NOTIFICATION_TYPE_NONE;
+       notification_ly_type_e ly_type = NOTIFICATION_LY_NONE;
+       bool ongoing_flag = false;
+
+       notification_get_type(noti, &type);
+       notification_get_layout(noti, &ly_type);
+       notification_get_ongoing_flag(noti, &ongoing_flag);
+
+       if( (type == NOTIFICATION_TYPE_ONGOING && ongoing_flag) ||
+                       (type == NOTIFICATION_TYPE_ONGOING && ly_type == NOTIFICATION_LY_ONGOING_PROGRESS)) {
+               return 0;
+       }
+
+       return 1;
+}
+
+static int _do_noti_delete(notification_h noti)
+{
+       char *pkgname = NULL;
+       char *caller_pkgname = NULL;
+       int flags = 0, priv_id = 0, flag_delete = 0;
+       notification_type_e type = NOTIFICATION_TYPE_NONE;
+       int ret = NOTIFICATION_ERROR_INVALID_PARAMETER;
+
+       quickpanel_media_play_feedback();
+
+       retif(noti == NULL, NOTIFICATION_ERROR_INVALID_PARAMETER, "Invalid parameter!");
+
+       notification_get_pkgname(noti, &caller_pkgname);
+       //      notification_get_application(noti, &pkgname);
+       if (pkgname == NULL) {
+               pkgname = caller_pkgname;
+       }
+
+       notification_get_id(noti, NULL, &priv_id);
+       notification_get_property(noti, &flags);
+       notification_get_type(noti, &type);
+
+       if (flags & NOTIFICATION_PROP_PERMANENT_DISPLAY) {
+               flag_delete = 0;
+       } else {
+               flag_delete = 1;
+       }
+
+       if (flag_delete == 1 && ( type == NOTIFICATION_TYPE_NOTI || _is_item_deletable(noti)) ) {
+               ret = notification_delete_by_priv_id(caller_pkgname, NOTIFICATION_TYPE_NOTI,
+                               priv_id);
+       }
+
+       return ret;
+}
+
+static void _do_noti_press(notification_h noti, int pressed_area)
+{
+       DBG("launch app");
+       int ret = APP_CONTROL_ERROR_NONE;
+       char *pkgname = NULL;
+       char *caller_pkgname = NULL;
+
+       bundle *responding_service_handle = NULL;
+       bundle *single_service_handle = NULL;
+       bundle *multi_service_handle = NULL;
+       int flags = 0, group_id = 0, priv_id = 0, count = 0, flag_launch = 0,
+               flag_delete = 0;
+       notification_type_e type = NOTIFICATION_TYPE_NONE;
+
+       quickpanel_media_play_feedback();
+
+       retif(noti == NULL, , "Invalid parameter!");
+
+       notification_get_pkgname(noti, &caller_pkgname);
+       //      notification_get_application(noti, &pkgname);
+       if (pkgname == NULL) {
+               pkgname = caller_pkgname;
+       }
+
+       notification_get_id(noti, &group_id, &priv_id);
+       notification_get_property(noti, &flags);
+       notification_get_type(noti, &type);
+
+       if (flags & NOTIFICATION_PROP_DISABLE_APP_LAUNCH) {
+               flag_launch = 0;
+       } else {
+               flag_launch = 1;
+       }
+
+       if (flags & NOTIFICATION_PROP_DISABLE_AUTO_DELETE) {
+               flag_delete = 0;
+       } else {
+               flag_delete = 1;
+       }
+
+       notification_get_execute_option(noti,
+                       NOTIFICATION_EXECUTE_TYPE_RESPONDING,
+                       NULL, &responding_service_handle);
+       notification_get_execute_option(noti,
+                       NOTIFICATION_EXECUTE_TYPE_SINGLE_LAUNCH,
+                       NULL, &single_service_handle);
+       notification_get_execute_option(noti,
+                       NOTIFICATION_EXECUTE_TYPE_MULTI_LAUNCH,
+                       NULL, &multi_service_handle);
+
+       if (pressed_area == NOTI_PRESS_BUTTON_1 && responding_service_handle != NULL) {
+               DBG("");
+               quickpanel_uic_close_quickpanel(true, 1);
+               ret = quickpanel_uic_launch_app(NULL, responding_service_handle);
+       } else if (flag_launch == 1) {
+               /* Hide quickpanel */
+               quickpanel_uic_close_quickpanel(true, 1);
+
+               char *text_count = NULL;
+               notification_get_text(noti, NOTIFICATION_TEXT_TYPE_EVENT_COUNT, &text_count);
+
+               if (text_count != NULL) {
+                       count = atoi(text_count);
+               } else {
+                       count = 1;
+               }
+
+               if (single_service_handle != NULL && multi_service_handle == NULL) {
+                       DBG("");
+                       ret = quickpanel_uic_launch_app(NULL, single_service_handle);
+               }
+               if (single_service_handle == NULL && multi_service_handle != NULL) {
+                       DBG("");
+                       ret = quickpanel_uic_launch_app(NULL, multi_service_handle);
+               }
+               if (single_service_handle != NULL && multi_service_handle != NULL) {
+                       DBG("");
+                       if (count <= 1) {
+                               ret = quickpanel_uic_launch_app(NULL, single_service_handle);
+                       } else {
+                               ret = quickpanel_uic_launch_app(NULL, multi_service_handle);
+                       }
+               }
+               quickpanel_uic_launch_app_inform_result(pkgname, ret);
+       }
+
+       if (flag_delete == 1 && type == NOTIFICATION_TYPE_NOTI) {
+               notification_delete_by_priv_id(caller_pkgname,
+                               NOTIFICATION_TYPE_NOTI,
+                               priv_id);
+       }
+}
+
+static void _notibox_delete_cb(noti_node_item *item, Evas_Object *obj)
+{
+       DBG("");
+       retif(obj == NULL, , "Invalid parameter!");
+       retif(item == NULL, , "Invalid parameter!");
+
+       notification_h noti = item->noti;
+       retif(noti == NULL, , "Invalid parameter!");
+
+       _do_noti_delete(noti);
+}
+
+static void _notibox_button_1_cb(noti_node_item *item, Evas_Object *obj)
+{
+       DBG("");
+       retif(item == NULL, , "Invalid parameter!");
+
+       notification_h noti = item->noti;
+       retif(noti == NULL, , "Invalid parameter!");
+
+       _do_noti_press(noti, NOTI_PRESS_BUTTON_1);
+}
+
+static void _notibox_select_cb(noti_node_item *item, Evas_Object *obj)
+{
+       DBG("");
+       retif(item == NULL, , "Invalid parameter!");
+       notification_h noti = item->noti;
+       retif(noti == NULL, , "Invalid parameter!");
+
+       _do_noti_press(noti, NOTI_PRESS_BG);
+}
+
+static void _noti_listitem_select_cb(noti_node_item *item, Evas_Object * obj)
+{
+       DBG("");
+       retif(item == NULL, , "Invalid parameter!");
+
+       notification_h noti = item->noti;
+       retif(noti == NULL, , "Invalid parameter!");
+
+       _do_noti_press(noti, NOTI_PRESS_BG);
+}
+
+static inline void _ongoing_comp_n_copy(notification_h old, notification_h new)
+{
+       int priv_id = 0;
+       int new_priv_id = 0;
+       char *pkgname = NULL;
+       char *new_pkgname = NULL;
+       int ret = NOTIFICATION_ERROR_NONE;
+
+       if (!old) {
+               return;
+       }
+
+       if (!new) {
+               return;
+       }
+
+       notification_get_id(old, NULL, &priv_id);
+       notification_get_id(new, NULL, &new_priv_id);
+
+       notification_get_pkgname(old, &pkgname);
+       notification_get_pkgname(new, &new_pkgname);
+
+       if (!pkgname || !new_pkgname) {
+               return;
+       }
+
+       if (!strcmp(pkgname, new_pkgname) && priv_id == new_priv_id) {
+               double percentage = 0.0;
+               double size = 0.0;
+               time_t insert_time = 0;
+               time_t new_insert_time = 0;
+
+               notification_get_progress(old, &percentage);
+               notification_get_size(old, &size);
+               if (notification_set_progress(new, percentage) != NOTIFICATION_ERROR_NONE) {
+                       ERR("fail to set progress");
+               }
+               if (notification_set_size(new, size) != NOTIFICATION_ERROR_NONE) {
+                       ERR("fail to set size");
+               }
+               notification_get_insert_time(old, &insert_time);
+               notification_get_insert_time(new, &new_insert_time);
+
+               if (insert_time == new_insert_time) {
+                       char *content = NULL;
+                       notification_get_text(old, NOTIFICATION_TEXT_TYPE_CONTENT,      &content);
+                       ret = notification_set_text(new, NOTIFICATION_TEXT_TYPE_CONTENT, content, NULL, NOTIFICATION_VARIABLE_TYPE_NONE);
+                       if (ret != NOTIFICATION_ERROR_NONE) {
+                               ERR("Failed to set text[%d]", ret);
+                       }
+               }
+       }
+}
+
+static void _noti_node_clear_list_cb(gpointer key, gpointer value, gpointer user_data)
+{
+       Evas_Object *noti_listbox = user_data;
+       noti_node_item *node = (noti_node_item *)value;
+
+       if (noti_listbox != NULL && node != NULL) {
+               if (node->noti != NULL && node->view != NULL) {
+                       quickpanel_noti_listbox_remove_item(noti_listbox, node->view, EINA_TRUE);
+               }
+       }
+}
+
+static void _noti_clear_list_all(void)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+
+       retif(ad == NULL, , "Invalid parameter!");
+
+       if (s_info.noti_node != NULL && s_info.noti_node->table != NULL) {
+               g_hash_table_foreach(s_info.noti_node->table, _noti_node_clear_list_cb, ad->list);
+
+               quickpanel_noti_node_remove_all(s_info.noti_node);
+       }
+}
+
+static void _ongoing_noti_section_icon_state_set(int is_closed)
+{
+       if (s_info.ongoing_noti_section_view != NULL) {
+               if (is_closed == 1) {
+                       elm_object_signal_emit(s_info.ongoing_noti_section_view, "button,opened", "prog");
+               } else {
+                       elm_object_signal_emit(s_info.ongoing_noti_section_view, "button,closed", "prog");
+               }
+       }
+}
+
+static void _ongoing_noti_section_add(void)
+{
+       int noti_count;
+       struct appdata *ad;
+
+       ad = quickpanel_get_app_data();
+       if (!ad) {
+               ERR("Invalid parameter");
+               return;
+       }
+
+       if (!ad->list) {
+               ERR("Invalid list");
+               return;
+       }
+
+       if (s_info.noti_node) {
+               noti_count = quickpanel_noti_node_get_item_count(s_info.noti_node, NOTIFICATION_TYPE_NONE);
+       } else {
+               noti_count = 0;
+       }
+
+       DBG("[%d] ", noti_count);
+
+       if (!s_info.ongoing_noti_section_view) {
+               s_info.ongoing_noti_section_view = quickpanel_noti_section_create(ad->list, QP_ITEM_TYPE_ONGOING_NOTI_GROUP);
+               if (s_info.ongoing_noti_section_view) {
+                       quickpanel_noti_section_set_deleted_cb(s_info.ongoing_noti_section_view, _ongoing_noti_section_deleted_cb, ad);
+                       quickpanel_noti_section_update(s_info.ongoing_noti_section_view, noti_count);
+
+                       if (s_info.is_ongoing_hided == 1) {
+                               DBG("Hide NOTI.SECTION");
+                               _ongoing_noti_section_icon_state_set(0);
+                       }
+               }
+       }
+       else {
+               DBG("noti section update %d ", noti_count);
+               quickpanel_noti_section_update(s_info.ongoing_noti_section_view, noti_count);
+       }
+}
+
+static void _ongoing_noti_section_deleted_cb(void *data, Evas *e, Evas_Object *obj, void *event_info)
+{
+       DBG("");
+       struct appdata *ad = data;
+       s_info.ongoing_noti_section_view = NULL;
+       DBG("VIM ongoing noti_section deleted");
+
+       if (quickpanel_noti_node_get_item_count(s_info.noti_node, NOTIFICATION_TYPE_NONE) > 0) {
+               _ongoing_noti_section_add();
+       }
+
+       quickpanel_noti_listbox_remove_item(ad->list, s_info.noti_section_view, 1);
+       s_info.noti_section_view = NULL;
+}
+
+static void _noti_ongoing_add(Evas_Object *list, void *data, int is_prepend)
+{
+       Evas_Object *noti_list_item = NULL;
+       notification_h noti = data;
+       retif(list == NULL, , "Invalid parameter!");
+
+       if (noti != NULL) {
+               noti_list_item = quickpanel_noti_list_item_create(list, noti);
+
+               if (noti_list_item != NULL) {
+                       noti_node_item *item = quickpanel_noti_node_add(s_info.noti_node, (void*)data, (void*)noti_list_item);
+                       if (item != NULL) {
+                               quickpanel_noti_list_item_node_set(noti_list_item, item);
+                               quickpanel_noti_list_item_set_item_selected_cb(noti_list_item, _noti_listitem_select_cb);
+                               quickpanel_noti_list_item_set_item_deleted_cb(noti_list_item, _notibox_delete_cb);
+
+                               if (s_info.ongoing_noti_section_view == NULL) {
+                                       _ongoing_noti_section_add();
+                               }
+                               quickpanel_noti_listbox_add_item(list, noti_list_item, is_prepend, s_info.ongoing_noti_section_view);
+                       }
+               } else
+                       ERR("fail to insert item to list : %p", data);
+       }
+
+       DBG("noti[%p] data[%p] added listbox[%p]",
+                       data, noti_list_item, list);
+}
+
+static void _noti_add(Evas_Object *list, void *data, int insert_pos)
+{
+       notification_h noti = data;
+       notification_ly_type_e layout = NOTIFICATION_LY_NOTI_EVENT_SINGLE;
+       Evas_Object *noti_view = NULL;
+
+       retif(list == NULL, , "Invalid parameter!");
+
+       if (noti != NULL) {
+               notification_get_layout(noti, &layout);
+               noti_view = quickpanel_noti_list_item_create(list, noti);
+
+               if (noti_view != NULL) {
+                       noti_node_item *item = quickpanel_noti_node_add(s_info.noti_node, (void*)data, (void*)noti_view);
+                       if (item != NULL) {
+                               quickpanel_noti_list_item_node_set(noti_view, item);
+                               quickpanel_noti_list_item_set_item_selected_cb(noti_view, _notibox_select_cb);
+                               quickpanel_noti_list_item_set_item_button_1_cb(noti_view, _notibox_button_1_cb);
+                               quickpanel_noti_list_item_set_item_deleted_cb(noti_view, _notibox_delete_cb);
+
+                               if (s_info.noti_section_view == NULL) {
+                                       _ongoing_noti_section_add();
+                               }
+                               quickpanel_noti_listbox_add_item(list, noti_view, insert_pos, s_info.noti_section_view);
+                       }
+               } else
+                       ERR("fail to insert item to list : %p", data);
+       }
+
+       DBG("noti[%p] view[%p] added gridbox[%p]",
+                       data, noti_view, list);
+}
+
+static void _update_notilist(struct appdata *ad)
+{
+       DBG("");
+       Evas_Object *list = NULL;
+       notification_h noti = NULL;
+       notification_h noti_save = NULL;
+       notification_list_h list_head = NULL;
+       notification_list_h list_traverse = NULL;
+       int applist = NOTIFICATION_DISPLAY_APP_ALL;
+
+       DBG("");
+
+       retif(ad == NULL, , "Invalid parameter!");
+
+       list = ad->list;
+       retif(list == NULL, , "Failed to get noti genlist.");
+
+       _noti_clear_list_all();
+
+       notification_get_list(NOTIFICATION_TYPE_ONGOING, -1, &list_head);
+       list_traverse = list_head;
+       while (list_traverse != NULL) {
+               noti = notification_list_get_data(list_traverse);
+               notification_get_display_applist(noti, &applist);
+
+               if (applist &
+                               NOTIFICATION_DISPLAY_APP_NOTIFICATION_TRAY) {
+                       notification_clone(noti, &noti_save);
+                       _noti_ongoing_add(list, noti_save, LISTBOX_APPEND);
+               }
+               list_traverse = notification_list_get_next(list_traverse);
+       }
+       if (list_head != NULL) {
+               notification_free_list(list_head);
+               list_head = NULL;
+       }
+
+       notification_get_list(NOTIFICATION_TYPE_NOTI , -1, &list_head);
+       list_traverse = list_head;
+       while (list_traverse != NULL) {
+               noti = notification_list_get_data(list_traverse);
+               notification_get_display_applist(noti, &applist);
+
+               if (applist &
+                               NOTIFICATION_DISPLAY_APP_NOTIFICATION_TRAY) {
+                       notification_clone(noti, &noti_save);
+                       _noti_add(list, noti_save, LISTBOX_APPEND);
+               }
+               list_traverse = notification_list_get_next(list_traverse);
+       }
+       if (list_head != NULL) {
+               notification_free_list(list_head);
+               list_head = NULL;
+       }
+
+       if (list != NULL) {
+               elm_box_recalculate(list);
+       }
+}
+
+static inline void _print_debuginfo_from_noti(notification_h noti)
+{
+       retif(noti == NULL, , "Invalid parameter!");
+
+       char *noti_pkgname = NULL;
+       notification_type_e noti_type = NOTIFICATION_TYPE_NONE;
+
+       notification_get_pkgname(noti, &noti_pkgname);
+       notification_get_type(noti, &noti_type);
+
+       if (noti_pkgname != NULL) {
+               SERR("pkg:%s", noti_pkgname);
+       }
+
+       SERR("type:%d", noti_type);
+}
+
+static void _detailed_changed_cb(void *data, notification_type_e type, notification_op *op_list, int num_op)
+{
+       int i = 0;
+       int op_type = 0;
+       int priv_id = 0;
+       struct appdata *ad = NULL;
+       notification_h noti_new = NULL;
+       notification_h noti_from_master = NULL;
+       notification_type_e noti_type = NOTIFICATION_TYPE_NONE;
+       int noti_applist = NOTIFICATION_DISPLAY_APP_ALL;
+       notification_ly_type_e noti_layout = NOTIFICATION_LY_NONE;
+       notification_ly_type_e old_noti_layout = NOTIFICATION_LY_NONE;
+
+       retif(data == NULL, , "Invalid parameter!");
+       ad = data;
+
+       SERR("num_op:%d", num_op);
+
+       for (i = 0; i < num_op; i++) {
+               notification_op_get_data(op_list + i, NOTIFICATION_OP_DATA_TYPE, &op_type);
+               notification_op_get_data(op_list + i, NOTIFICATION_OP_DATA_PRIV_ID, &priv_id);
+               notification_op_get_data(op_list + i, NOTIFICATION_OP_DATA_NOTI, &noti_from_master);
+
+               SERR("noti operation:%d privid:%d", op_type, priv_id);
+
+
+               switch(op_type) {
+               case NOTIFICATION_OP_INSERT: 
+                       DBG("NOTIFICATION_OP_INSERT");
+                       if (noti_from_master == NULL) {
+                               ERR("failed to get a notification from master");
+                               continue;
+                       }
+                       if (notification_clone(noti_from_master, &noti_new) != NOTIFICATION_ERROR_NONE) {
+                               ERR("failed to create a cloned notification");
+                               continue;
+                       }
+
+                       _print_debuginfo_from_noti(noti_new);
+#ifdef QP_EMERGENCY_MODE_ENABLE
+                       if (quickpanel_emergency_mode_is_on()) {
+                               if (quickpanel_emergency_mode_notification_filter(noti_new, 0)) {
+                                       notification_free(noti_new);
+                                       return;
+                               }
+                       }
+#endif
+#ifdef QP_SERVICE_NOTI_LED_ENABLE
+                       quickpanel_noti_led_proc(noti_new, op_type);
+#endif
+
+                       notification_get_type(noti_new, &noti_type);
+                       notification_get_display_applist(noti_new, &noti_applist);
+                       notification_get_layout(noti_new, &noti_layout);
+
+                       if (noti_applist & NOTIFICATION_DISPLAY_APP_NOTIFICATION_TRAY) {
+                               noti_node_item *node = quickpanel_noti_node_get(s_info.noti_node, priv_id);
+                               if (node != NULL) {
+                                       if (noti_type == NOTIFICATION_TYPE_NOTI) {
+                                               DBG("cb after inserted:%d", priv_id);
+                                       }
+                                       notification_free(noti_new);
+                               } else {
+                                       if (noti_type == NOTIFICATION_TYPE_NOTI) {
+                                               _noti_add(ad->list, noti_new, LISTBOX_APPEND);
+#ifdef QP_REMINDER_ENABLE
+                                               quickpanel_reminder_start(NULL);
+#endif
+                                       } else if (noti_type == NOTIFICATION_TYPE_ONGOING) {
+                                               _noti_ongoing_add(ad->list, noti_new, LISTBOX_PREPEND);
+                                       } else {
+                                               notification_free(noti_new);
+                                       }
+                               }
+                       } else {
+                               notification_free(noti_new);
+                       }
+                       break;
+
+               case NOTIFICATION_OP_DELETE:
+                       {
+                               DBG("NOTIFICATION_OP_DELETE");
+                               noti_node_item *node = quickpanel_noti_node_get(s_info.noti_node, priv_id);
+
+                               if (node != NULL && node->noti != NULL) {
+                                       notification_h noti = node->noti;
+                                       notification_get_type(noti, &noti_type);
+
+#ifdef QP_SERVICE_NOTI_LED_ENABLE
+                                       quickpanel_noti_led_proc(noti, op_type);
+#endif
+                                       _print_debuginfo_from_noti(noti);
+
+                                       if (noti_type == NOTIFICATION_TYPE_NOTI) {
+                                               quickpanel_noti_listbox_remove_item(ad->list, node->view, 1);
+                                       } else if (noti_type == NOTIFICATION_TYPE_ONGOING) {
+                                               quickpanel_noti_listbox_remove_item(ad->list, node->view, 1);
+                                       }
+
+                                       quickpanel_noti_node_remove(s_info.noti_node, priv_id);
+                                       if (quickpanel_media_player_id_get() == priv_id) {
+                                               quickpanel_media_player_stop();
+                                       }
+                               } else {
+                                       ERR("node = NULL or node->noti == NULL");
+                               }
+
+#ifdef QP_REMINDER_ENABLE
+                               if (quickpanel_noti_node_get_item_count(s_info.noti_node, NOTIFICATION_TYPE_NOTI) <= 0) {
+                                       quickpanel_reminder_stop(NULL);
+                               }
+#endif
+                       }
+                       break;
+
+               case NOTIFICATION_OP_UPDATE:
+                       {
+                               DBG("NOTIFICATION_OP_UPDATE");
+                               noti_node_item *node = quickpanel_noti_node_get(s_info.noti_node, priv_id);
+                               notification_h old_noti = NULL;
+
+                               DBG("Notification update priv_id[%d]", priv_id);
+
+                               if (noti_from_master == NULL) {
+                                       ERR("failed to get a notification from master");
+                                       continue;
+                               }
+
+                               if (notification_clone(noti_from_master, &noti_new) != NOTIFICATION_ERROR_NONE) {
+                                       ERR("failed to create a cloned notification");
+                                       continue;
+                               }
+#ifdef QP_EMERGENCY_MODE_ENABLE
+                               if (quickpanel_emergency_mode_is_on()) {
+                                       if (quickpanel_emergency_mode_notification_filter(noti_new, 0)) {
+                                               DBG("notification filtered");
+                                               notification_free(noti_new);
+                                               return;
+                                       }
+                               }
+#endif
+#ifdef QP_SERVICE_NOTI_LED_ENABLE
+                               quickpanel_noti_led_proc(noti_new, op_type);
+#endif
+                               _print_debuginfo_from_noti(noti_new);
+                               notification_get_layout(noti_new, &noti_layout);
+
+                               if (node != NULL && node->view != NULL && node->noti != NULL) {
+                                       notification_get_type(noti_new, &noti_type);
+
+                                       notification_get_layout(node->noti, &old_noti_layout);
+                                       if (noti_type == NOTIFICATION_TYPE_NOTI || old_noti_layout != noti_layout) {
+                                               if (quickpanel_noti_view_is_view_handler_changed(node->view, noti_new) == 1) {
+                                                       quickpanel_noti_listbox_remove_item(ad->list, node->view, 1);
+                                                       quickpanel_noti_node_remove(s_info.noti_node, priv_id);
+                                               } else {
+                                                       old_noti = node->noti;
+                                                       node->noti = noti_new;
+                                                       quickpanel_noti_listbox_update_item(ad->list, node->view);
+                                               }
+                                       } else if (noti_type == NOTIFICATION_TYPE_ONGOING) {
+                                               old_noti = node->noti;
+                                               node->noti = noti_new;
+
+                                               quickpanel_noti_listbox_update_item(ad->list, node->view);
+                                       } else {
+                                               notification_free(noti_new);
+                                       }
+
+                                       if (old_noti != NULL) {
+                                               notification_free(old_noti);
+                                       }
+                               } else {
+                                       notification_get_display_applist(noti_new, &noti_applist);
+
+                                       if (noti_applist & NOTIFICATION_DISPLAY_APP_NOTIFICATION_TRAY) {
+                                               if (noti_type == NOTIFICATION_TYPE_NOTI) {
+                                                       _noti_add(ad->list, noti_new, LISTBOX_PREPEND);
+                                               } else if (noti_type == NOTIFICATION_TYPE_ONGOING) {
+                                                       _noti_ongoing_add(ad->list, noti_new, LISTBOX_PREPEND);
+                                               } else {
+                                                       notification_free(noti_new);
+                                               }
+                                       } else {
+                                               notification_free(noti_new);
+                                       }
+                               }
+                       }
+                       break;
+
+               case NOTIFICATION_OP_SERVICE_READY:
+                       _update_notilist(ad);
+
+#ifdef QP_SERVICE_NOTI_LED_ENABLE
+                       quickpanel_noti_led_init(ad, s_info.noti_node);
+#endif
+                       quickpanel_vim_set_state_ready();
+
+#ifdef QP_REMINDER_ENABLE
+                       if (quickpanel_noti_node_get_item_count(s_info.noti_node, NOTIFICATION_TYPE_NOTI) > 0) {
+                               quickpanel_reminder_start(NULL);
+                       } else {
+                               quickpanel_reminder_stop(NULL);
+                       }
+#endif
+                       //quickpanel_chg_init();
+                       break;
+
+               default:
+                       SERR("Unknown op type");
+                       break;
+               }
+       }
+
+       int noti_count = quickpanel_noti_node_get_item_count(s_info.noti_node, NOTIFICATION_TYPE_NOTI);
+       int ongoing_noti_count = quickpanel_noti_node_get_item_count(s_info.noti_node, NOTIFICATION_TYPE_ONGOING);
+
+       if (s_info.noti_section_view != NULL) {
+               quickpanel_noti_section_update(s_info.noti_section_view, noti_count+ongoing_noti_count);
+       }
+       if (s_info.ongoing_noti_section_view != NULL) {
+               quickpanel_noti_section_update(s_info.ongoing_noti_section_view, noti_count+ongoing_noti_count);
+       }
+
+       SERR("current noti count:%d, ongoing:%d", noti_count, ongoing_noti_count);
+}
+
+static void _update_sim_status_cb(keynode_t *node, void *data)
+{
+       struct appdata *ad = data;
+
+       if (ad != NULL && ad->list != NULL) {
+               if (notification_is_service_ready() == 1) {
+                       _update_notilist(ad);
+               }
+       }
+}
+
+static Eina_Bool _noti_callback_register_idler_cb(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, EINA_FALSE, "Invalid parameter!");
+
+       notification_register_detailed_changed_cb(_detailed_changed_cb, ad);
+
+       return EINA_FALSE;
+}
+
+static int _register_event_handler(struct appdata *ad)
+{
+       int ret = 0;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+       retif(ad->dbus_connection == NULL, QP_FAIL, "Invalid parameter!");
+
+       s_info.dbus_handler_size =
+               e_dbus_signal_handler_add(ad->dbus_connection, NULL,
+                               QP_NOTI_ONGOING_DBUS_PATH,
+                               QP_NOTI_ONGOING_DBUS_INTERFACE, "update_progress",
+                               _item_progress_update_cb,
+                               ad);
+       if (s_info.dbus_handler_size == NULL) {
+               ERR("fail to add size signal");
+       }
+
+       s_info.dbus_handler_progress =
+               e_dbus_signal_handler_add(ad->dbus_connection, NULL,
+                               QP_NOTI_ONGOING_DBUS_PATH,
+                               QP_NOTI_ONGOING_DBUS_INTERFACE, "update_size",
+                               _item_size_update_cb,
+                               ad);
+       if (s_info.dbus_handler_progress == NULL) {
+               ERR("fail to add progress signal");
+       }
+
+       s_info.dbus_handler_content =
+               e_dbus_signal_handler_add(ad->dbus_connection, NULL,
+                               QP_NOTI_ONGOING_DBUS_PATH,
+                               QP_NOTI_ONGOING_DBUS_INTERFACE, "update_content",
+                               _item_content_update_cb,
+                               ad);
+       if (s_info.dbus_handler_content == NULL) {
+               ERR("fail to add content signal");
+       }
+
+       /* Notify vconf key */
+       ret = vconf_notify_key_changed(VCONFKEY_TELEPHONY_SIM_SLOT, _update_sim_status_cb, (void *)ad);
+       if (ret != 0) {
+               ERR("Failed to register SIM_SLOT change callback!");
+       }
+
+       /* Register notification changed cb */
+       ecore_idler_add(_noti_callback_register_idler_cb, ad);
+
+       return ret;
+}
+
+static int _unregister_event_handler(struct appdata *ad)
+{
+       int ret = 0;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+       retif(ad->dbus_connection == NULL, QP_FAIL, "Invalid parameter!");
+
+       /* Unregister notification changed cb */
+       notification_unregister_detailed_changed_cb(_detailed_changed_cb, (void *)ad);
+
+       ret = vconf_ignore_key_changed(VCONFKEY_TELEPHONY_SIM_SLOT, _update_sim_status_cb);
+       if (ret != 0) {
+               ERR("Failed to ignore SIM_SLOT change callback!");
+       }
+
+       /* Delete dbus signal */
+       if (s_info.dbus_handler_size != NULL) {
+               e_dbus_signal_handler_del(ad->dbus_connection, s_info.dbus_handler_size);
+               s_info.dbus_handler_size = NULL;
+       }
+       if (s_info.dbus_handler_progress != NULL) {
+               e_dbus_signal_handler_del(ad->dbus_connection, s_info.dbus_handler_progress);
+               s_info.dbus_handler_progress = NULL;
+       }
+       if (s_info.dbus_handler_content != NULL) {
+               e_dbus_signal_handler_del(ad->dbus_connection, s_info.dbus_handler_content);
+               s_info.dbus_handler_content = NULL;
+       }
+
+       return QP_OK;
+}
+
+/*static void _quickpanel_noti_init(void *data)
+  {
+  struct appdata *ad = NULL;
+
+  retif(data == NULL, , "Invalid parameter!");
+  ad = data;
+
+  retif(ad->list == NULL, , "Invalid parameter!");
+
+  DBG("wr");
+
+  if (s_info.noti_box == NULL) {
+  s_info.noti_box = quickpanel_noti_listbox_create(ad->list
+  , quickpanel_get_app_data(), QP_ITEM_TYPE_ONGOING_NOTI);
+  quickpanel_noti_listbox_set_item_deleted_cb(s_info.noti_box, _quickpanel_list_box_deleted_cb);
+  quickpanel_list_util_sort_insert(ad->list, s_info.noti_box);
+  }
+  }
+
+  static void _quickpanel_noti_fini(void *data)
+  {
+  struct appdata *ad = NULL;
+
+  retif(data == NULL, , "Invalid parameter!");
+  ad = data;
+
+  retif(ad->list == NULL, , "Invalid parameter!");
+
+  DBG("dr");
+  }*/
+
+static void _on_time_changed(keynode_t *key, void *data)
+{
+       struct appdata *ad = data;
+       time_t current_time;
+       struct tm loc_time;
+
+       if (!key) {
+               /**
+                * @todo
+                * Todo something for this case.
+                */
+       }
+
+       current_time = time(NULL);
+       localtime_r(&current_time, &loc_time);
+
+       if (loc_time.tm_yday != s_info.last_time.tm_yday || loc_time.tm_year != s_info.last_time.tm_year) {
+               _update_notilist(ad);
+       }
+
+       s_info.last_time = loc_time;
+}
+
+static void _noti_time_init(void *data)
+{
+       int ret = 0;
+       struct appdata *ad = data;
+       retif_nomsg(ad == NULL, );
+       time_t current_time;
+
+       current_time = time(NULL);
+       localtime_r(&current_time, &s_info.last_time);
+
+       ret = vconf_notify_key_changed(VCONFKEY_SETAPPL_TIMEZONE_INT, _on_time_changed, data);
+       msgif(ret != 0, "failed to set key(%s) : %d", VCONFKEY_SETAPPL_TIMEZONE_INT, ret);
+       ret = vconf_notify_key_changed(VCONFKEY_TELEPHONY_SVC_ROAM, _on_time_changed, data);
+       msgif(ret != 0, "failed to set key(%s) : %d", VCONFKEY_TELEPHONY_SVC_ROAM, ret);
+       ret = vconf_notify_key_changed(VCONFKEY_SETAPPL_TIMEZONE_ID, _on_time_changed, data);
+       msgif(ret != 0, "failed to set key(%s) : %d", VCONFKEY_SETAPPL_TIMEZONE_ID, ret);
+}
+
+static int _init(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+       quickpanel_noti_node_create(&s_info.noti_node);
+
+       //_quickpanel_noti_init(ad);
+
+       _register_event_handler(ad);
+
+       // NOTI TIME
+       _noti_time_init(data);
+
+       return QP_OK;
+}
+
+static void _noti_time_fini(void *data)
+{
+       int ret = 0;
+       struct appdata *ad = data;
+       retif_nomsg(ad == NULL, );
+
+       ret = vconf_ignore_key_changed(VCONFKEY_SETAPPL_TIMEZONE_INT, _on_time_changed);
+       msgif(ret != 0, "failed to set key(%s) : %d", VCONFKEY_SETAPPL_TIMEZONE_INT, ret);
+       ret = vconf_ignore_key_changed(VCONFKEY_SETAPPL_TIMEZONE_ID, _on_time_changed);
+       msgif(ret != 0, "failed to set key(%s) : %d", VCONFKEY_SETAPPL_TIMEZONE_ID, ret);
+       ret = vconf_ignore_key_changed(VCONFKEY_TELEPHONY_SVC_ROAM, _on_time_changed);
+       msgif(ret != 0, "failed to set key(%s) : %d", VCONFKEY_TELEPHONY_SVC_ROAM, ret);
+}
+
+static int _fini(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+#ifdef QP_SERVICE_NOTI_LED_ENABLE
+       quickpanel_noti_led_fini(ad);
+#endif
+
+       /* Unregister event handler */
+       _unregister_event_handler(data);
+
+       _noti_clear_list_all();
+
+       //_quickpanel_noti_fini(ad);
+
+       if (s_info.noti_node != NULL) {
+               quickpanel_noti_node_destroy(&s_info.noti_node);
+       }
+
+       // NOTI TIME
+       _noti_time_fini(data);
+
+       return QP_OK;
+}
+
+static int _suspend(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+       return QP_OK;
+}
+
+static void _noti_node_ongoing_update_cb(gpointer key, gpointer value, gpointer user_data)
+{
+       notification_type_e noti_type = NOTIFICATION_TYPE_NONE;
+       Evas_Object *noti_listbox = user_data;
+       noti_node_item *node = (noti_node_item *)value;
+
+       if (noti_listbox != NULL && node != NULL) {
+               if (node->noti != NULL && node->view != NULL) {
+                       notification_get_type(node->noti, &noti_type);
+                       if (noti_type == NOTIFICATION_TYPE_ONGOING) {
+                               quickpanel_noti_listbox_update_item(noti_listbox, node->view);
+                       }
+               }
+       }
+}
+
+static int _resume(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+       if (ad->list != NULL && s_info.noti_node != NULL) {
+               if (quickpanel_noti_node_get_item_count(s_info.noti_node, QP_ITEM_TYPE_ONGOING_NOTI) > 0) {
+                       if (s_info.noti_node->table != NULL) {
+                               g_hash_table_foreach(s_info.noti_node->table, _noti_node_ongoing_update_cb, ad->list);
+                       }
+               }
+       }
+
+       return QP_OK;
+}
+
+static void _refresh(void *data)
+{
+       struct appdata *ad = NULL;
+
+       retif(data == NULL, , "Invalid parameter!");
+       ad = data;
+
+       quickpanel_noti_listbox_rotation(ad->list, ad->angle);
+}
+
+static void _lang_changed(void *data)
+{
+       int noti_count = 0;
+       int ongoing_noti_count = 0;
+       struct appdata *ad = data;
+
+       retif(ad == NULL, , "Invalid parameter!");
+
+       if (notification_is_service_ready() == 1) {
+
+               _update_notilist(ad);
+
+               noti_count = quickpanel_noti_node_get_item_count(s_info.noti_node, NOTIFICATION_TYPE_NOTI);
+               ongoing_noti_count = quickpanel_noti_node_get_item_count(s_info.noti_node, NOTIFICATION_TYPE_ONGOING);
+
+               if (s_info.noti_section_view != NULL) {
+                       quickpanel_noti_section_update(s_info.noti_section_view, noti_count+ongoing_noti_count);
+               }
+               if (s_info.ongoing_noti_section_view != NULL) {
+                       quickpanel_noti_section_update(s_info.ongoing_noti_section_view, noti_count+ongoing_noti_count);
+               }
+       }
+}
+
+HAPI int quickpanel_noti_get_count(void)
+{
+       return quickpanel_noti_node_get_item_count(s_info.noti_node, NOTIFICATION_TYPE_NONE);
+}
+
+HAPI int quickpanel_noti_get_type_count(notification_type_e noti_type)
+{
+       return quickpanel_noti_node_get_item_count(s_info.noti_node, noti_type);
+}
+
+HAPI int quickpanel_noti_get_geometry(int *limit_h, int *limit_partial_h, int *limit_partial_w)
+{
+       retif(limit_h == NULL, 0, "invalid parameter");
+       retif(limit_partial_h == NULL, 0, "invalid parameter");
+       retif(limit_partial_w == NULL, 0, "invalid parameter");
+       struct appdata *ad = quickpanel_get_app_data();
+
+       return quickpanel_noti_listbox_get_geometry(ad->list, limit_h, limit_partial_h, limit_partial_w);
+}
+
+HAPI noti_node_item *quickpanel_noti_node_get_by_priv_id(int priv_id)
+{
+       retif(s_info.noti_node == NULL, NULL, "invalid parameter");
+
+       return quickpanel_noti_node_get(s_info.noti_node, priv_id);
+}
+
+HAPI noti_node_item *quickpanel_noti_node_get_first_noti(void)
+{
+       // get box list
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *obj = NULL;
+       Eina_List *item_list = NULL;
+       noti_node_item *node = NULL;
+       noti_node_item *node_first_noti = NULL;
+       notification_type_e type = NOTIFICATION_TYPE_NONE;
+       struct appdata *ad = quickpanel_get_app_data();
+
+       item_list = elm_box_children_get(ad->list);
+       retif(item_list == NULL, NULL, "invalid parameter");
+
+       EINA_LIST_FOREACH_SAFE(item_list, l, l_next, obj) {
+               if (obj != NULL) {
+                       node = quickpanel_noti_list_item_node_get(obj);
+                       if (node) {
+                               notification_h noti = node->noti;
+                               if (noti) {
+                                       notification_get_type(noti, &type);
+                                       if (type == NOTIFICATION_TYPE_NOTI) {
+                                               node_first_noti = node;
+                                               break;
+                                       }
+                               }
+                       }
+               }
+       }
+
+       if (item_list != NULL) {
+               eina_list_free(item_list);
+       }
+
+       return node_first_noti;
+}
+
+HAPI void quickpanel_noti_closing_trigger_set(void)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+
+       retif(ad == NULL, , "invalid parameter");
+
+       quickpanel_noti_listbox_closing_trigger_set(ad->list);
+}
+
+static void _opened(void *data)
+{
+       if (elm_config_access_get() == EINA_TRUE) {
+               elm_access_say(_NOT_LOCALIZED("Notification panel"));
+       }
+}
+
+HAPI void quickpanel_noti_set_clear_all_status()
+{
+       notification_h noti;
+       notification_list_h list_head;
+       notification_list_h list_traverse;
+       bool ongoing_cnt = false;
+       int ret;
+
+       list_head = NULL;
+       ret = notification_get_list(NOTIFICATION_TYPE_ONGOING, -1, &list_head);
+       if (ret != NOTIFICATION_ERROR_NONE) {
+               ERR("Unable to get the list of notification");
+               return;
+       }
+
+       list_traverse = list_head;
+       while (list_traverse != NULL) {
+               noti = notification_list_get_data(list_traverse);
+               if (_is_item_deletable(noti)) {
+                       ongoing_cnt++;
+               }
+               list_traverse = notification_list_get_next(list_traverse);
+       }
+
+       if (list_head != NULL) {
+               notification_free_list(list_head);
+       }
+
+       if (ongoing_cnt == 0 && quickpanel_noti_node_get_item_count(s_info.noti_node, NOTIFICATION_TYPE_NOTI) <= 0) {
+               INFO("NOTI SECTION CLEAR ALL HIDE");
+               elm_object_signal_emit(s_info.ongoing_noti_section_view, "notifaction,section,clear_all,hide", "base");
+       } else {
+               INFO("NOTI SECTION CLEAR ALL SHOW");
+               elm_object_signal_emit(s_info.ongoing_noti_section_view, "notifaction,section,clear_all,show", "base");
+       }
+}
+
+HAPI void quickpanel_noti_on_clear_all_clicked(void *data, Evas_Object *obj, void *info)
+{
+       quickpanel_media_play_feedback();
+       LOGI("NOTI CLEAR ALL CLICKED");
+
+       DBG("");
+       notification_h noti;
+       notification_list_h list_head;
+       notification_list_h list_traverse;
+       int ret;
+
+       quickpanel_noti_closing_trigger_set();
+       notification_clear(NOTIFICATION_TYPE_NOTI);
+
+       list_head = NULL;
+       ret = notification_get_list(NOTIFICATION_TYPE_ONGOING, -1, &list_head);
+       if (ret != NOTIFICATION_ERROR_NONE) {
+               ERR("Unable to get the list of notifications");
+               return;
+       }
+
+       list_traverse = list_head;
+       while (list_traverse != NULL) {
+               noti = notification_list_get_data(list_traverse);
+               if (_is_item_deletable(noti)) {
+                       char *caller_pkgname;
+                       int priv_id;
+
+                       ret = notification_get_id(noti, NULL, &priv_id);
+                       if (ret != NOTIFICATION_ERROR_NONE) {
+                               ERR("Unable to get ID from noti object: %p", noti);
+                               priv_id = 0;
+                       }
+                       ret = notification_get_pkgname(noti, &caller_pkgname);
+                       if (ret != NOTIFICATION_ERROR_NONE) {
+                               ERR("Unable to get caller package name: %p", noti);
+                               caller_pkgname = NULL;
+                       }
+
+                       notification_delete_by_priv_id(caller_pkgname, NOTIFICATION_TYPE_NOTI, priv_id);
+               }
+
+               list_traverse = notification_list_get_next(list_traverse);
+       }
+
+       if (list_head != NULL) {
+               notification_free_list(list_head);
+               list_head = NULL;
+       }
+
+       quickpanel_uic_close_quickpanel(EINA_FALSE, EINA_FALSE);
+
+}
+
+static Eina_Bool _notification_time_format_changed_cb(void *data)
+{
+       struct appdata *ad = data;
+
+       _update_notilist(ad);
+
+       return ECORE_CALLBACK_CANCEL;
+}
+
+HAPI void quickpanel_noti_update_by_system_time_changed_setting_cb(system_settings_key_e key, void *data)
+{
+       // struct appdata *ad = data;
+       if (key == SYSTEM_SETTINGS_KEY_TIME_CHANGED || key == SYSTEM_SETTINGS_KEY_LOCALE_COUNTRY) {
+               _on_time_changed(NULL, data);
+       } else { //key == SYSTEM_SETTINGS_KEY_LOCALE_TIMEFORMAT_24HOUR
+               _notification_time_format_changed_cb(data);
+       }
+}
+
+HAPI void quickpanel_noti_update_by_system_time_changed_vconf_cb(keynode_t *key, void *data)
+{
+       _notification_time_format_changed_cb(data);
+}
+
+HAPI void quickpanel_noti_init_noti_section(void)
+{
+       if (s_info.ongoing_noti_section_view == NULL) {
+               _ongoing_noti_section_add();
+       }
+}
+
+QP_Module noti = {
+       .name = "noti",
+       .init = _init,
+       .fini = _fini,
+       .suspend = _suspend,
+       .resume = _resume,
+       .lang_changed = _lang_changed,
+       .hib_enter = NULL,
+       .hib_leave = NULL,
+       .refresh = _refresh,
+       .get_height = NULL,
+       .qp_opened = _opened,
+};
+
+/* End of a file */
diff --git a/daemon/notifications/noti.h b/daemon/notifications/noti.h
new file mode 100755 (executable)
index 0000000..13d5e3c
--- /dev/null
@@ -0,0 +1,42 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __NOTI_H__
+#define __NOTI_H__
+
+#define NOTI_PRESS_BG 0
+#define NOTI_PRESS_BUTTON_1 1
+
+#define QP_PRELOAD_NOTI_ICON_PATH "/usr/apps/org.tizen.quickpanel/shared/res/noti_icons"
+
+extern int quickpanel_noti_get_count(void);
+extern int quickpanel_noti_get_geometry(int *limit_h, int *limit_partial_h, int *limit_partial_w);
+extern void quickpanel_noti_closing_trigger_set(void);
+
+extern noti_node_item *quickpanel_noti_node_get_by_priv_id(int priv_id);
+extern noti_node_item *quickpanel_noti_node_get_first_noti(void);
+
+extern void quickpanel_noti_set_clear_all_status();
+
+extern void quickpanel_noti_on_clear_all_clicked(void *data, Evas_Object *obj, void *info);
+extern int quickpanel_noti_get_type_count(notification_type_e noti_type);
+extern void quickpanel_noti_init_noti_section(void);
+extern void quickpanel_noti_update_by_system_time_changed_setting_cb(system_settings_key_e  key, void *data);
+extern void quickpanel_noti_update_by_system_time_changed_vconf_cb(keynode_t *key, void *data);
+
+#endif
diff --git a/daemon/notifications/noti_list_item.c b/daemon/notifications/noti_list_item.c
new file mode 100755 (executable)
index 0000000..9bd2009
--- /dev/null
@@ -0,0 +1,622 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#include <Elementary.h>
+#include <string.h>
+#include <glib.h>
+
+#include <vconf.h>
+#include <notification.h>
+#include <notification_internal.h>
+#include <notification_ongoing_flag.h>
+#include <system_settings.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "quickpanel-ui.h"
+#include "common.h"
+#include "list_util.h"
+#include "quickpanel_def.h"
+#include "vi_manager.h"
+#include "noti_node.h"
+#include "noti_list_item.h"
+#include "noti.h"
+#include "noti_util.h"
+#include "animated_icon.h"
+
+#ifdef QP_SCREENREADER_ENABLE
+#include "accessibility.h"
+#endif
+
+#ifdef QP_ANIMATED_IMAGE_ENABLE
+#include "animated_image.h"
+#endif
+
+extern Noti_View_H noti_view_h;
+extern Noti_View_H ongoing_noti_view_h;
+
+#define THRESHOLD_DRAGGING_TIME_LIMIT 1.0
+#define LIMIT_ZOOM_RATIO 0.57
+#define LIMIT_FADEOUT_RATIO 0.1
+#define THRESHOLD_DELETE_START 80
+#define THRESHOLD_DELETE_START_Y_LIMIT 60
+#define THRESHOLD_DISTANCE (300)
+
+static struct _info {
+       int item_debug_step;
+       Noti_View_H *view_handlers[NOTIFICATION_LY_MAX + 1];
+} s_info = {
+       .item_debug_step = 0,
+       .view_handlers = {
+               NULL,
+               &noti_view_h,
+               &noti_view_h,
+               &noti_view_h,
+               &ongoing_noti_view_h,
+               &ongoing_noti_view_h,
+               NULL,
+       },
+};
+
+static int _is_item_deletable_by_gesture(noti_list_item_h *handler)
+{
+       notification_type_e type = NOTIFICATION_TYPE_NONE;
+       notification_ly_type_e ly_type = NOTIFICATION_LY_NONE;
+
+       retif(handler == NULL, 0, "Invalid parameter!");
+       retif(handler->noti_node == NULL, 0, "Invalid parameter!");
+       retif(handler->noti_node->noti == NULL, 0, "Invalid parameter!");
+       bool ongoing_flag = false;
+
+       notification_h noti = handler->noti_node->noti;
+
+       notification_get_type(noti, &type);
+       notification_get_layout(noti, &ly_type);
+       notification_get_ongoing_flag(noti, &ongoing_flag);
+
+       if( (type == NOTIFICATION_TYPE_ONGOING && ongoing_flag) ||
+                       (type == NOTIFICATION_TYPE_ONGOING && ly_type == NOTIFICATION_LY_ONGOING_PROGRESS)) {
+               return 0;
+       }
+
+       return 1;
+}
+
+static void _item_handler_set(Evas_Object *item, noti_list_item_h *handler)
+{
+       retif(item == NULL, , "Invalid parameter!");
+       retif(handler == NULL, , "Invalid parameter!");
+
+       evas_object_data_set(item, E_DATA_NOTI_LIST_ITEM_H, handler);
+}
+
+static noti_list_item_h *_item_handler_get(Evas_Object *item)
+{
+       retif(item == NULL, NULL, "Invalid parameter!");
+
+       return evas_object_data_get(item, E_DATA_NOTI_LIST_ITEM_H);
+}
+
+static noti_node_item *_get_noti_node(Evas_Object *item)
+{
+       retif(item == NULL, NULL, "invalid parameter");
+
+       noti_list_item_h *handler = _item_handler_get(item);
+       retif(handler == NULL, NULL, "invalid parameter");
+
+       return quickpanel_noti_node_get_by_priv_id(handler->priv_id);
+}
+
+static void _response_callback_call(Evas_Object *item, const char *emission)
+{
+       static double time_called = 0.0;
+       retif(item == NULL, , "invalid parameter");
+       retif(emission == NULL, , "invalid parameter");
+
+       if (time_called == 0.0) {
+               time_called = ecore_loop_time_get();
+       } else {
+               if ((ecore_loop_time_get() - time_called) < 0.4) {
+                       DBG("click rejected");
+                       return;
+               }
+               time_called = ecore_loop_time_get();
+       }
+
+       response_cb cb = NULL;
+       noti_list_item_h *handler = _item_handler_get(item);
+       noti_node_item *noti_node = _get_noti_node(item);
+       if (handler != NULL && noti_node != NULL) {
+               if (strncmp(emission,"selected", strlen("selected")) == 0) {
+                       if (handler->need_to_cancel_press > 0) {
+                               handler->need_to_cancel_press = 0;
+                               return;
+                       }
+
+                       cb = handler->selected_cb;
+                       if (cb != NULL) {
+                               cb(noti_node, item);
+                       }
+               }
+               if (strncmp(emission,"button_1", strlen("button_1")) == 0) {
+                       if (handler->need_to_cancel_press > 0) {
+                               handler->need_to_cancel_press = 0;
+                               return;
+                       }
+
+                       cb = handler->button_1_cb;
+                       if (cb != NULL) {
+                               cb(noti_node, item);
+                       }
+               }
+               if (strncmp(emission,"deleted", strlen("deleted")) == 0) {
+                       cb = handler->deleted_cb;
+                       if (cb != NULL) {
+                               cb(noti_node, item);
+                       }
+               }
+       }
+}
+
+static void _signal_cb(void *data, Evas_Object *o, const char *emission, const char *source)
+{
+       retif(data == NULL, , "invalid parameter");
+       retif(o == NULL, , "invalid parameter");
+       retif(emission == NULL, , "invalid parameter");
+
+       _response_callback_call(o, emission);
+}
+
+void static _mouse_down_cb(void *data, Evas *e, Evas_Object *obj, void *event_info)
+{
+       int w = 0, h = 0;
+       noti_list_item_h *handler = NULL;
+       Evas_Event_Mouse_Down *ev = (Evas_Event_Mouse_Down *)event_info;
+       retif(ev == NULL, , "event_info is NULL");
+
+       handler = _item_handler_get(obj);
+       retif(handler == NULL, , "handler is NULL");
+
+       evas_object_geometry_get(obj, NULL, NULL, &w, &h);
+
+       handler->press_x = ev->canvas.x;
+       handler->press_y = ev->canvas.y;
+       handler->obj_w = w;
+       handler->obj_h = h;
+       handler->state = NOTILISTITEM_STATE_NORMAL;
+
+       s_info.item_debug_step = 1;
+       SDBG("mouse down:%d %d %d", handler->obj_w, handler->obj_h, handler->state);
+
+       if (handler->vi != NULL) {
+               quickpanel_vi_user_event_del(handler->vi);
+               handler->vi = NULL;
+       }
+
+       handler->need_to_cancel_press = 0;
+}
+
+static void _mouse_move_cb(void* data, Evas* e, Evas_Object* obj, void* event_info)
+{
+       int delta_x = 0;
+       static int vi_start_x = 0;
+       static int delta_prev = -1;
+       int x = 0, y = 0;
+       int w = 0, h = 0;
+       noti_list_item_h *handler = NULL;
+       Evas_Map *map = NULL;
+       Evas_Event_Mouse_Move* ev = event_info;
+       QP_VI *vi = NULL;
+       retif(ev == NULL, , "event_info is NULL");
+
+       handler = _item_handler_get(obj);
+       retif(handler == NULL, , "handler is NULL");
+
+       if (handler->state == NOTILISTITEM_STATE_GETSTURE_CANCELED) {
+               DBG("deletion has been canceled");
+               return;
+       }
+
+       evas_object_geometry_get(obj, &x, &y, &w, &h);
+       delta_x = ev->cur.output.x - handler->press_x;
+
+       if (s_info.item_debug_step == 1) {
+               SDBG("mouse move:%d %d %d", delta_x, vi_start_x, handler->state);
+               s_info.item_debug_step = 2;
+       }
+
+       if (handler->state == NOTILISTITEM_STATE_NORMAL && _is_item_deletable_by_gesture(handler) == 1) {
+               if (abs(delta_x) >= THRESHOLD_DELETE_START) {
+                       DBG("start a deletion");
+                       handler->state = NOTILISTITEM_STATE_GETSTURE_WAIT;
+
+                       vi_start_x = delta_x;
+
+                       vi = quickpanel_vi_new_with_data(
+                                       VI_OP_DELETE,
+                                       QP_ITEM_TYPE_NOTI,
+                                       NULL,
+                                       obj,
+                                       NULL,
+                                       NULL,
+                                       NULL,
+                                       NULL,
+                                       vi,
+                                       NULL,
+                                       0,
+                                       0);
+                       handler->vi = vi;
+                       handler->need_to_cancel_press = 1;
+                       quickpanel_vi_user_event_add(vi);
+               }
+       } else if (handler->state == NOTILISTITEM_STATE_GETSTURE_WAIT) {
+               if (delta_prev != delta_x) {
+                       map = evas_map_new(4);
+                       if (map != NULL) {
+                               evas_map_util_points_populate_from_object(map, obj);
+                               evas_map_util_points_populate_from_geometry(map, x + delta_x - vi_start_x, y, w, h, 0);
+                               evas_object_map_enable_set(obj, EINA_TRUE);
+                               evas_object_map_set(obj, map);
+                               evas_map_free(map);
+                               quickpanel_list_util_scroll_freeze_set(EINA_TRUE);
+                       }
+                       delta_prev = delta_x;
+               }
+       }
+
+       handler->distance = delta_x;
+}
+
+static void _mouse_up_cb(void *data, Evas *e, Evas_Object *obj, void *event_info)
+{
+       int x = 0;
+       noti_list_item_h *handler;
+
+       handler = _item_handler_get(obj);
+       retif(handler == NULL, , "handler is NULL");
+
+       quickpanel_list_util_scroll_freeze_set(EINA_FALSE);
+
+       if (s_info.item_debug_step == 2) {
+               SDBG("mouse up:%d", handler->state);
+               s_info.item_debug_step = 3;
+       }
+
+       if (handler->state == NOTILISTITEM_STATE_GETSTURE_WAIT) {
+               if (abs(handler->distance) >= (THRESHOLD_DISTANCE - 10) && _is_item_deletable_by_gesture(handler) == 1) {
+                       x = abs(handler->distance) - THRESHOLD_DELETE_START;
+
+                       if (handler->distance > 0) {
+                               Elm_Transit *transit_flick;
+
+                               evas_object_map_set(obj, NULL);
+                               transit_flick = elm_transit_add();
+                               if (transit_flick != NULL) {
+                                       elm_transit_effect_translation_add(transit_flick, x, 0, 480, 0);
+                                       elm_transit_object_add(transit_flick, obj);
+                                       elm_transit_duration_set(transit_flick, 0.25 * (480 - x ) / 480);
+                                       elm_transit_tween_mode_set(transit_flick, ELM_TRANSIT_TWEEN_MODE_LINEAR);
+                                       elm_transit_objects_final_state_keep_set(transit_flick, EINA_TRUE);
+                                       elm_transit_go(transit_flick);
+
+                                       _response_callback_call(obj, "deleted");
+                               }
+                       } else if (handler->distance < 0) {
+                               Elm_Transit *transit_flick;
+
+                               evas_object_map_set(obj, NULL);
+                               transit_flick = elm_transit_add();
+                               if (transit_flick != NULL) {
+                                       elm_transit_effect_translation_add(transit_flick, -x, 0, -480, 0);
+                                       elm_transit_object_add(transit_flick, obj);
+                                       elm_transit_duration_set(transit_flick, 0.25 * ( 480 - x ) / 480);
+                                       elm_transit_tween_mode_set(transit_flick, ELM_TRANSIT_TWEEN_MODE_LINEAR);
+                                       elm_transit_objects_final_state_keep_set(transit_flick, EINA_TRUE);
+                                       elm_transit_go(transit_flick);
+
+                                       _response_callback_call(obj, "deleted");
+                               }
+                       }
+               } else {
+                       evas_object_map_enable_set(obj, EINA_FALSE);
+               }
+
+               if (handler->vi != NULL) {
+                       quickpanel_vi_user_event_del(handler->vi);
+                       handler->vi = NULL;
+               }
+       } else if (handler->state == NOTILISTITEM_STATE_GETSTURE_CANCELED) {
+               evas_object_map_enable_set(obj, EINA_FALSE);
+
+               if (handler->vi != NULL) {
+                       quickpanel_vi_user_event_del(handler->vi);
+                       handler->vi = NULL;
+               }
+       }
+
+       handler->state = NOTILISTITEM_STATE_NORMAL;
+}
+
+static Evas_Event_Flags _flick_end_cb(void *data, void *event_info)
+{
+       int x = 0;
+       noti_list_item_h *handler = NULL;
+       Evas_Object *view = NULL;
+       Elm_Transit *transit_flick = NULL;
+       Elm_Gesture_Momentum_Info *info = (Elm_Gesture_Momentum_Info *)event_info;
+
+       view = (Evas_Object *)data;
+       handler = _item_handler_get(view);
+
+       if (handler != NULL) {
+               handler->state = NOTILISTITEM_STATE_GETSTURE_CANCELED;
+
+               if (_is_item_deletable_by_gesture(handler) != 1) {
+                       return EVAS_EVENT_FLAG_NONE;
+               }
+
+               x = abs(handler->distance) - THRESHOLD_DELETE_START;
+       }
+
+       if (info->x2 - info->x1 > 50) {
+               DBG("Flick event is occurred to right.");
+               evas_object_map_set(view, NULL);
+               transit_flick = elm_transit_add();
+               if (transit_flick != NULL) {
+                       elm_transit_effect_translation_add(transit_flick, x, 0, 480, 0);
+                       elm_transit_object_add(transit_flick, view);
+                       elm_transit_duration_set(transit_flick, 0.25 * (480 - x ) /480);
+                       elm_transit_tween_mode_set(transit_flick, ELM_TRANSIT_TWEEN_MODE_LINEAR);
+                       elm_transit_objects_final_state_keep_set(transit_flick, EINA_TRUE);
+                       elm_transit_go(transit_flick);
+
+                       _response_callback_call(view, "deleted");
+               }
+       } else if (info->x1 - info->x2 > 50) {
+               DBG("Flick event is occurred to left.");
+               evas_object_map_set(view, NULL);
+               transit_flick = elm_transit_add();
+               if (transit_flick != NULL) {
+                       elm_transit_effect_translation_add(transit_flick, -x, 0, -480, 0);
+                       elm_transit_object_add(transit_flick, view);
+                       elm_transit_duration_set(transit_flick, 0.25 * ( 480 - x ) / 480);
+                       elm_transit_tween_mode_set(transit_flick, ELM_TRANSIT_TWEEN_MODE_LINEAR);
+                       elm_transit_objects_final_state_keep_set(transit_flick, EINA_TRUE);
+                       elm_transit_go(transit_flick);
+
+                       _response_callback_call(view, "deleted");
+               }
+       }
+
+       return EVAS_EVENT_FLAG_NONE;
+}
+
+HAPI Evas_Object *quickpanel_noti_list_item_create(Evas_Object *parent, notification_h noti)
+{
+       Evas_Object *view = NULL;
+       retif(noti == NULL, NULL, "invalid parameter");
+
+       notification_ly_type_e layout = NOTIFICATION_LY_NOTI_EVENT_SINGLE;
+       notification_get_layout(noti, &layout);
+
+       retif(s_info.view_handlers[layout] == NULL, NULL, "invalid parameter");
+       retif(s_info.view_handlers[layout]->create == NULL, NULL, "invalid parameter");
+
+       view = s_info.view_handlers[layout]->create(noti, parent);
+       if (view != NULL) {
+               noti_list_item_h *handler = (noti_list_item_h *) malloc(sizeof(noti_list_item_h));
+               retif(handler == NULL, NULL, "failed to allocate a memory");
+
+               memset(handler, 0, sizeof(noti_list_item_h));
+
+               handler->layout = layout;
+               handler->status = STATE_NORMAL;
+               handler->noti_node = NULL;
+               handler->state = NOTILISTITEM_STATE_NORMAL;
+
+               _item_handler_set(view, handler);
+
+               Evas_Object *focus = quickpanel_accessibility_ui_get_focus_object(view);
+               elm_object_part_content_set(view, "focus", focus);
+
+               //add event
+               elm_object_signal_callback_add(view,
+                               "selected",
+                               "edje",
+                               _signal_cb,
+                               parent
+                               );
+
+               //add event
+               elm_object_signal_callback_add(view,
+                               "button_1",
+                               "edje",
+                               _signal_cb,
+                               parent
+                               );
+
+               //add event
+               elm_object_signal_callback_add(view,
+                               "deleted",
+                               "edje",
+                               _signal_cb,
+                               parent
+                               );
+
+               DBG("created box:%p", view);
+
+               evas_object_event_callback_add(view, EVAS_CALLBACK_MOUSE_DOWN, _mouse_down_cb, NULL);
+               evas_object_event_callback_add(view, EVAS_CALLBACK_MOUSE_MOVE, _mouse_move_cb, NULL);
+               evas_object_event_callback_add(view, EVAS_CALLBACK_MOUSE_UP, _mouse_up_cb, NULL);
+
+               Evas_Object *gl = elm_gesture_layer_add(parent);
+               elm_gesture_layer_flick_time_limit_ms_set(gl, 300);
+               elm_gesture_layer_attach(gl, view);
+
+               elm_gesture_layer_cb_set(gl, ELM_GESTURE_N_FLICKS, ELM_GESTURE_STATE_END, _flick_end_cb, view);
+       } else {
+               ERR("failed to create notification view(%s)"
+                               , s_info.view_handlers[layout]->name);
+       }
+
+       return view;
+}
+
+HAPI void quickpanel_noti_list_item_update(Evas_Object *item)
+{
+       retif(item == NULL, , "invalid parameter");
+
+       noti_list_item_h *handler = _item_handler_get(item);
+       if (handler != NULL) {
+               retif(s_info.view_handlers[handler->layout] == NULL, , "invalid parameter");
+               retif(s_info.view_handlers[handler->layout]->update == NULL, , "invalid parameter");
+
+               noti_node_item *noti_node = _get_noti_node(item);
+               s_info.view_handlers[handler->layout]->update(noti_node, handler->layout, item);
+       }
+}
+
+HAPI void quickpanel_noti_list_item_remove(Evas_Object *item)
+{
+       retif(item == NULL, , "invalid parameter");
+
+       noti_list_item_h *handler = _item_handler_get(item);
+       if (handler != NULL) {
+               retif(s_info.view_handlers[handler->layout] == NULL, , "invalid parameter");
+
+               if (s_info.view_handlers[handler->layout] != NULL) {
+                       if (s_info.view_handlers[handler->layout]->remove != NULL) {
+                               noti_node_item *noti_node = _get_noti_node(item);
+                               s_info.view_handlers[handler->layout]->remove(noti_node, handler->layout, item);
+                       }
+               }
+
+               free(handler);
+       }
+
+       evas_object_data_del(item, E_DATA_NOTI_LIST_ITEM_H);
+       evas_object_del(item);
+       item = NULL;
+}
+
+HAPI void quickpanel_noti_list_item_set_status(Evas_Object *item, int status)
+{
+       retif(item == NULL, , "invalid parameter");
+
+       noti_list_item_h *handler = _item_handler_get(item);
+       if (handler != NULL) {
+               handler->status = status;
+       }
+}
+
+HAPI int quickpanel_noti_list_item_get_status(Evas_Object *item)
+{
+       retif(item == NULL, STATE_NORMAL, "invalid parameter");
+
+       noti_list_item_h *handler = _item_handler_get(item);
+       if (handler != NULL) {
+               return handler->status;
+       }
+
+       return STATE_DELETING;
+}
+
+HAPI void quickpanel_noti_list_item_node_set(Evas_Object *item, noti_node_item *noti_node)
+{
+       int priv_id = 0;
+       retif(item == NULL, , "invalid parameter");
+       retif(noti_node == NULL, , "invalid parameter");
+
+       noti_list_item_h *handler = _item_handler_get(item);
+       if (handler != NULL) {
+               handler->noti_node = noti_node;
+               notification_get_id(handler->noti_node->noti, NULL, &priv_id);
+               handler->priv_id = priv_id;
+               quickpanel_noti_list_item_update(item);
+       }
+}
+
+HAPI void *quickpanel_noti_list_item_node_get(Evas_Object *item)
+{
+       retif(item == NULL, NULL, "invalid parameter");
+
+       noti_node_item *noti_node = _get_noti_node(item);
+       if (noti_node != NULL) {
+               return noti_node;
+       }
+
+       return NULL;
+}
+
+#ifdef QP_SCREENREADER_ENABLE
+static void _focus_selected_cb(void *data, Evas_Object *obj, void *event_info)
+{
+       Evas_Object *item = data;
+       retif(item == NULL, , "invalid parameter");
+
+       _response_callback_call(item, "selected");
+}
+#endif
+
+HAPI void quickpanel_noti_list_item_set_item_selected_cb(Evas_Object *item, response_cb callback)
+{
+       retif(item == NULL, , "invalid parameter");
+       retif(callback == NULL, , "invalid parameter");
+
+       noti_list_item_h *handler = _item_handler_get(item);
+       if (handler != NULL) {
+               handler->selected_cb = callback;
+       }
+
+#ifdef QP_SCREENREADER_ENABLE
+       Evas_Object *ao = NULL;
+       ao = quickpanel_accessibility_screen_reader_object_get(item,
+                       SCREEN_READER_OBJ_TYPE_ELM_OBJECT, "focus", item);
+       if (ao != NULL) {
+               evas_object_smart_callback_add(ao, "clicked", _focus_selected_cb, item);
+       }
+#endif
+}
+
+HAPI void quickpanel_noti_list_item_set_item_button_1_cb(Evas_Object *item, response_cb callback)
+{
+       retif(item == NULL, , "invalid parameter");
+       retif(callback == NULL, , "invalid parameter");
+
+       noti_list_item_h *handler = _item_handler_get(item);
+       if (handler != NULL) {
+               handler->button_1_cb = callback;
+       }
+}
+
+HAPI void quickpanel_noti_list_item_set_item_deleted_cb(Evas_Object *item, response_cb callback)
+{
+       retif(item == NULL, , "invalid parameter");
+       retif(callback == NULL, , "invalid parameter");
+
+       noti_list_item_h *handler = _item_handler_get(item);
+       if (handler != NULL) {
+               handler->deleted_cb = callback;
+       }
+}
+
+HAPI noti_list_item_h *quickpanel_noti_list_item_handler_get(Evas_Object *item)
+{
+       return _item_handler_get(item);
+}
diff --git a/daemon/notifications/noti_list_item.h b/daemon/notifications/noti_list_item.h
new file mode 100755 (executable)
index 0000000..616579b
--- /dev/null
@@ -0,0 +1,83 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __QUICKPANEL_NOTI_LIST_ITEM_H__
+#define __QUICKPANEL_NOTI_LIST_ITEM_H__
+
+#define STATE_NORMAL 1
+#define STATE_DELETING 0
+
+#define E_DATA_NOTI_LIST_ITEM_H "noti_list_item"
+
+typedef Evas_Object *(*creater_cb)(notification_h, Evas_Object *);
+typedef void (*action_cb)(noti_node_item *, notification_ly_type_e, Evas_Object *);
+typedef void (*response_cb)(noti_node_item *, Evas_Object *);
+
+typedef enum _qp_notilistitem_state_type {
+       NOTILISTITEM_STATE_NORMAL = 0,
+       NOTILISTITEM_STATE_GETSTURE_WAIT,
+       NOTILISTITEM_STATE_GETSTURE_CANCELED,
+       NOTILISTITEM_STATE_DELETED,
+} qp_notilistitem_state_type;
+
+typedef struct _Noti_View_H {
+       char *name;
+
+       /* func */
+       creater_cb create;
+       action_cb update;
+       action_cb remove;
+} Noti_View_H;
+
+typedef struct _noti_list_item_h {
+       int status;
+       int priv_id;
+       notification_ly_type_e layout;
+       noti_node_item *noti_node;
+
+       response_cb selected_cb;
+       response_cb button_1_cb;
+       response_cb deleted_cb;
+
+       QP_VI *vi;
+       Ecore_Animator *animator;
+
+       int obj_w;
+       int obj_h;
+       int press_x;
+       int press_y;
+       int distance;
+       int need_to_cancel_press;
+       qp_notilistitem_state_type state;
+} noti_list_item_h;
+
+extern Evas_Object *quickpanel_noti_list_item_create(Evas_Object *parent, notification_h noti);
+extern void quickpanel_noti_list_item_update(Evas_Object *item);
+extern void quickpanel_noti_list_item_remove(Evas_Object *item);
+
+extern void quickpanel_noti_list_item_node_set(Evas_Object *item, noti_node_item *noti_node);
+extern void *quickpanel_noti_list_item_node_get(Evas_Object *item);
+extern int quickpanel_noti_list_item_get_status(Evas_Object *item);
+extern void quickpanel_noti_list_item_set_status(Evas_Object *item, int status);
+
+extern void quickpanel_noti_list_item_set_item_selected_cb(Evas_Object *item, response_cb selected_cb);
+extern void quickpanel_noti_list_item_set_item_button_1_cb(Evas_Object *item, response_cb callback);
+extern void quickpanel_noti_list_item_set_item_deleted_cb(Evas_Object *item, response_cb callback);
+
+extern noti_list_item_h *quickpanel_noti_list_item_handler_get(Evas_Object *item);
+#endif
diff --git a/daemon/notifications/noti_listbox.c b/daemon/notifications/noti_listbox.c
new file mode 100755 (executable)
index 0000000..9c9fdee
--- /dev/null
@@ -0,0 +1,917 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+#include <glib.h>
+
+#include <vconf.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <notification.h>
+#include <system_settings.h>
+#include <E_DBus.h>
+
+#include "quickpanel-ui.h"
+#include "common.h"
+#include "common_uic.h"
+#include "list_util.h"
+#include "quickpanel_def.h"
+#include "noti_listbox.h"
+#include "vi_manager.h"
+#include "noti_node.h"
+#include "noti_list_item.h"
+#include "noti.h"
+
+#define E_DATA_LAYOUT_PORTRAIT "layout_portrait"
+#define E_DATA_LAYOUT_LANDSCAPE "layout_landscape"
+#define E_DATA_CB_DELETE_ITEM "cb_delete_item"
+#define E_DATA_CB_REMOVED "cb_removed"
+#define E_DATA_APP_DATA "app_data"
+#define E_DATA_IS_HIDED "hided"
+
+static Eina_Bool _anim_init_cb(void *data);
+static Eina_Bool _anim_job_cb(void *data);
+static Eina_Bool _anim_done_cb(void *data);
+
+static void _listbox_flag_set(Evas_Object *container, const char *key, int value)
+{
+       retif(container == NULL, , "invalid parameter");
+       retif(key == NULL, , "invalid parameter");
+
+       evas_object_data_set(container, key, (void *)(long)value);
+}
+
+static int _listbox_flag_get(Evas_Object *container, const char *key)
+{
+       retif(container == NULL, 0, "invalid parameter");
+       retif(key == NULL, 0, "invalid parameter");
+
+       return (int)(long)evas_object_data_get(container, key);
+}
+
+static int _listbox_layout_item_valid(Evas_Object *container, Evas_Object *item)
+{
+       int ret = 0;
+       Eina_List *list = NULL;
+       retif(container == NULL, 0, "invalid parameter");
+       list = elm_box_children_get(container);
+       retif(list == NULL, 0, "invalid parameter. containter[%p]", container);
+
+       if (eina_list_data_find(list, item) != NULL) {
+               ret = 1;
+       }
+
+       eina_list_free(list);
+
+       return ret;
+}
+
+static void _listbox_layout_get_coord(Evas_Object *container, int insert_position, int *coord_x, int *coord_y, Evas_Object *noti_section)
+{
+       int x, y, h;
+       int off_y = 0;
+       struct appdata *ad = quickpanel_get_app_data();
+
+       retif(container == NULL, , "invalid parameter");
+       retif(ad == NULL, , "invalid data.");
+
+       if (insert_position == 0) {
+               Eina_List *l;
+               Eina_List *l_next;
+               Evas_Object *obj = NULL;
+               Eina_List *item_list = elm_box_children_get(container);
+               noti_node_item *node = NULL;
+               notification_type_e type = NOTIFICATION_TYPE_NONE;
+
+               EINA_LIST_FOREACH_SAFE(item_list, l, l_next, obj) {
+                       node = quickpanel_noti_list_item_node_get(obj);
+                       if (node) {
+                               notification_h noti = node->noti;
+                               if (noti) {
+                                       notification_get_type(noti, &type);
+                                       if (type == NOTIFICATION_TYPE_NOTI) {
+                                               break;
+                                       } else {
+                                               evas_object_geometry_get(obj, NULL, NULL, NULL, &h);
+                                               off_y += h;
+                                       }
+                               }
+                       } else {
+                               evas_object_geometry_get(obj, NULL, NULL, NULL, &h);
+                               off_y += h;
+                       }
+               }
+
+               if (item_list != NULL) {
+                       eina_list_free(item_list);
+               }
+       }
+       else if (insert_position == 1) {
+               Eina_List *l;
+               Eina_List *l_next;
+               Evas_Object *obj = NULL;
+               Eina_List *item_list = elm_box_children_get(container);
+
+               EINA_LIST_FOREACH_SAFE(item_list, l, l_next, obj) {
+                       if (obj != NULL) {
+                               evas_object_geometry_get(obj, NULL, NULL, NULL, &h);
+                               off_y += h;
+                       }
+                       if (obj == noti_section) {
+                               break;
+                       }
+               }
+
+               if (item_list != NULL) {
+                       eina_list_free(item_list);
+               }
+       }
+
+       evas_object_geometry_get(container, &x, &y, NULL, &h);
+       if (off_y == 0 || y == 0) {
+               ERR("Failed get a valid height offset : %d %d", off_y, y);
+       }
+
+       if (coord_x != NULL) {
+               *coord_x = x;
+       }
+       if (coord_y != NULL) {
+               *coord_y = y + off_y;
+       }
+}
+
+static void _listbox_layout_size_get(Evas_Object *container, int *w, int *h)
+{
+       int h_temp = 0;
+       int w_item = 0, h_item = 0;
+       Evas_Object *obj = NULL;
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "invalid data.");
+       retif(container == NULL, , "invalid parameter");
+
+       Eina_List *item_list = elm_box_children_get(container);
+
+       EINA_LIST_FREE(item_list, obj)
+       {
+               if (obj != NULL) {
+                       evas_object_geometry_get(obj, NULL, NULL, NULL, &h_temp);
+                       h_item += h_temp;
+               }
+       }
+       evas_object_geometry_get(container, NULL, NULL, &w_item, NULL);
+
+       if (w != NULL) {
+               *w = w_item;
+       }
+       if (h != NULL) {
+               *h = h_item;
+       }
+}
+
+HAPI Evas_Object *quickpanel_noti_listbox_create(Evas_Object *parent, void *data, qp_item_type_e item_type)
+{
+
+       struct appdata *ad = data;
+       Evas_Object *listbox = NULL;
+
+       retif(parent == NULL, NULL, "invalid parameter");
+       retif(data == NULL, NULL, "invalid parameter");
+
+       listbox = elm_box_add(parent);
+       evas_object_size_hint_weight_set(listbox, EVAS_HINT_EXPAND,
+                       EVAS_HINT_EXPAND);
+       evas_object_size_hint_align_set(listbox, EVAS_HINT_FILL, EVAS_HINT_FILL);
+       elm_box_horizontal_set(listbox, EINA_FALSE);
+       evas_object_show(listbox);
+
+       evas_object_data_set(listbox, E_DATA_CB_DELETE_ITEM, NULL);
+       evas_object_data_set(listbox, E_DATA_APP_DATA, ad);
+       _listbox_flag_set(listbox, E_DATA_IS_HIDED, 0);
+
+       qp_item_data *qid
+               = quickpanel_list_util_item_new(item_type, NULL);
+       quickpanel_list_util_item_set_tag(listbox, qid);
+
+       return listbox;
+}
+
+HAPI void quickpanel_noti_listbox_remove(Evas_Object *listbox)
+{
+       retif(listbox == NULL, , "invalid parameter");
+
+       quickpanel_noti_listbox_remove_all_item(listbox, 0);
+       evas_object_data_del(listbox, E_DATA_CB_DELETE_ITEM);
+       evas_object_data_del(listbox, E_DATA_APP_DATA);
+       quickpanel_list_util_item_del_tag(listbox);
+       evas_object_del(listbox);
+       listbox = NULL;
+}
+
+HAPI void quickpanel_noti_listbox_set_item_deleted_cb(Evas_Object *listbox, void(*deleted_cb)(void *data, Evas_Object *obj))
+{
+       retif(listbox == NULL, , "invalid parameter");
+       retif(deleted_cb == NULL, , "invalid parameter");
+
+       evas_object_data_set(listbox, E_DATA_CB_DELETE_ITEM, deleted_cb);
+}
+
+static void _listbox_call_item_deleted_cb(Evas_Object *listbox, void *data, Evas_Object *obj)
+{
+       retif(listbox == NULL, , "invalid parameter");
+
+       void (*deleted_cb)(void *data, Evas_Object *obj) = NULL;
+
+       deleted_cb = evas_object_data_get(listbox, E_DATA_CB_DELETE_ITEM);
+
+       if (deleted_cb != NULL) {
+               deleted_cb(data, obj);
+       }
+}
+
+HAPI void quickpanel_noti_listbox_add_item(Evas_Object *listbox, Evas_Object *item, int insert_pos, Evas_Object *noti_section)
+{
+       QP_VI *vi = NULL;
+       const char *signal = NULL;
+       retif(listbox == NULL, , "invalid parameter");
+       retif(item == NULL, , "invalid parameter");
+
+       struct appdata *ad = evas_object_data_get(listbox, E_DATA_APP_DATA);
+
+       if (ad != NULL) {
+               if (ad->angle == 270 || ad->angle == 90) {
+                       signal = "box.landscape";
+               } else {
+                       signal = "box.portrait";
+               }
+       }
+
+       DBG("set to %s, %x", signal, item);
+
+       elm_object_signal_emit(item, signal, "box.prog");
+       edje_object_message_signal_process(_EDJ(item));
+       elm_layout_sizing_eval(item);
+
+       vi = quickpanel_vi_new_with_data(
+                       VI_OP_INSERT,
+                       QP_ITEM_TYPE_ONGOING_NOTI,
+                       listbox,
+                       item,
+                       _anim_init_cb,
+                       _anim_job_cb,
+                       _anim_done_cb,
+                       _anim_done_cb,
+                       vi,
+                       noti_section,
+                       insert_pos,
+                       0);
+       quickpanel_vi_start(vi);
+}
+
+HAPI void quickpanel_noti_listbox_remove_item(Evas_Object *listbox, Evas_Object *item, int with_animation)
+{
+       QP_VI *vi = NULL;
+       retif(listbox == NULL, , "invalid parameter");
+       retif(item == NULL, , "invalid parameter");
+
+
+       DBG("remove:%p", item);
+
+       if (with_animation == 1) {
+               vi = quickpanel_vi_new_with_data(
+                               VI_OP_DELETE,
+                               QP_ITEM_TYPE_ONGOING_NOTI,
+                               listbox,
+                               item,
+                               _anim_init_cb,
+                               _anim_job_cb,
+                               _anim_done_cb,
+                               _anim_done_cb,
+                               vi,
+                               NULL,
+                               0,
+                               0);
+               quickpanel_vi_start(vi);
+       } else {
+               DBG("%p", item);
+               void *node = quickpanel_noti_list_item_node_get(item);
+               elm_box_unpack(listbox, item);
+               quickpanel_noti_list_item_remove(item);
+               _listbox_call_item_deleted_cb(listbox,
+                               node, NULL);
+       }
+}
+
+static void _anim_job_delete_all(void *data)
+{
+       QP_VI *vi = data;
+       retif(vi == NULL, , "invalid parameter");
+
+       quickpanel_vi_done(vi);
+}
+
+static void _anim_done_delete_all(void *data)
+{
+       QP_VI *vi = data;
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *obj = NULL;
+       Eina_List *item_list = NULL;
+
+       retif(vi == NULL, , "invalid parameter");
+       retif(vi->container == NULL, , "invalid parameter");
+
+       Evas_Object *listbox = vi->container;
+
+       item_list = elm_box_children_get(listbox);
+       retif(item_list == NULL, , "invalid parameter");
+
+       EINA_LIST_FOREACH_SAFE(item_list, l, l_next, obj) {
+               if (obj != NULL) {
+                       DBG("try to remove:%p", obj);
+                       quickpanel_noti_listbox_remove_item(listbox, obj, EINA_TRUE);
+               }
+       }
+
+       if (item_list != NULL) {
+               eina_list_free(item_list);
+       }
+}
+
+HAPI void quickpanel_noti_listbox_remove_all_item(Evas_Object *listbox, int with_animation)
+{
+       QP_VI *vi = NULL;
+       retif(listbox == NULL, , "invalid parameter");
+
+       vi = quickpanel_vi_new_with_data(
+                       VI_OP_DELETE_ALL,
+                       QP_ITEM_TYPE_ONGOING_NOTI,
+                       listbox,
+                       NULL,
+                       _anim_init_cb,
+                       _anim_job_cb,
+                       _anim_done_cb,
+                       _anim_done_cb,
+                       vi,
+                       NULL,
+                       0,
+                       0);
+       quickpanel_vi_start(vi);
+}
+
+HAPI void quickpanel_noti_listbox_update(Evas_Object *listbox)
+{
+       retif(listbox == NULL, , "invalid parameter");
+
+       Evas_Object *obj;
+       Eina_List *item_list = elm_box_children_get(listbox);
+
+       EINA_LIST_FREE(item_list, obj)
+       {
+               quickpanel_noti_list_item_update(obj);
+       }
+}
+
+HAPI void quickpanel_noti_listbox_items_visibility_set(Evas_Object *listbox, int is_visible)
+{
+       retif(listbox == NULL, , "invalid parameter");
+
+       _listbox_flag_set(listbox, E_DATA_IS_HIDED, is_visible);
+}
+
+HAPI void quickpanel_noti_listbox_update_item(Evas_Object *listbox, Evas_Object *item)
+{
+       retif(listbox == NULL, , "invalid parameter");
+       retif(item == NULL, , "invalid parameter");
+
+       if (_listbox_layout_item_valid(listbox, item)) {
+               quickpanel_noti_list_item_update(item);
+       }
+}
+
+HAPI void quickpanel_noti_listbox_rotation(Evas_Object *listbox, int angle)
+{
+       int h = 0;
+       Evas_Object *obj = NULL;
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "invalid parameter");
+       retif(listbox == NULL, , "invalid parameter");
+
+       Eina_List *item_list = elm_box_children_get(listbox);
+
+       DBG("items in listbox:%d", eina_list_count(item_list));
+
+       EINA_LIST_FREE(item_list, obj)
+       {
+               if (obj != NULL) {
+                       evas_object_geometry_get(obj, NULL, NULL, NULL, &h);
+                       if (angle == 270 || angle == 90) {
+                               evas_object_resize(obj, ad->win_height, h);
+                       } else {
+                               evas_object_resize(obj, ad->win_width, h);
+                       }
+                       elm_layout_sizing_eval(obj);
+               }
+       }
+
+       _listbox_layout_size_get(listbox, NULL, &h);
+
+       if (angle == 270 || angle == 90) {
+               evas_object_resize(listbox, ad->win_height, h);
+       } else {
+               evas_object_resize(listbox, ad->win_width, h);
+       }
+       DBG("listbox has been rotated to %d", angle);
+}
+
+HAPI int quickpanel_noti_listbox_get_item_count(Evas_Object *listbox)
+{
+       int item_count = 0;
+       Eina_List *items = NULL;
+       retif(listbox == NULL, 0, "invalid parameter");
+
+       if ((items = elm_box_children_get(listbox)) != NULL) {
+               item_count = eina_list_count(items);
+               eina_list_free(items);
+               return item_count;
+       } else {
+               return 0;
+       }
+}
+
+static void _anim_init_insert(void *data)
+{
+
+       QP_VI *vi = data;
+       retif(vi == NULL, , "invalid parameter");
+       retif(vi->container == NULL, , "invalid parameter");
+       retif(vi->target == NULL, , "invalid parameter");
+
+       Evas_Object *container = vi->container;
+       Evas_Object *item = vi->target;
+
+       evas_object_clip_set(item, evas_object_clip_get(container));
+       evas_object_color_set(item, 0, 0, 0, 0);
+}
+
+static void _anim_job_insert(void *data)
+{
+
+       QP_VI *vi = data;
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *obj = NULL;
+       Eina_List *item_list = NULL;
+       int item_width, item_height = 0;
+       int coord_x = 0, coord_y = 0;
+       int insert_position = 0;
+       Elm_Transit *transit_layout_parent = NULL;
+       Elm_Transit *transit_layout = NULL;
+       Elm_Transit *transit_fadein = NULL;
+       Evas_Object *container = NULL;
+       Evas_Object *item = NULL;
+       int flag = 0;
+       noti_node_item *node = NULL;
+       notification_type_e type = NOTIFICATION_TYPE_NONE;
+
+       retif(vi == NULL, , "invalid parameter");
+       retif(vi->container == NULL, , "invalid parameter");
+       retif(vi->target == NULL, , "invalid parameter");
+
+       container = vi->container;
+       item = vi->target;
+       insert_position = vi->extra_flag_1;
+       item_list = elm_box_children_get(container);
+
+       _listbox_layout_get_coord(container, insert_position, &coord_x, &coord_y, (Evas_Object *)vi->extra_data_2);
+       evas_object_move(item, coord_x, coord_y);
+
+       evas_object_geometry_get(item, NULL, NULL, &item_width, &item_height);
+       if (item_width == 0 && item_height == 0) {
+               ERR("failed to get a size of item %d %d", item_width, item_height);
+               evas_object_size_hint_min_get (item, &item_width, &item_height);
+       }
+
+       transit_layout_parent = quickpanel_list_util_get_reorder_transit(container, NULL, item_height);
+
+       if (insert_position) {
+               EINA_LIST_FOREACH_SAFE(item_list, l, l_next, obj) {
+                       if (obj == (Evas_Object *)vi->extra_data_2) {
+                               flag = 1;
+                       }
+                       else if (flag == 1) {
+                               transit_layout = elm_transit_add();
+                               if (transit_layout != NULL) {
+                                       elm_transit_effect_translation_add(transit_layout, 0, 0, 0, item_height);
+                                       elm_transit_object_add(transit_layout, obj);
+                                       elm_transit_duration_set(transit_layout,
+                                                       quickpanel_vim_get_duration(VI_OP_REORDER));
+                                       elm_transit_tween_mode_set(transit_layout,
+                                                       quickpanel_vim_get_tweenmode(VI_OP_REORDER));
+                                       elm_transit_objects_final_state_keep_set(transit_layout, EINA_TRUE);
+
+                                       elm_transit_go(transit_layout);
+                               } else {
+                                       ERR("failed to create a transit");
+                               }
+                       }
+               }
+       }
+       else if (insert_position == 0) {
+               EINA_LIST_FOREACH_SAFE(item_list, l, l_next, obj) {
+                       node = quickpanel_noti_list_item_node_get(obj);
+                       if (node) {
+                               notification_h noti = node->noti;
+                               if (noti) {
+                                       notification_get_type(noti, &type);
+                                       if (type == NOTIFICATION_TYPE_NOTI) {
+                                               flag = 1;
+                                       }
+                               }
+                       }
+                       if (flag == 1) {
+                               transit_layout = elm_transit_add();
+                               if (transit_layout != NULL) {
+                                       elm_transit_effect_translation_add(transit_layout, 0, 0, 0, item_height);
+                                       elm_transit_object_add(transit_layout, obj);
+                                       elm_transit_duration_set(transit_layout,
+                                                       quickpanel_vim_get_duration(VI_OP_REORDER));
+                                       elm_transit_tween_mode_set(transit_layout,
+                                                       quickpanel_vim_get_tweenmode(VI_OP_REORDER));
+                                       elm_transit_objects_final_state_keep_set(transit_layout, EINA_TRUE);
+
+                                       elm_transit_go(transit_layout);
+                               } else {
+                                       ERR("failed to create a transit");
+                               }
+                       }
+               }
+       }
+
+       if (item_list != NULL) {
+               eina_list_free(item_list);
+       }
+
+       transit_fadein = elm_transit_add();
+       if (transit_fadein != NULL) {
+               elm_transit_object_add(transit_fadein, item);
+               elm_transit_effect_color_add(transit_fadein, 0, 0, 0, 0, 255, 255, 255, 255);
+               elm_transit_duration_set(transit_fadein,
+                               quickpanel_vim_get_duration(VI_OP_INSERT));
+               elm_transit_tween_mode_set(transit_fadein,
+                               quickpanel_vim_get_tweenmode(VI_OP_INSERT));
+               elm_transit_del_cb_set(transit_fadein, quickpanel_vi_done_cb_for_transit, vi);
+
+               if (transit_layout != NULL) {
+                       elm_transit_chain_transit_add(transit_layout, transit_fadein);
+               } else {
+                       if (transit_layout_parent != NULL) {
+                               elm_transit_chain_transit_add(transit_layout_parent, transit_fadein);
+                       } else {
+                               elm_transit_go(transit_fadein);
+                       }
+               }
+       } else {
+               ERR("Failed to create all the transit");
+               quickpanel_vi_done(vi);
+       }
+}
+
+static void _anim_done_insert(void *data)
+{
+
+       QP_VI *vi = data;
+       int inset_position = 0;
+       Eina_List *l;
+       Eina_List *l_next;
+       Eina_List *item_list = NULL;
+       Evas_Object *obj = NULL;
+       noti_node_item *node = NULL;
+       notification_type_e type = NOTIFICATION_TYPE_NONE;
+       int flag = 0;
+
+       retif(vi == NULL, , "invalid parameter");
+       retif(vi->container == NULL, , "invalid parameter");
+       retif(vi->target == NULL, , "invalid parameter");
+
+       Evas_Object *container = vi->container;
+       Evas_Object *item = vi->target;
+       inset_position = vi->extra_flag_1;
+       item_list = elm_box_children_get(container);
+
+       evas_object_color_set(item, 255, 255, 255, 255);
+
+       if (inset_position == LISTBOX_PREPEND) {
+               EINA_LIST_FOREACH_SAFE(item_list, l, l_next, obj) {
+                       if (obj == (Evas_Object *)vi->extra_data_2) {
+                               elm_box_pack_after(container, item, obj);
+                               break;
+                       }
+               }
+       } else if (inset_position == LISTBOX_APPEND) {
+               EINA_LIST_FOREACH_SAFE(item_list, l, l_next, obj) {
+                       node = quickpanel_noti_list_item_node_get(obj);
+                       if (node) {
+                               notification_h noti = node->noti;
+                               if (noti) {
+                                       notification_get_type(noti, &type);
+                                       if (type == NOTIFICATION_TYPE_NOTI) {
+                                               //node_first_noti = node;
+                                               elm_box_pack_before(container, item, obj);
+                                               flag = 1;
+                                               break;
+                                       }
+                               }
+                       }
+               }
+               if (flag == 0) {
+                       elm_box_pack_end(container, item);
+               }
+       } else {
+               int ongoing_count = quickpanel_noti_get_type_count(NOTIFICATION_TYPE_ONGOING);
+               DBG("NOTI INSERT AT: %d", ongoing_count);
+
+               if (ongoing_count == 0) {
+                       DBG("NOTI INSERT START");
+                       elm_box_pack_start(container, item);
+               } else {
+                       Eina_List *items = elm_box_children_get(container);
+                       if (!items) {
+                               ERR("Failed to recieve container items, adding new notification to end of the list");
+                               elm_box_pack_end(container, item);
+                               return;
+                       }
+
+                       Evas_Object *before = eina_list_nth (items, ongoing_count - 1);
+                       if (!before) {
+                               ERR("Failed to recieve preceding item, adding new notification to end of the list");
+                               elm_box_pack_end(container, item);
+                               return;
+                       }
+
+                       DBG("NOTI INSERT BEFORE: %p", before);
+                       elm_box_pack_after(container, item, before);
+               }
+       }
+}
+
+static void _anim_job_delete(void *data)
+{
+       QP_VI *vi = data;
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *obj = NULL;
+       Eina_List *item_list = NULL;
+       int is_start_relayout = 0;
+       int item_width, item_height = 0;
+       Elm_Transit *transit_layout_parent = NULL;
+       Elm_Transit *transit_layout = NULL;
+       Elm_Transit *transit_fadeout = NULL;
+       Evas_Object *container = NULL;
+       Evas_Object *item = NULL;
+
+       retif(vi == NULL, , "invalid parameter");
+       retif(vi->container == NULL, , "invalid parameter");
+       retif(vi->target == NULL, , "invalid parameter");
+
+       container = vi->container;
+       item = vi->target;
+       item_list = elm_box_children_get(container);
+
+       evas_object_geometry_get(item, NULL, NULL, &item_width, &item_height);
+       if (item_width == 0 && item_height == 0) {
+               ERR("failed to get a size of item %d %d", item_width, item_height);
+               evas_object_size_hint_min_get (item, &item_width, &item_height);
+       }
+
+       transit_fadeout = elm_transit_add();
+       if (transit_fadeout != NULL) {
+               elm_transit_object_add(transit_fadeout, item);
+               elm_transit_effect_color_add(transit_fadeout, 255, 255, 255, 255, 0, 0, 0, 0);
+               elm_transit_objects_final_state_keep_set(transit_fadeout, EINA_TRUE);
+               elm_transit_duration_set(transit_fadeout, quickpanel_vim_get_duration(VI_OP_DELETE));
+               elm_transit_go(transit_fadeout);
+       } else {
+               ERR("failed to create a transit");
+       }
+
+       EINA_LIST_FOREACH_SAFE(item_list, l, l_next, obj) {
+               if (obj == item) {
+                       is_start_relayout = 1;
+               } else if (obj != NULL && is_start_relayout == 1) {
+                       transit_layout = elm_transit_add();
+                       if (transit_layout != NULL) {
+                               elm_transit_effect_translation_add(transit_layout, 0, 0, 0, -item_height);
+                               elm_transit_object_add(transit_layout, obj);
+                               elm_transit_duration_set(transit_layout,
+                                               quickpanel_vim_get_duration(VI_OP_REORDER));
+                               elm_transit_tween_mode_set(transit_layout,
+                                               quickpanel_vim_get_tweenmode(VI_OP_REORDER));
+                               elm_transit_objects_final_state_keep_set(transit_layout, EINA_TRUE);
+                               if (transit_fadeout != NULL) {
+                                       elm_transit_chain_transit_add(transit_fadeout, transit_layout);
+                               }
+                       } else {
+                               ERR("failed to create a transit");
+                       }
+               }
+       }
+
+       if (item_list != NULL) {
+               eina_list_free(item_list);
+       }
+
+       transit_layout_parent = quickpanel_list_util_get_reorder_transit(container,
+                       transit_fadeout, -item_height);
+
+       if (transit_layout_parent != NULL) {
+               elm_transit_del_cb_set(transit_layout_parent, quickpanel_vi_done_cb_for_transit,
+                               vi);
+       } else if (transit_layout != NULL) {
+               elm_transit_del_cb_set(transit_layout, quickpanel_vi_done_cb_for_transit,
+                               vi);
+       } else if (transit_fadeout != NULL) {
+               elm_transit_del_cb_set(transit_fadeout, quickpanel_vi_done_cb_for_transit,
+                               vi);
+       } else {
+               ERR("Failed to create all the transit");
+               quickpanel_vi_done(vi);
+       }
+}
+
+static void _anim_done_delete(void *data)
+{
+       int w = 0, h = 0;
+       QP_VI *vi = data;
+
+       retif(vi == NULL, , "invalid parameter");
+       retif(vi->container == NULL, , "invalid parameter");
+       retif(vi->target == NULL, , "invalid parameter");
+
+       Evas_Object *container = vi->container;
+       Evas_Object *item = vi->target;
+
+       elm_box_unpack(container, item);
+       quickpanel_noti_list_item_remove(item);
+       _listbox_call_item_deleted_cb(container,
+                       quickpanel_noti_list_item_node_get(item), NULL);
+
+       if (_listbox_flag_get(container, E_DATA_IS_HIDED) == 1) {
+               _listbox_layout_size_get(container, &w, &h);
+               evas_object_resize(container, w, h);
+       }
+}
+
+static Eina_Bool _anim_init_cb(void *data)
+{
+       QP_VI *vi = data;
+       retif(vi == NULL, EINA_FALSE, "invalid parameter");
+
+       static qp_vi_op_table anim_init_table[] = {
+               {
+                       .op_type = VI_OP_INSERT,
+                       .handler = _anim_init_insert,
+               },
+               {
+                       .op_type = VI_OP_NONE,
+                       .handler = NULL,
+               },
+       };
+
+       int i = 0;
+       for (i = 0; anim_init_table[i].op_type != VI_OP_NONE; i++) {
+               if (anim_init_table[i].op_type != vi->op_type) {
+                       continue;
+               }
+
+               anim_init_table[i].handler(vi);
+               break;
+       }
+
+       return EINA_TRUE;
+}
+
+static Eina_Bool _anim_job_cb(void *data)
+{
+       QP_VI *vi = data;
+       retif(vi == NULL, EINA_FALSE, "invalid parameter");
+
+       static qp_vi_op_table anim_job_table[] = {
+               {
+                       .op_type = VI_OP_INSERT,
+                       .handler = _anim_job_insert,
+               },
+               {
+                       .op_type = VI_OP_DELETE,
+                       .handler = _anim_job_delete,
+               },
+               {
+                       .op_type = VI_OP_DELETE_ALL,
+                       .handler = _anim_job_delete_all,
+               },
+               {
+                       .op_type = VI_OP_NONE,
+                       .handler = NULL,
+               },
+       };
+
+       int i = 0;
+       for (i = 0; anim_job_table[i].op_type != VI_OP_NONE; i++) {
+               if (anim_job_table[i].op_type != vi->op_type) {
+                       continue;
+               }
+               anim_job_table[i].handler(vi);
+               break;
+       }
+
+       return EINA_TRUE;
+}
+
+static Eina_Bool _anim_done_cb(void *data)
+{
+       QP_VI *vi = data;
+       retif(vi == NULL, EINA_FALSE, "invalid parameter");
+
+       static qp_vi_op_table anim_done_table[] = {
+               {
+                       .op_type = VI_OP_INSERT,
+                       .handler = _anim_done_insert,
+               },
+               {
+                       .op_type = VI_OP_DELETE,
+                       .handler = _anim_done_delete,
+               },
+               {
+                       .op_type = VI_OP_DELETE_ALL,
+                       .handler = _anim_done_delete_all,
+               },
+               {
+                       .op_type = VI_OP_NONE,
+                       .handler = NULL,
+               },
+       };
+
+       int i = 0;
+       for (i = 0; anim_done_table[i].op_type != VI_OP_NONE; i++) {
+               if (anim_done_table[i].op_type != vi->op_type) {
+                       continue;
+               }
+
+               anim_done_table[i].handler(vi);
+               break;
+       }
+
+       return EINA_TRUE;
+}
+
+HAPI int quickpanel_noti_listbox_get_geometry(Evas_Object *listbox, int *limit_h, int *limit_partial_h, int *limit_partial_w)
+{
+
+       int x = 0, y = 0, w = 0, h = 0;
+
+       retif(listbox == NULL, 0, "invalid parameter");
+       retif(limit_h == NULL, 0, "invalid parameter");
+       retif(limit_partial_h == NULL, 0, "invalid parameter");
+       retif(limit_partial_w == NULL, 0, "invalid parameter");
+       evas_object_geometry_get(listbox, &x, &y, &w, &h);
+
+       *limit_h =  y + h;
+       *limit_partial_h = *limit_h;
+       *limit_partial_w = 0;
+
+       return 1;
+}
+
+static void _notibox_deleted_cb(void *data, Evas *e, Evas_Object *obj, void *event_info)
+{
+       quickpanel_uic_close_quickpanel(EINA_FALSE, EINA_FALSE);
+}
+
+HAPI void quickpanel_noti_listbox_closing_trigger_set(Evas_Object *listbox)
+{
+       Evas_Object *item = NULL;
+       Eina_List *items = NULL;
+       retif(listbox == NULL, , "invalid parameter");
+
+       if ((items = elm_box_children_get(listbox)) != NULL) {
+               item = eina_list_nth(items, 0);
+               if (item != NULL) {
+                       evas_object_event_callback_add(item,
+                                       EVAS_CALLBACK_DEL, _notibox_deleted_cb, NULL);
+               }
+               eina_list_free(items);
+       }
+}
diff --git a/daemon/notifications/noti_listbox.h b/daemon/notifications/noti_listbox.h
new file mode 100755 (executable)
index 0000000..608213f
--- /dev/null
@@ -0,0 +1,40 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __QUICKPANEL_NOTI_LISTBOX_H__
+#define __QUICKPANEL_NOTI_LISTBOX_H__
+
+#define LISTBOX_INSERT_AFTER -1
+#define LISTBOX_PREPEND 1
+#define LISTBOX_APPEND 0
+
+extern Evas_Object *quickpanel_noti_listbox_create(Evas_Object *parent, void *data, qp_item_type_e item_type);
+extern void quickpanel_noti_listbox_remove(Evas_Object *listbox);
+extern void quickpanel_noti_listbox_add_item(Evas_Object *listbox, Evas_Object *item, int is_prepend, Evas_Object *noti_section);
+extern void quickpanel_noti_listbox_remove_item(Evas_Object *listbox, Evas_Object *item, int with_animation);
+extern void quickpanel_noti_listbox_rotation(Evas_Object *listbox, int angle);
+extern void quickpanel_noti_listbox_remove_all_item(Evas_Object *listbox, int with_animation);
+extern void quickpanel_noti_listbox_set_item_deleted_cb(Evas_Object *listbox, void(*deleted_cb)(void *data, Evas_Object *obj));
+extern void quickpanel_noti_listbox_update(Evas_Object *listbox);
+extern void quickpanel_noti_listbox_update_item(Evas_Object *listbox, Evas_Object *item);
+extern int quickpanel_noti_listbox_get_item_count(Evas_Object *listbox);
+extern void quickpanel_noti_listbox_items_visibility_set(Evas_Object *listbox, int is_visible);
+extern int quickpanel_noti_listbox_get_geometry(Evas_Object *listbox, int *limit_h, int *limit_partial_h, int *limit_partial_w);
+extern void quickpanel_noti_listbox_closing_trigger_set(Evas_Object *listbox);
+
+#endif
diff --git a/daemon/notifications/noti_node.c b/daemon/notifications/noti_node.c
new file mode 100755 (executable)
index 0000000..89ad802
--- /dev/null
@@ -0,0 +1,170 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+#include <glib.h>
+
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <notification.h>
+#include <notification_internal.h>
+#include <E_DBus.h>
+
+#include "quickpanel-ui.h"
+#include "common.h"
+#include "list_util.h"
+#include "noti_node.h"
+
+static void _noti_node_free(noti_node_item *node);
+
+HAPI void quickpanel_noti_node_create(noti_node **handle)
+{
+       retif(handle == NULL, , "Invalid parameter!");
+
+       *handle = (noti_node *)malloc(sizeof(noti_node));
+
+       if (*handle != NULL) {
+               (*handle)->table = g_hash_table_new_full(g_direct_hash, g_direct_equal, NULL, (GDestroyNotify)_noti_node_free);
+               (*handle)->n_ongoing = 0;
+               (*handle)->n_noti = 0;
+       } else {
+               *handle = NULL;
+       }
+}
+
+HAPI void quickpanel_noti_node_destroy(noti_node **handle)
+{
+       retif(handle == NULL, , "Invalid parameter!");
+       retif(*handle == NULL, , "Invalid parameter!");
+
+       g_hash_table_remove_all((*handle)->table);
+       g_hash_table_destroy((*handle)->table);
+       (*handle)->table = NULL;
+
+       free((*handle));
+       *handle = NULL;
+}
+
+HAPI noti_node_item *quickpanel_noti_node_add(noti_node *handle, notification_h noti, void *view)
+{
+       int priv_id = 0;
+       notification_type_e noti_type = NOTIFICATION_TYPE_NONE;
+       noti_node_item *node = NULL;
+
+       retif(handle == NULL || noti == NULL, NULL, "Invalid parameter!");
+
+       if (notification_get_id(noti, NULL, &priv_id) == NOTIFICATION_ERROR_NONE) {
+               node = malloc(sizeof(noti_node_item));
+               if (!node) {
+                       ERR("fail to alloc item");
+                       return NULL;
+               }
+
+               node->noti = noti;
+               node->view = view;
+
+               g_hash_table_insert(handle->table, GINT_TO_POINTER(priv_id), (gpointer *)node);
+
+               notification_get_type(noti, &noti_type);
+
+               if (noti_type == NOTIFICATION_TYPE_NOTI) {
+                       handle->n_noti++;
+               } else if (noti_type == NOTIFICATION_TYPE_ONGOING) {
+                       handle->n_ongoing++;
+               }
+
+               DBG("n_noti = [%d] n_ongoing = [%d]", handle->n_noti, handle->n_ongoing);
+               return node;
+       }
+
+       return NULL;
+}
+
+HAPI void quickpanel_noti_node_remove(noti_node *handle, int priv_id)
+{
+       notification_type_e noti_type = NOTIFICATION_TYPE_NONE;
+
+       retif(handle == NULL, , "Invalid parameter!");
+       retif(handle->table == NULL, , "Invalid parameter!");
+
+       noti_node_item *item = quickpanel_noti_node_get(handle, priv_id);
+
+       if (item != NULL) {
+               if (item->noti != NULL) {
+                       notification_get_type(item->noti, &noti_type);
+
+                       if (noti_type == NOTIFICATION_TYPE_NOTI) {
+                               handle->n_noti--;
+                       } else if (noti_type == NOTIFICATION_TYPE_ONGOING) {
+                               handle->n_ongoing--;
+                       }
+               }
+
+               notification_free(item->noti);
+               item->noti = NULL;
+               item->view = NULL;
+
+               if (g_hash_table_remove(handle->table, GINT_TO_POINTER(priv_id))) {
+                       DBG("success to remove %d", priv_id);
+               }
+       }
+}
+
+HAPI void quickpanel_noti_node_remove_all(noti_node *handle)
+{
+       retif(handle == NULL, , "Invalid parameter!");
+       retif(handle->table == NULL, , "Invalid parameter!");
+
+       g_hash_table_remove_all(handle->table);
+       handle->n_noti = 0;
+       handle->n_ongoing = 0;
+       DBG("all the nodes are removed");
+}
+
+HAPI noti_node_item *quickpanel_noti_node_get(noti_node *handle, int priv_id)
+{
+       retif(handle == NULL, NULL, "Invalid parameter!");
+       retif(handle->table == NULL, NULL, "Invalid parameter!");
+
+       return (noti_node_item *)g_hash_table_lookup(handle->table, GINT_TO_POINTER(priv_id));
+}
+
+HAPI int quickpanel_noti_node_get_item_count(noti_node *handle, notification_type_e noti_type)
+{
+       retif(handle == NULL, 0, "Invalid parameter!");
+
+       DBG("n_noti %d , n_ongoing %d ", handle->n_noti, handle->n_ongoing);
+
+       if (noti_type == NOTIFICATION_TYPE_NOTI) {
+               return handle->n_noti;
+       } else if (noti_type == NOTIFICATION_TYPE_ONGOING) {
+               return handle->n_ongoing;
+       } else if (noti_type == NOTIFICATION_TYPE_NONE) {
+               return handle->n_noti + handle->n_ongoing;
+       }
+
+       return 0;
+}
+
+static void _noti_node_free(noti_node_item *node)
+{
+       retif(node == NULL, , "Invalid parameter!");
+
+       DBG("item_node is freed:%p", node);
+
+       free(node);
+}
diff --git a/daemon/notifications/noti_node.h b/daemon/notifications/noti_node.h
new file mode 100755 (executable)
index 0000000..ffa11c3
--- /dev/null
@@ -0,0 +1,42 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __QUICKPANEL_NOTI_NODE_H__
+#define __QUICKPANEL_NOTI_NODE_H__
+
+typedef struct _noti_node {
+       GHashTable *table;
+       int n_ongoing;
+       int n_noti;
+} noti_node;
+
+typedef struct _noti_node_item {
+       notification_h noti;
+       void *view;
+} noti_node_item;
+
+extern void quickpanel_quickpanel_noti_node_create(noti_node **handle);
+extern void quickpanel_noti_node_destroy(noti_node **handle);
+extern noti_node_item *quickpanel_noti_node_add(noti_node *handle, notification_h noti, void *view);
+extern void quickpanel_noti_node_remove(noti_node *handle, int priv_id);
+extern void quickpanel_noti_node_remove_all(noti_node *handle);
+extern noti_node_item *quickpanel_noti_node_get(noti_node *handle, int priv_id);
+extern int quickpanel_noti_node_get_item_count(noti_node *handle, notification_type_e noti_type);
+extern void quickpanel_noti_node_create(noti_node **handle);
+
+#endif
diff --git a/daemon/notifications/noti_section.c b/daemon/notifications/noti_section.c
new file mode 100755 (executable)
index 0000000..8738a14
--- /dev/null
@@ -0,0 +1,178 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#include <Elementary.h>
+#include <glib.h>
+
+#include <vconf.h>
+#include <notification.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <system_settings.h>
+#include <E_DBus.h>
+
+#include "quickpanel-ui.h"
+#include "quickpanel_def.h"
+#include "common_uic.h"
+#include "common.h"
+#include "noti_node.h"
+#include "noti.h"
+#include "list_util.h"
+#include "noti_section.h"
+
+#ifdef QP_SCREENREADER_ENABLE
+#include "accessibility.h"
+#endif
+
+#define NOTI_CLEAR_ALL_SECTION "quickpanel/notisection/clear_all"
+#define NOTI_DEFAULT_SECTION "quickpanel/notisection/default"
+
+static void _noti_section_set_text(Evas_Object *noti_section, int count)
+{
+       char text[128] = { 0, };
+       char *format;
+       const char *old_text;
+
+       if (!noti_section) {
+               ERR("Invalid parameter");
+               return;
+       }
+
+       DBG("count is : %d ", count);
+       format = _("IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB");
+       snprintf(text, sizeof(text) - 1, format, count);
+
+       old_text = elm_object_part_text_get(noti_section, "elm.text.notifications_number");
+       if (old_text != NULL) {
+               if (strcmp(old_text, text) == 0) {
+                       return;
+               }
+       }
+
+#ifdef QP_SCREENREADER_ENABLE
+       Evas_Object *ao;
+
+       ao = quickpanel_accessibility_screen_reader_object_get(noti_section, SCREEN_READER_OBJ_TYPE_ELM_OBJECT, "focus.label", noti_section);
+       if (ao != NULL) {
+               elm_access_info_set(ao, ELM_ACCESS_TYPE, "");
+               elm_access_info_set(ao, ELM_ACCESS_INFO, text);
+       }
+#endif
+
+       DBG("Trying to set text :%s ", text);
+       elm_object_part_text_set(noti_section, "elm.text.notifications_number", text);
+       elm_object_part_text_set(noti_section, "text.button.clear_all", _("IDS_QP_HEADER_CLEAR_ALL_ABB"));
+}
+
+HAPI Evas_Object *quickpanel_noti_section_create(Evas_Object *parent, qp_item_type_e type)
+{
+       Evas_Object *section;
+       Evas_Object *focus;
+       struct appdata *ad;
+       qp_item_data *qid;
+       Eina_Bool ret;
+
+       ad = quickpanel_get_app_data();
+       if (!ad || !parent) {
+               ERR("Invalid parameter");
+               return NULL;
+       }
+
+       section = elm_layout_add(parent);
+       ret = elm_layout_file_set(section, DEFAULT_EDJ, NOTI_CLEAR_ALL_SECTION);
+       if (ret == EINA_FALSE) {
+               ERR("Failed to set a file");
+               evas_object_del(section);
+               return NULL;
+       }
+
+       evas_object_size_hint_weight_set(section, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       evas_object_size_hint_align_set(section, EVAS_HINT_FILL, EVAS_HINT_FILL);
+       quickpanel_uic_initial_resize(section, QP_THEME_LIST_ITEM_NOTI_SECTION_HEIGHT);
+       evas_object_show(section);
+
+       qid = quickpanel_list_util_item_new(type, NULL);
+       if (!qid) {
+               ERR("Unable to create a qid");
+               evas_object_del(section);
+               return NULL;
+       }
+       quickpanel_list_util_item_set_tag(section, qid);
+       quickpanel_list_util_sort_insert(ad->list, section);
+
+       focus = quickpanel_accessibility_ui_get_focus_object(section);
+       if (!focus) {
+               ERR("Unable to get the focus object");
+               quickpanel_list_util_item_del(qid);
+               evas_object_del(section);
+               return NULL;
+       }
+       elm_object_part_content_set(section, "focus", focus);
+       evas_object_smart_callback_add(focus, "clicked", quickpanel_noti_on_clear_all_clicked, NULL);
+
+       return section;
+}
+
+static void _focus_pair_set(Evas_Object *view)
+{
+       Evas_Object *label = NULL;
+       Evas_Object *button = NULL;
+       retif(view == NULL, , "Invalid parameter!");
+
+       label = elm_object_part_content_get(view, "focus.label");
+       button = elm_object_part_content_get(view, "elm.swallow.icon");
+
+       if (label != NULL && button != NULL) {
+               /* label */
+               elm_object_focus_next_object_set(label, button, ELM_FOCUS_RIGHT);
+               elm_object_focus_next_object_set(label, button, ELM_FOCUS_DOWN);
+
+               /* button */
+               elm_object_focus_next_object_set(button, label, ELM_FOCUS_LEFT);
+               elm_object_focus_next_object_set(button, label, ELM_FOCUS_UP);
+       }
+}
+
+HAPI void quickpanel_noti_section_update(Evas_Object *noti_section, int noti_count)
+{
+       retif(noti_section == NULL, , "invalid parameter");
+
+       _noti_section_set_text(noti_section, noti_count);
+       _focus_pair_set(noti_section);
+
+       quickpanel_noti_set_clear_all_status();
+}
+
+HAPI void quickpanel_noti_section_set_deleted_cb(Evas_Object *noti_section,
+               Evas_Object_Event_Cb func, void *data)
+{
+       retif(noti_section == NULL, , "invalid parameter");
+       retif(func == NULL, , "invalid parameter");
+
+       evas_object_event_callback_add(noti_section, EVAS_CALLBACK_DEL, func, data);
+}
+
+HAPI void quickpanel_noti_section_remove(Evas_Object *noti_section)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "invalid parameter");
+       retif(noti_section == NULL, , "invalid parameter");
+
+       quickpanel_list_util_item_del_tag(noti_section);
+       quickpanel_list_util_item_unpack_by_object(ad->list, noti_section, 0, 0);
+}
diff --git a/daemon/notifications/noti_section.h b/daemon/notifications/noti_section.h
new file mode 100755 (executable)
index 0000000..b9beec9
--- /dev/null
@@ -0,0 +1,26 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#ifndef __QUICKPANEL_NOTI_SECTION_H__
+#define __QUICKPANEL_NOTI_SECTION_H__
+
+extern Evas_Object *quickpanel_noti_section_create(Evas_Object *parent, qp_item_type_e type);
+extern void quickpanel_noti_section_update(Evas_Object *noti_section, int noti_count);
+extern void quickpanel_noti_section_remove(Evas_Object *noti_section) ;
+extern void quickpanel_noti_section_set_deleted_cb(Evas_Object *noti_section, Evas_Object_Event_Cb func, void *data);
+
+#endif
diff --git a/daemon/notifications/noti_util.c b/daemon/notifications/noti_util.c
new file mode 100755 (executable)
index 0000000..a41da37
--- /dev/null
@@ -0,0 +1,298 @@
+/* * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <stdio.h>
+#include <string.h>
+#include <stdlib.h>
+
+#include <Elementary.h>
+#include <E_DBus.h>
+
+#include <unicode/uloc.h>
+#include <unicode/udat.h>
+#include <unicode/udatpg.h>
+#include <unicode/ustring.h>
+
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <runtime_info.h>
+#include <vconf.h>
+#include <system_settings.h>
+#include <notification_list.h>
+#include <E_DBus.h>
+
+#include "quickpanel-ui.h"
+#include "common.h"
+#include "noti_util.h"
+
+#define QP_NOTI_DAY_DEC        (24 * 60 * 60)
+#define QP_NOTI_TIME_LEN_LIMIT 12
+
+HAPI int quickpanel_noti_util_get_event_count_from_noti(notification_h noti)
+{
+       char *text_count = NULL;
+
+       retif(noti == NULL, 0, "Invalid parameter!");
+
+       notification_get_text(noti, NOTIFICATION_TEXT_TYPE_EVENT_COUNT, &text_count);
+       if (text_count != NULL) {
+               return atoi(text_count);
+       }
+       return 1;
+}
+
+HAPI int quickpanel_noti_util_get_event_count_by_pkgname(const char *pkgname)
+{
+       int count = 0;
+       notification_h noti = NULL;
+       notification_list_h noti_list = NULL;
+
+       retif(pkgname == NULL, 0, "Invalid parameter!");
+
+       notification_get_detail_list(pkgname, NOTIFICATION_GROUP_ID_NONE, NOTIFICATION_PRIV_ID_NONE, -1, &noti_list);
+       if (noti_list != NULL) {
+               noti = notification_list_get_data(noti_list);
+               if (noti != NULL) {
+                       count = quickpanel_noti_util_get_event_count_from_noti(noti);
+               }
+               notification_free_list(noti_list);
+               return count;
+       }
+
+       return 0;
+}
+
+static char* _get_locale(void)
+{
+       char locale_tmp[32] = { 0, };
+       char *locale = NULL;
+       int ret = 0;
+
+       ret = system_settings_get_value_string(SYSTEM_SETTINGS_KEY_LOCALE_COUNTRY, &locale);
+       msgif(ret != SYSTEM_SETTINGS_ERROR_NONE, "ailed to set key(%s) : %d", SYSTEM_SETTINGS_KEY_LOCALE_COUNTRY, ret);
+
+
+       if (locale == NULL) {
+               ERR("vconf_get_str() failed : region format");
+               return strdup("en_US");
+       }
+
+       strncpy(locale_tmp, locale, sizeof(locale_tmp) - 1);
+
+       // remove .UTF-8
+       if (strlen(locale_tmp) > 0) {
+               char *p = strstr(locale_tmp, ".UTF-8");
+               if (p) {
+                       *p = 0;
+               }
+       }
+
+       free(locale);
+
+       if (strlen(locale_tmp) > 0) {
+               return strdup(locale_tmp);
+       }
+
+       return strdup("en_US");
+}
+
+static char* _get_timezone_from_vconf(void)
+{
+       char *szTimezone = NULL;
+       szTimezone = vconf_get_str(VCONFKEY_SETAPPL_TIMEZONE_ID);
+       if (szTimezone == NULL) {
+               ERR("Cannot get time zone.");
+               return strdup("N/A");
+       }
+
+       return szTimezone;
+}
+
+static char* _get_timezone(void)
+{
+       char buf[1024] = {0,};
+       ssize_t len = readlink("/opt/etc/localtime", buf, sizeof(buf)-1);
+
+       if (len != -1) {
+               buf[len] = '\0';
+       } else {
+               ERR("failed to get a timezone information");
+               return _get_timezone_from_vconf();
+       }
+
+       return strdup(buf + 20);
+}
+
+HAPI char *quickpanel_noti_util_get_time(time_t t, char *buf, int buf_len)
+{
+       int ret = 0;
+       UErrorCode status = U_ZERO_ERROR;
+       UDate date;
+       UDateTimePatternGenerator *generator = NULL;
+       UDateFormat *formatter = NULL;
+       UChar utimezone_id[40] = {0,};
+       UChar skeleton[40] = { 0 };
+       UChar pattern[40] = { 0 };
+       UChar formatted[40] = { 0 };
+       int32_t patternCapacity, formattedCapacity;
+       int32_t skeletonLength, patternLength;
+       time_t today;
+       struct tm loc_time;
+       char *timezone = NULL;
+       char *locale = NULL;
+       char bf1[32] = { 0, };
+       bool is_24hour_enabled = FALSE;
+       int is_show_time = 0;
+
+       today = time(NULL);
+       localtime_r(&today, &loc_time);
+
+       loc_time.tm_sec = 0;
+       loc_time.tm_min = 0;
+       loc_time.tm_hour = 0;
+       today = mktime(&loc_time);
+
+       localtime_r(&t, &loc_time);
+
+       if (buf == NULL) {
+               return NULL;
+       }
+
+       if (t < today) {
+               /* ascii to unicode for input skeleton */
+               u_uastrcpy(skeleton, UDAT_ABBR_MONTH_DAY);
+               skeletonLength = strlen(UDAT_ABBR_MONTH_DAY);
+               is_show_time = 0;
+       } else {
+               ret = system_settings_get_value_bool(SYSTEM_SETTINGS_KEY_LOCALE_TIMEFORMAT_24HOUR, &is_24hour_enabled);
+
+               if (ret == SYSTEM_SETTINGS_ERROR_NONE && is_24hour_enabled == true) {
+                       /* ascii to unicode for input skeleton */
+                       u_uastrcpy(skeleton, "HHmm");
+                       skeletonLength = strlen("HHmm");
+               } else {
+                       /* ascii to unicode for input skeleton */
+                       u_uastrcpy(skeleton, "hhmm");
+                       skeletonLength = strlen("hhmm");
+               }
+               is_show_time = 1;
+       }
+
+       /* set UDate  from time_t */
+       date = (UDate)t * 1000;
+
+       patternCapacity =
+               (int32_t) (sizeof(pattern) / sizeof((pattern)[0]));
+
+       timezone = _get_timezone();
+       locale = _get_locale();
+
+       if (u_uastrncpy(utimezone_id, timezone, 40) == NULL) {
+               ERR("u_uastrncpy() error.");
+               ret = 0;
+               goto err;
+       }
+
+       ucal_setDefaultTimeZone(utimezone_id , &status);
+       if (U_FAILURE(status)) {
+               ERR("ucal_setDefaultTimeZone() is failed.");
+               ret = 0;
+               goto err;
+       }
+
+#ifdef HAVE___SECURE_GETENV
+       uloc_setDefault(__secure_getenv("LC_TIME"), &status);
+#elif defined HAVE_SECURE_GETENV
+       uloc_setDefault(secure_getenv("LC_TIME"), &status);
+#else
+       uloc_setDefault(getenv("LC_TIME"), &status);
+#endif
+       if (U_FAILURE(status)) {
+               ERR("uloc_setDefault() is failed.");
+               ret = 0;
+               goto err;
+       }
+
+       /* open datetime pattern generator */
+       generator = udatpg_open(locale, &status);
+       if (generator == NULL) {
+               ret = 0;
+               goto err;
+       }
+
+       /* get best pattern using skeleton */
+       patternLength =
+               udatpg_getBestPattern(generator, skeleton, skeletonLength,
+                               pattern, patternCapacity, &status);
+
+       /* open datetime formatter using best pattern */
+       formatter =
+               udat_open(UDAT_IGNORE, UDAT_IGNORE, locale, NULL, -1,
+                               pattern, patternLength, &status);
+       if (formatter == NULL) {
+               ret = 0;
+               goto err;
+       }
+
+       /* calculate formatted string capacity */
+       formattedCapacity =
+               (int32_t) (sizeof(formatted) / sizeof((formatted)[0]));
+
+       /* formatting date using formatter by best pattern */
+       udat_format(formatter, date, formatted, formattedCapacity,
+                       NULL, &status);
+
+       /* unicode to ascii to display */
+       u_austrcpy(bf1, formatted);
+       ret = snprintf(buf, buf_len, "%s", bf1);
+
+       if (is_show_time == 1 && strlen(buf) > QP_NOTI_TIME_LEN_LIMIT) {
+               if (is_24hour_enabled == TRUE) {
+                       ret = strftime(buf, buf_len, "%H:%M", &loc_time);
+               } else {
+                       strftime(bf1, sizeof(bf1), "%l:%M", &loc_time);
+
+                       if (loc_time.tm_hour >= 0 && loc_time.tm_hour < 12) {
+                               ret = snprintf(buf, buf_len, "%s%s", bf1, "AM");
+                       } else {
+                               ret = snprintf(buf, buf_len, "%s%s", bf1, "PM");
+                       }
+               }
+       }
+
+err:
+       if (timezone) {
+               free(timezone);
+               timezone = NULL;
+       }
+
+       if (locale) {
+               free(locale);
+               locale = NULL;
+       }
+
+       if (generator) {
+               udatpg_close(generator);
+               generator = NULL;
+       }
+
+       if (formatter) {
+               udat_close(formatter);
+               formatter = NULL;
+       }
+
+       return ret <= 0 ? NULL : buf;
+}
diff --git a/daemon/notifications/noti_util.h b/daemon/notifications/noti_util.h
new file mode 100755 (executable)
index 0000000..b49b680
--- /dev/null
@@ -0,0 +1,26 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef _QP_NOTI_UTIL_DEF_
+#define _QP_NOTI_UTIL_DEF_
+
+extern int quickpanel_noti_util_get_event_count_from_noti(notification_h noti);
+extern int quickpanel_noti_util_get_event_count_by_pkgname(const char *pkgname);
+extern char *quickpanel_noti_util_get_time(time_t t, char *buf, int buf_len);
+
+#endif
diff --git a/daemon/notifications/noti_view.c b/daemon/notifications/noti_view.c
new file mode 100755 (executable)
index 0000000..8ddbf58
--- /dev/null
@@ -0,0 +1,210 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+#include <glib.h>
+
+#include <string.h>
+#include <vconf.h>
+#include <notification.h>
+#include <system_settings.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "quickpanel-ui.h"
+#include "common.h"
+#include "list_util.h"
+#include "quickpanel_def.h"
+#include "vi_manager.h"
+#include "noti_node.h"
+#include "noti_list_item.h"
+#include "noti.h"
+#include "noti_util.h"
+#include "animated_icon.h"
+#include "noti_list_item.h"
+
+#ifdef QP_SCREENREADER_ENABLE
+#include "accessibility.h"
+#endif
+
+#ifdef QP_ANIMATED_IMAGE_ENABLE
+#include "animated_image.h"
+#endif
+
+#define NOTI_LAYOUT_LISTTYPE 0
+#define NOTI_LAYOUT_BOXTYPE 1
+
+#define E_DATA_VIEW_HANDLER_KEY "view_handler_cache"
+
+extern Noti_View_H noti_view_listtype_h;
+extern Noti_View_H noti_view_boxtype_h;
+
+static struct _info {
+       Noti_View_H *view_handlers[NOTI_LAYOUT_BOXTYPE + 1];
+} s_info = {
+       .view_handlers = {
+               &noti_view_listtype_h,
+               &noti_view_boxtype_h,
+       },
+};
+
+#ifdef BOX_TYPE_SUPPORTED
+static int _is_image_exist(notification_h noti, notification_image_type_e image_type)
+{
+       char *image = NULL;
+
+       notification_get_image(noti, image_type, &image);
+
+       if (image == NULL) {
+               return 0;
+       }
+
+       if (strncasecmp(image, "(null)", strlen(image)) == 0) {
+               return 0;
+       }
+
+       return 1;
+}
+
+static int _is_text_exist(notification_h noti, notification_text_type_e text_type)
+{
+       char *text = NULL;
+
+       notification_get_text(noti, text_type, &text);
+
+       if (text == NULL) {
+               return 0;
+       }
+
+       return 1;
+}
+#endif
+
+static void _view_handler_set(Evas_Object *item, Noti_View_H *handler)
+{
+       retif(item == NULL, , "Invalid parameter!");
+       retif(handler == NULL, , "Invalid parameter!");
+
+       evas_object_data_set(item, E_DATA_VIEW_HANDLER_KEY, handler);
+}
+
+static Noti_View_H *_view_handler_cached_get(Evas_Object *item)
+{
+       retif(item == NULL, NULL, "Invalid parameter!");
+
+       return (Noti_View_H *)evas_object_data_get(item, E_DATA_VIEW_HANDLER_KEY);
+}
+
+static Noti_View_H *_view_handler_get_by_contents(notification_h noti)
+{
+#ifdef BOX_TYPE_SUPPORTED      // Box type is not supported in Kiran
+       int ret = 0;
+
+       ret += _is_text_exist(noti, NOTIFICATION_TEXT_TYPE_INFO_1);
+       ret += _is_text_exist(noti, NOTIFICATION_TEXT_TYPE_INFO_2);
+       ret += _is_image_exist(noti, NOTIFICATION_IMAGE_TYPE_BACKGROUND);
+
+       if (ret > 0) {
+               return s_info.view_handlers[NOTI_LAYOUT_BOXTYPE];
+       }
+#endif
+       return s_info.view_handlers[NOTI_LAYOUT_LISTTYPE];
+}
+
+static void _view_handler_del(Evas_Object *item)
+{
+       retif(item == NULL, , "Invalid parameter!");
+
+       evas_object_data_del(item, E_DATA_VIEW_HANDLER_KEY);
+}
+
+static Evas_Object *_create(notification_h noti, Evas_Object *parent)
+{
+       Evas_Object *view = NULL;
+       Noti_View_H *view_handler = NULL;
+       retif(parent == NULL, NULL, "Invalid parameter!");
+       retif(noti == NULL, NULL, "Invalid parameter!");
+
+       view_handler = _view_handler_get_by_contents(noti);
+       if (view_handler != NULL && view_handler->create != NULL) {
+               view = view_handler->create(noti, parent);
+               if (view == NULL) {
+                       ERR("failed to create notification view(%s)", view_handler->name);
+               } else {
+                       _view_handler_set(view, view_handler);
+               }
+       } else {
+               ERR("create handler isn't supported");
+       }
+
+       return view;
+}
+
+static void _update(noti_node_item *noti_node, notification_ly_type_e layout, Evas_Object *item)
+{
+       Noti_View_H *view_handler = NULL;
+       retif(item == NULL, , "Invalid parameter!");
+       retif(noti_node == NULL, , "Invalid parameter!");
+       retif(noti_node->noti == NULL, , "Invalid parameter!");
+
+       view_handler = _view_handler_get_by_contents(noti_node->noti);
+       if (view_handler != NULL && view_handler->update != NULL) {
+               _view_handler_set(item, view_handler);
+               view_handler->update(noti_node, layout, item);
+       } else {
+               ERR("update handler isn't supported");
+       }
+}
+
+static void _remove(noti_node_item *noti_node, notification_ly_type_e layout, Evas_Object *item)
+{
+       Noti_View_H *view_handler = NULL;
+       retif(item == NULL, , "Invalid parameter!");
+       retif(noti_node == NULL, , "Invalid parameter!");
+       retif(noti_node->noti == NULL, , "Invalid parameter!");
+
+       view_handler = _view_handler_cached_get(item);
+       if (view_handler != NULL && view_handler->remove != NULL) {
+               _view_handler_del(item);
+               view_handler->remove(noti_node, layout, item);
+       } else {
+               ERR("remove handler isn't supported");
+       }
+}
+
+HAPI int quickpanel_noti_view_is_view_handler_changed(Evas_Object *item, notification_h noti)
+{
+       Noti_View_H *view_handler_old = NULL;
+       Noti_View_H *view_handler_new = NULL;
+
+       view_handler_old = _view_handler_cached_get(item);
+       view_handler_new = _view_handler_get_by_contents(noti);
+
+       if (view_handler_old != view_handler_new) {
+               return 1;
+       }
+
+       return 0;
+}
+
+Noti_View_H noti_view_h = {
+       .name                   = "noti_view",
+       .create                 = _create,
+       .update                 = _update,
+       .remove                 = _remove,
+};
diff --git a/daemon/notifications/noti_view.h b/daemon/notifications/noti_view.h
new file mode 100755 (executable)
index 0000000..7c8507a
--- /dev/null
@@ -0,0 +1,24 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef _QP_NOTI_VIEW_H_
+#define _QP_NOTI_VIEW_H_
+
+extern int quickpanel_noti_view_is_view_handler_changed(Evas_Object *item, notification_h noti);
+
+#endif
diff --git a/daemon/notifications/noti_view_listype.c b/daemon/notifications/noti_view_listype.c
new file mode 100755 (executable)
index 0000000..d773c77
--- /dev/null
@@ -0,0 +1,379 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#include <Elementary.h>
+#include <string.h>
+#include <glib.h>
+
+#include <notification.h>
+#include <notification_text_domain.h>
+#include <system_settings.h>
+#include <vconf.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "quickpanel-ui.h"
+#include "common_uic.h"
+#include "common.h"
+#include "list_util.h"
+#include "quickpanel_def.h"
+#include "vi_manager.h"
+#include "noti_node.h"
+#include "noti_list_item.h"
+#include "noti.h"
+#include "noti_util.h"
+#include "animated_icon.h"
+
+#ifdef QP_SCREENREADER_ENABLE
+#include "accessibility.h"
+#endif
+
+#ifdef QP_ANIMATED_IMAGE_ENABLE
+#include "animated_image.h"
+#endif
+
+#define LEN_UNIT_TEXTBLOCK 560
+#define QP_DEFAULT_ICON        RESDIR"/quickpanel_icon_default.png"
+
+#ifdef QP_SCREENREADER_ENABLE
+static inline void _check_and_add_to_buffer(Eina_Strbuf *str_buf, const char *text)
+{
+       char buf_number[QP_UTIL_PHONE_NUMBER_MAX_LEN * 2] = { 0, };
+
+       retif(str_buf == NULL, , "Invalid parameter!");
+
+       if (text != NULL) {
+               if (strlen(text) > 0) {
+                       if (quickpanel_common_util_is_phone_number(text)) {
+                               quickpanel_common_util_phone_number_tts_make(buf_number, text,
+                                               (QP_UTIL_PHONE_NUMBER_MAX_LEN * 2) - 1);
+                               eina_strbuf_append(str_buf, buf_number);
+                       } else {
+                               eina_strbuf_append(str_buf, text);
+                       }
+                       eina_strbuf_append_char(str_buf, '\n');
+               }
+       }
+}
+#endif
+
+static Evas_Object *_check_duplicated_image_loading(Evas_Object *obj, const char *part, const char *file_path)
+{
+       Evas_Object *old_ic = NULL;
+       const char *old_ic_path = NULL;
+
+       retif(obj == NULL, NULL, "Invalid parameter!");
+       retif(part == NULL, NULL, "Invalid parameter!");
+       retif(file_path == NULL, NULL, "Invalid parameter!");
+
+       old_ic = elm_object_part_content_get(obj, part);
+
+       if (quickpanel_animated_icon_is_same_icon(old_ic, file_path) == 1) {
+               return old_ic;
+       }
+
+       if (old_ic != NULL) {
+               elm_image_file_get(old_ic, &old_ic_path, NULL);
+               if (old_ic_path != NULL) {
+                       if (strcmp(old_ic_path, file_path) == 0)
+                               return old_ic;
+               }
+
+               elm_object_part_content_unset(obj, part);
+               evas_object_del(old_ic);
+               old_ic = NULL;
+       }
+
+       return NULL;
+}
+
+static void _set_text_to_part(Evas_Object *obj, const char *part, const char *text)
+{
+       const char *old_text = NULL;
+
+       retif(obj == NULL, , "Invalid parameter!");
+       retif(part == NULL, , "Invalid parameter!");
+       retif(text == NULL, , "Invalid parameter!");
+
+       old_text = elm_object_part_text_get(obj, part);
+       if (old_text != NULL) {
+               if (strcmp(old_text, text) == 0) {
+                       return;
+               }
+       }
+
+       elm_object_part_text_set(obj, part, text);
+}
+
+static void _set_icon(Evas_Object *item, notification_h noti)
+{
+       Evas_Object *ic = NULL;
+       Evas_Object *old_ic = NULL;
+       char *icon_path = NULL;
+       char *icon_sub_path = NULL;
+       char *thumbnail_path = NULL;
+       char *main_icon_path = NULL;
+       char *sub_icon_path = NULL;
+       char *icon_default = NULL;
+       char *pkgname = NULL;
+
+       retif(item == NULL, , "Invalid parameter!");
+       retif(noti == NULL, , "noti is NULL");
+
+       notification_get_pkgname(noti, &pkgname);
+       notification_get_image(noti, NOTIFICATION_IMAGE_TYPE_THUMBNAIL,
+                       &thumbnail_path);
+       notification_get_image(noti, NOTIFICATION_IMAGE_TYPE_ICON, &icon_path);
+       notification_get_image(noti, NOTIFICATION_IMAGE_TYPE_ICON_SUB, &icon_sub_path);
+
+       if (thumbnail_path != NULL && icon_path != NULL) {
+               main_icon_path = thumbnail_path;
+               sub_icon_path = icon_path;
+       } else if (icon_path != NULL && thumbnail_path == NULL) {
+               main_icon_path = icon_path;
+               sub_icon_path = icon_sub_path;
+       } else if (icon_path == NULL && thumbnail_path != NULL) {
+               main_icon_path = thumbnail_path;
+               sub_icon_path = icon_sub_path;
+       } else {
+               icon_default = quickpanel_common_ui_get_pkginfo_icon(pkgname);
+               main_icon_path = icon_default;
+               sub_icon_path = NULL;
+       }
+
+       if (main_icon_path != NULL) {
+               old_ic = _check_duplicated_image_loading(item,
+                               "elm.swallow.thumbnail", main_icon_path);
+
+               if (old_ic == NULL) {
+                       ic = quickpanel_animated_icon_get(item, main_icon_path);
+                       if (ic == NULL) {
+                               ic = elm_image_add(item);
+                               elm_image_resizable_set(ic, EINA_FALSE, EINA_TRUE);
+                               elm_image_file_set(ic, main_icon_path, quickpanel_animated_image_get_groupname(main_icon_path));
+#ifdef QP_ANIMATED_IMAGE_ENABLE
+                               quickpanel_animated_image_add(ic);
+#endif
+
+                               if (!strncmp(main_icon_path, QP_PRELOAD_NOTI_ICON_PATH, strlen(QP_PRELOAD_NOTI_ICON_PATH)))     {
+                                       DBG("Apply color theme [%s]", main_icon_path);
+                                       evas_object_color_set(ic, 155, 216, 226, 255);
+                               } else {
+                                       elm_image_aspect_fixed_set(ic, EINA_TRUE);
+                               }
+                       }
+                       elm_object_part_content_set(item, "elm.swallow.thumbnail", ic);
+               }
+       }
+
+       if (sub_icon_path != NULL) {
+               old_ic = _check_duplicated_image_loading(item,
+                               "elm.swallow.icon", sub_icon_path);
+
+               if (old_ic == NULL) {
+                       ic = elm_image_add(item);
+                       elm_image_resizable_set(ic, EINA_FALSE, EINA_TRUE);
+                       elm_image_file_set(ic, sub_icon_path, quickpanel_animated_image_get_groupname(sub_icon_path));
+                       elm_object_part_content_set(item, "elm.swallow.icon", ic);
+                       elm_object_signal_emit(item, "elm.icon.bg.show", "elm");
+               }
+       }
+
+       if (main_icon_path == NULL && sub_icon_path == NULL) {
+               old_ic = _check_duplicated_image_loading(item,
+                               "elm.swallow.thumbnail", QP_DEFAULT_ICON);
+
+               if (old_ic == NULL) {
+                       ic = elm_image_add(item);
+                       elm_image_resizable_set(ic, EINA_FALSE, EINA_TRUE);
+                       elm_image_file_set(ic, QP_DEFAULT_ICON, quickpanel_animated_image_get_groupname(QP_DEFAULT_ICON));
+                       elm_object_part_content_set(item, "elm.swallow.thumbnail", ic);
+#ifdef QP_ANIMATED_IMAGE_ENABLE
+                       quickpanel_animated_image_add(ic);
+#endif
+               }
+       }
+
+       if (icon_default != NULL) {
+               free(icon_default);
+       }
+}
+
+static void _set_text(Evas_Object *item, notification_h noti)
+{
+       int noti_err = NOTIFICATION_ERROR_NONE;
+       char *text = NULL;
+       char *domain = NULL;
+       char *dir = NULL;
+       time_t noti_time;
+       char buf[512] = {0,};
+#ifdef QP_SCREENREADER_ENABLE
+       Evas_Object *ao = NULL;
+       Eina_Strbuf *str_buf = NULL;
+#endif
+       struct appdata *ad = quickpanel_get_app_data();
+
+       retif(ad == NULL, , "Invalid parameter!");
+       retif(item == NULL, , "Invalid parameter!");
+       retif(noti == NULL, , "noti is NULL");
+
+       /* Set text domain */
+       notification_get_text_domain(noti, &domain, &dir);
+       if (domain != NULL && dir != NULL) {
+               bindtextdomain(domain, dir);
+       }
+
+#ifdef QP_SCREENREADER_ENABLE
+       ao = quickpanel_accessibility_screen_reader_object_get(item,
+                       SCREEN_READER_OBJ_TYPE_ELM_OBJECT, "focus", item);
+       if (ao != NULL) {
+               str_buf = eina_strbuf_new();
+               elm_access_info_set(ao, ELM_ACCESS_TYPE, _("IDS_QP_BUTTON_NOTIFICATION"));
+       }
+#endif
+
+       /* Get pkgname & id */
+       noti_err = notification_get_text(noti,
+                       NOTIFICATION_TEXT_TYPE_TITLE,
+                       &text);
+
+       if (noti_err == NOTIFICATION_ERROR_NONE && text != NULL) {
+               quickpanel_common_util_char_replace(text, _NEWLINE, _SPACE);
+               _set_text_to_part(item, "elm.text.title", text);
+#ifdef QP_SCREENREADER_ENABLE
+               _check_and_add_to_buffer(str_buf, text);
+#endif
+       }
+
+       noti_err = notification_get_text(noti,
+                       NOTIFICATION_TEXT_TYPE_EVENT_COUNT,
+                       &text);
+
+       if (noti_err == NOTIFICATION_ERROR_NONE && text != NULL) {
+               quickpanel_common_util_char_replace(text, _NEWLINE, _SPACE);
+               int count = atoi(text);
+               if (count > 999) {
+                       _set_text_to_part(item, "elm.text.count", "999+");
+               } else {
+                       _set_text_to_part(item, "elm.text.count", text);
+               }
+#ifdef QP_SCREENREADER_ENABLE
+               _check_and_add_to_buffer(str_buf, text);
+#endif
+       }
+
+       noti_err = notification_get_text(noti,
+                       NOTIFICATION_TEXT_TYPE_CONTENT,
+                       &text);
+       if (noti_err == NOTIFICATION_ERROR_NONE && text != NULL) {
+               quickpanel_common_util_char_replace(text, _NEWLINE, _SPACE);
+               _set_text_to_part(item, "elm.text.content", text);
+#ifdef QP_SCREENREADER_ENABLE
+               _check_and_add_to_buffer(str_buf, text);
+#endif
+       }
+
+       noti_err = notification_get_time(noti, &noti_time);
+       if (noti_time == 0.0) {
+               noti_err = notification_get_insert_time(noti, &noti_time);
+       }
+       if (noti_err == NOTIFICATION_ERROR_NONE) {
+               quickpanel_noti_util_get_time(noti_time, buf, 512);
+               _set_text_to_part(item, "elm.text.time", buf);
+#ifdef QP_SCREENREADER_ENABLE
+               _check_and_add_to_buffer(str_buf, buf);
+#endif
+       }
+
+       if (elm_object_part_text_get(item, "elm.text.count") != NULL) {
+               elm_object_signal_emit(item, "content.short", "prog");
+               elm_object_signal_emit(item, "count.show", "prog");
+       }
+       if (elm_object_part_text_get(item, "elm.text.time") != NULL) {
+               elm_object_signal_emit(item, "title.short", "prog");
+       }
+
+       const char *get_content = elm_object_part_text_get(item, "elm.text.content");
+       if (get_content == NULL || strlen(get_content) == 0) {
+               // if there is no content, move title to vertical center.
+               elm_object_signal_emit(item, "title.move.center", "prog");
+               if (elm_object_part_text_get(item, "elm.text.time") != NULL) {
+                       elm_object_signal_emit(item, "title.short.center", "prog");
+                       elm_object_signal_emit(item, "time.move.center", "prog");
+               }
+       } else {
+               elm_object_signal_emit(item, "title.move.default", "prog");
+               if (elm_object_part_text_get(item, "elm.text.time") != NULL) {
+                       elm_object_signal_emit(item, "time.move.default", "prog");
+                       elm_object_signal_emit(item, "title.short", "prog");
+               } else {
+                       elm_object_signal_emit(item, "title.text.default", "prog");
+               }
+       }
+#ifdef QP_SCREENREADER_ENABLE
+       if (ao != NULL && str_buf != NULL) {
+               elm_access_info_set(ao, ELM_ACCESS_INFO, eina_strbuf_string_get(str_buf));
+               eina_strbuf_free(str_buf);
+       }
+#endif
+}
+
+static Evas_Object *_create(notification_h noti, Evas_Object *parent)
+{
+       int view_height = 0;
+       Evas_Object *view = NULL;
+       const char *view_layout_group = NULL;
+       retif(parent == NULL, NULL, "Invalid parameter!");
+       retif(noti == NULL, NULL, "Invalid parameter!");
+
+       notification_ly_type_e layout = NOTIFICATION_LY_NOTI_EVENT_SINGLE;
+       notification_get_layout(noti, &layout);
+
+       view_layout_group = "quickpanel/listitem/notification";
+       view_height = QP_THEME_LIST_ITEM_NOTIFICATION_LISTTYPE_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT;
+
+       view = elm_layout_add(parent);
+       if (view != NULL) {
+               elm_layout_file_set(view, DEFAULT_EDJ, view_layout_group);
+               evas_object_size_hint_weight_set(view, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+               evas_object_size_hint_align_set(view, EVAS_HINT_FILL, EVAS_HINT_FILL);
+               quickpanel_uic_initial_resize(view, view_height);
+               evas_object_show(view);
+       } else {
+               ERR("failed to create ongoing notification view");
+       }
+
+       return view;
+}
+
+static void _update(noti_node_item *noti_node, notification_ly_type_e layout, Evas_Object *item)
+{
+       retif(item == NULL, , "Invalid parameter!");
+       retif(noti_node == NULL, , "Invalid parameter!");
+
+       _set_icon(item, noti_node->noti);
+       _set_text(item, noti_node->noti);
+}
+
+Noti_View_H noti_view_listtype_h = {
+       .name                   = "noti_view_listtype",
+       .create                 = _create,
+       .update                 = _update,
+       .remove                 = NULL,
+};
diff --git a/daemon/notifications/noti_view_ongoing.c b/daemon/notifications/noti_view_ongoing.c
new file mode 100755 (executable)
index 0000000..5885d37
--- /dev/null
@@ -0,0 +1,561 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <stdio.h>
+#include <string.h>
+#include <glib.h>
+
+#include <Elementary.h>
+
+#include <vconf.h>
+#include <notification.h>
+#include <notification_internal.h>
+#include <notification_text_domain.h>
+#include <system_settings.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "quickpanel-ui.h"
+#include "common_uic.h"
+#include "common.h"
+#include "list_util.h"
+#include "quickpanel_def.h"
+#include <vi_manager.h>
+#include "noti_node.h"
+#include "noti_list_item.h"
+#include "noti.h"
+#include "noti_util.h"
+#include "animated_icon.h"
+
+#ifdef QP_SCREENREADER_ENABLE
+#include "accessibility.h"
+#endif
+
+#ifdef QP_ANIMATED_IMAGE_ENABLE
+#include "animated_image.h"
+#endif
+
+#define LEN_UNIT_TEXTBLOCK 555
+#define QP_DEFAULT_ICON        RESDIR"/quickpanel_icon_default.png"
+
+#ifdef QP_SCREENREADER_ENABLE
+static inline void _check_and_add_to_buffer(Eina_Strbuf *str_buf, const char *text)
+{
+       char buf_number[QP_UTIL_PHONE_NUMBER_MAX_LEN * 2] = { 0, };
+
+       retif(str_buf == NULL, , "Invalid parameter!");
+
+       if (text != NULL) {
+               if (strlen(text) > 0) {
+                       if (quickpanel_common_util_is_phone_number(text)) {
+                               quickpanel_common_util_phone_number_tts_make(buf_number, text,
+                                               (QP_UTIL_PHONE_NUMBER_MAX_LEN * 2) - 1);
+                               eina_strbuf_append(str_buf, buf_number);
+                       } else {
+                               eina_strbuf_append(str_buf, text);
+                       }
+                       eina_strbuf_append_char(str_buf, '\n');
+               }
+       }
+}
+#endif
+
+static Evas_Object *_check_duplicated_progress_loading(Evas_Object *obj, const char *part, const char *style_name)
+{
+       Evas_Object *old_content = NULL;
+       const char *old_style_name = NULL;
+
+       retif(obj == NULL, NULL, "Invalid parameter!");
+       retif(part == NULL, NULL, "Invalid parameter!");
+       retif(style_name == NULL, NULL, "Invalid parameter!");
+
+       old_content = elm_object_part_content_get(obj, part);
+       if (old_content != NULL) {
+               old_style_name = elm_object_style_get(old_content);
+               if (old_style_name != NULL) {
+                       if (strcmp(old_style_name, style_name) == 0) {
+                               return old_content;
+                       }
+
+                       elm_object_part_content_unset(obj, part);
+                       evas_object_del(old_content);
+                       old_content = NULL;
+               }
+       }
+
+       return NULL;
+}
+
+static Evas_Object *_check_duplicated_image_loading(Evas_Object *obj, const char *part, const char *file_path)
+{
+       Evas_Object *old_ic = NULL;
+       const char *old_ic_path = NULL;
+
+       retif(obj == NULL, NULL, "Invalid parameter!");
+       retif(part == NULL, NULL, "Invalid parameter!");
+       retif(file_path == NULL, NULL, "Invalid parameter!");
+
+       old_ic = elm_object_part_content_get(obj, part);
+
+       if (quickpanel_animated_icon_is_same_icon(old_ic, file_path) == 1) {
+               return old_ic;
+       }
+
+       if (old_ic != NULL) {
+               elm_image_file_get(old_ic, &old_ic_path, NULL);
+               if (old_ic_path != NULL) {
+                       if (strcmp(old_ic_path, file_path) == 0)
+                               return old_ic;
+               }
+
+               elm_object_part_content_unset(obj, part);
+               evas_object_del(old_ic);
+               old_ic = NULL;
+       }
+
+       return NULL;
+}
+
+static void _set_text_to_part(Evas_Object *obj, const char *part, const char *text)
+{
+       const char *old_text;
+
+       if (!obj || !part || !text) {
+               ERR("Invalid parameters");
+               return;
+       }
+
+       old_text = elm_object_part_text_get(obj, part);
+       if (old_text != NULL) {
+               if (strcmp(old_text, text) == 0) {
+                       return;
+               }
+       }
+
+       elm_object_part_text_set(obj, part, text);
+}
+
+static char *_noti_get_progress(notification_h noti, char *buf, int buf_len)
+{
+       double size = 0.0;
+       double percentage = 0.0;
+
+       retif(noti == NULL, NULL, "Invalid parameter!");
+       retif(buf == NULL, NULL, "Invalid parameter!");
+
+       notification_get_size(noti, &size);
+       notification_get_progress(noti, &percentage);
+
+       if (percentage > 0) {
+               if (percentage < 1.0 ) {
+                       if (snprintf(buf, buf_len, "%d%%", (int)(percentage * 100.0 + 0.5)) <= 0) {
+                               return NULL;
+                       }
+               }
+               if (percentage >= 1.0) {
+                       snprintf(buf, buf_len, "%d%%", 100);
+               }
+
+               return buf;
+       } else if (size > 0 && percentage == 0) {
+               if (size > (1 << 30)) {
+                       if (snprintf(buf, buf_len, "%.1lfGB",
+                                               size / 1000000000.0) <= 0)
+                               return NULL;
+
+                       return buf;
+               } else if (size > (1 << 20)) {
+                       if (snprintf(buf, buf_len, "%.1lfMB",
+                                               size / 1000000.0) <= 0)
+                               return NULL;
+
+                       return buf;
+               } else if (size > (1 << 10)) {
+                       if (snprintf(buf, buf_len, "%.1lfKB",
+                                               size / 1000.0) <= 0)
+                               return NULL;
+
+                       return buf;
+               } else {
+                       if (snprintf(buf, buf_len, "%.0lfB", size) <= 0)
+                               return NULL;
+
+                       return buf;
+               }
+       }
+
+       return NULL;
+}
+
+static void _set_progressbar(Evas_Object *item, notification_h noti)
+{
+       Evas_Object *ic = NULL;
+       Evas_Object *old_ic = NULL;
+       double size = 0.0;
+       double percentage = 0.0;
+       notification_type_e type = NOTIFICATION_TYPE_NONE;
+       notification_ly_type_e layout = NOTIFICATION_LY_NONE ;
+
+       retif(item == NULL, , "Invalid parameter!");
+       retif(noti == NULL, , "noti is NULL");
+
+       notification_get_type(noti, &type);
+       if (type == NOTIFICATION_TYPE_ONGOING) {
+               notification_get_size(noti, &size);
+               notification_get_progress(noti, &percentage);
+               notification_get_layout(noti, &layout);
+
+               if (layout != NOTIFICATION_LY_ONGOING_EVENT) {
+                       if (percentage > 0.0 && percentage <= 1.0) {
+                               old_ic = _check_duplicated_progress_loading(item, "elm.swallow.progress", "list_progress");
+                               if (old_ic == NULL) {
+                                       ic = elm_progressbar_add(item);
+                                       elm_progressbar_unit_format_set(ic, "%0.0f%%");
+                                       if (ic == NULL)
+                                               return;
+                                       elm_object_style_set(ic, "list_progress");
+                               } else {
+                                       ic = old_ic;
+                               }
+
+                               elm_progressbar_value_set(ic, percentage);
+                               elm_progressbar_horizontal_set(ic, EINA_TRUE);
+                               elm_progressbar_pulse(ic, EINA_FALSE);
+                       } else if ((size >= 0.0 && percentage == 0.0) || ((size < 0.0 && percentage == 0.0)|| (size == 0.0 && percentage < 0.0))) {
+                               old_ic = _check_duplicated_progress_loading(item, "elm.swallow.progress", "pending");
+                               if (old_ic == NULL) {
+                                       ic = elm_progressbar_add(item);
+                                       elm_progressbar_unit_format_set(ic, "%0.0f%%");
+                                       if (ic == NULL)
+                                               return;
+                                       elm_object_style_set(ic, "pending");
+                               } else {
+                                       ic = old_ic;
+                               }
+
+                               elm_progressbar_horizontal_set(ic, EINA_TRUE);
+                               elm_progressbar_pulse(ic, EINA_TRUE);
+                       }
+               }
+       }
+
+       if (ic != NULL) {
+               elm_object_part_content_set(item, "elm.swallow.progress", ic);
+       }
+}
+
+static void _set_icon(Evas_Object *item, notification_h noti)
+{
+       Evas_Object *ic = NULL;
+       Evas_Object *old_ic = NULL;
+       char *icon_path = NULL;
+       char *icon_sub_path = NULL;
+       char *thumbnail_path = NULL;
+       char *main_icon_path = NULL;
+       char *sub_icon_path = NULL;
+       char *icon_default = NULL;
+       char *pkgname = NULL;
+
+       retif(item == NULL, , "Invalid parameter!");
+       retif(noti == NULL, , "noti is NULL");
+
+       notification_get_pkgname(noti, &pkgname);
+       notification_get_image(noti, NOTIFICATION_IMAGE_TYPE_THUMBNAIL,
+                       &thumbnail_path);
+       notification_get_image(noti, NOTIFICATION_IMAGE_TYPE_ICON, &icon_path);
+       notification_get_image(noti, NOTIFICATION_IMAGE_TYPE_ICON_SUB, &icon_sub_path);
+
+       if (thumbnail_path != NULL && icon_path != NULL) {
+               main_icon_path = thumbnail_path;
+               sub_icon_path = icon_path;
+       } else if (icon_path != NULL && thumbnail_path == NULL) {
+               main_icon_path = icon_path;
+               sub_icon_path = icon_sub_path;
+       } else if (icon_path == NULL && thumbnail_path != NULL) {
+               main_icon_path = thumbnail_path;
+               sub_icon_path = icon_sub_path;
+       } else {
+               icon_default = quickpanel_common_ui_get_pkginfo_icon(pkgname);
+               main_icon_path = icon_default;
+               sub_icon_path = NULL;
+       }
+
+       if (main_icon_path != NULL) {
+               old_ic = _check_duplicated_image_loading(item,
+                               "elm.swallow.thumbnail", main_icon_path);
+
+               if (old_ic == NULL) {
+                       ic = quickpanel_animated_icon_get(item, main_icon_path);
+                       if (ic == NULL) {
+                               ic = elm_image_add(item);
+                               elm_image_resizable_set(ic, EINA_FALSE, EINA_TRUE);
+                               elm_image_file_set(ic, main_icon_path, quickpanel_animated_image_get_groupname(main_icon_path));
+#ifdef QP_ANIMATED_IMAGE_ENABLE
+                               quickpanel_animated_image_add(ic);
+#endif
+                               if (!strncmp(main_icon_path, QP_PRELOAD_NOTI_ICON_PATH, strlen(QP_PRELOAD_NOTI_ICON_PATH)))     {
+                                       DBG("Apply color theme [%s]", main_icon_path);
+                                       evas_object_color_set(ic, 155, 216, 226, 255);
+                               } else {
+                                       elm_image_aspect_fixed_set(ic, EINA_TRUE);
+                               }
+                       }
+                       elm_object_part_content_set(item, "elm.swallow.thumbnail", ic);
+               }
+       }
+
+       if (sub_icon_path != NULL) {
+               old_ic = _check_duplicated_image_loading(item,
+                               "elm.swallow.icon", sub_icon_path);
+
+               if (old_ic == NULL) {
+                       ic = elm_image_add(item);
+                       elm_image_resizable_set(ic, EINA_FALSE, EINA_TRUE);
+                       elm_image_file_set(ic, sub_icon_path, quickpanel_animated_image_get_groupname(sub_icon_path));
+                       elm_object_part_content_set(item, "elm.swallow.icon", ic);
+                       elm_object_signal_emit(item, "elm.icon.bg.show", "elm");
+               }
+       }
+
+       if (main_icon_path == NULL && sub_icon_path == NULL) {
+               old_ic = _check_duplicated_image_loading(item,
+                               "elm.swallow.thumbnail", QP_DEFAULT_ICON);
+
+               if (old_ic == NULL) {
+                       ic = elm_image_add(item);
+                       elm_image_resizable_set(ic, EINA_FALSE, EINA_TRUE);
+                       elm_image_file_set(ic, QP_DEFAULT_ICON, quickpanel_animated_image_get_groupname(QP_DEFAULT_ICON));
+                       elm_object_part_content_set(item, "elm.swallow.thumbnail", ic);
+#ifdef QP_ANIMATED_IMAGE_ENABLE
+                       quickpanel_animated_image_add(ic);
+#endif
+               }
+       }
+
+       if (icon_default != NULL) {
+               free(icon_default);
+       }
+}
+
+static void _set_text(Evas_Object *item, notification_h noti)
+{
+       char *text = NULL;
+       char *text_utf8 = NULL;
+       char *domain = NULL;
+       char *dir = NULL;
+       char *pkgname = NULL;
+       //      char *caller_pkgname = NULL;
+       int group_id = 0, priv_id = 0;
+       char buf[128] = { 0, };
+       notification_type_e type = NOTIFICATION_TYPE_NONE;
+       double size = 0.0;
+       double percentage = 0.0;
+       notification_ly_type_e layout = NOTIFICATION_LY_NONE ;
+#ifdef QP_SCREENREADER_ENABLE
+       Evas_Object *ao = NULL;
+       Eina_Strbuf *str_buf = NULL;
+#endif
+       Evas_Object *textblock = NULL;
+       int len_w = 0, num_line = 1, view_height = 0;
+       struct appdata *ad = quickpanel_get_app_data();
+       char *text_count = NULL;
+       int ret;
+
+       if (!ad || !item || !noti) {
+               ERR("Invalid parameters: %p %p %p", ad, item, noti);
+               return;
+       }
+
+       /* Set text domain */
+       notification_get_text_domain(noti, &domain, &dir);
+       if (domain != NULL && dir != NULL) {
+               bindtextdomain(domain, dir);
+       }
+
+#ifdef QP_SCREENREADER_ENABLE
+       ao = quickpanel_accessibility_screen_reader_object_get(item, SCREEN_READER_OBJ_TYPE_ELM_OBJECT, "focus", item);
+       if (ao != NULL) {
+               str_buf = eina_strbuf_new();
+               elm_access_info_set(ao, ELM_ACCESS_TYPE, _("IDS_QP_BUTTON_NOTIFICATION"));
+       }
+#endif
+
+       /* Get pkgname & id */
+       ret = notification_get_pkgname(noti, &pkgname);
+       if (ret != NOTIFICATION_ERROR_NONE) {
+               ERR("Unable to get the pkgname");
+       }
+       //      notification_get_application(noti, &caller_pkgname);
+       ret = notification_get_id(noti, &group_id, &priv_id);
+       if (ret != NOTIFICATION_ERROR_NONE) {
+               ERR("Unable to get id");
+       }
+       ret = notification_get_type(noti, &type);
+       if (ret != NOTIFICATION_ERROR_NONE) {
+               ERR("Unable to get type");
+       }
+       ret = notification_get_size(noti, &size);
+       if (ret != NOTIFICATION_ERROR_NONE) {
+               ERR("Unable to get size");
+       }
+       ret = notification_get_progress(noti, &percentage);
+       if (ret != NOTIFICATION_ERROR_NONE) {
+               ERR("Unable to get progress");
+       }
+       ret = notification_get_layout(noti, &layout);
+       if (ret != NOTIFICATION_ERROR_NONE) {
+               ERR("Unable to get layout");
+       }
+       ret = notification_get_text(noti, NOTIFICATION_TEXT_TYPE_EVENT_COUNT, &text_count);
+       if (ret != NOTIFICATION_ERROR_NONE) {
+               ERR("Unable to get event_count");
+       } 
+
+       SDBG("percentage:%f size:%f", percentage, size);
+
+       ret = notification_get_text(noti, NOTIFICATION_TEXT_TYPE_TITLE, &text);
+       if (ret == NOTIFICATION_ERROR_NONE && text != NULL) {
+               quickpanel_common_util_char_replace(text, _NEWLINE, _SPACE);
+               _set_text_to_part(item, "elm.text.title", text);
+#ifdef QP_SCREENREADER_ENABLE
+               _check_and_add_to_buffer(str_buf, text);
+#endif
+       }
+
+       ret = notification_get_text(noti, NOTIFICATION_TEXT_TYPE_CONTENT, &text);
+       if (ret == NOTIFICATION_ERROR_NONE && text != NULL) {
+               if (layout == NOTIFICATION_LY_ONGOING_EVENT) {
+                       text_utf8 = elm_entry_utf8_to_markup(text);
+                       if (text_utf8 != NULL) {
+                               _set_text_to_part(item, "elm.text.content", text_utf8);
+                               free(text_utf8);
+                       } else {
+                               _set_text_to_part(item, "elm.text.content", text);
+                       }
+                       textblock = (Evas_Object *)edje_object_part_object_get(_EDJ(item), "elm.text.content");
+                       evas_object_textblock_size_native_get(textblock, &len_w, NULL);
+                       num_line = len_w / (LEN_UNIT_TEXTBLOCK * ad->scale);
+                       num_line = (len_w - (num_line * (LEN_UNIT_TEXTBLOCK * ad->scale))) > 0 ? num_line + 1 : num_line;
+                       if (num_line <= 1) {
+                               elm_object_signal_emit(item, "line1.set", "prog");
+                               view_height = QP_THEME_LIST_ITEM_ONGOING_EVENT_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT;
+                       } else /*if (num_line >= 2 && num_line < 3)*/ {
+                               elm_object_signal_emit(item, "line2.set", "prog");
+                               view_height = QP_THEME_LIST_ITEM_ONGOING_EVENT_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT;
+                       } /*else {
+                               elm_object_signal_emit(item, "line3.set", "prog");
+                               view_height = QP_THEME_LIST_ITEM_ONGOING_EVENT_LINE3_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT;
+                               }*/
+                       quickpanel_uic_initial_resize(item, view_height);
+#ifdef QP_SCREENREADER_ENABLE
+                       _check_and_add_to_buffer(str_buf, text);
+#endif
+               } else {
+                       quickpanel_common_util_char_replace(text, _NEWLINE, _SPACE);
+                       _set_text_to_part(item, "elm.text.content", text);
+#ifdef QP_SCREENREADER_ENABLE
+                       _check_and_add_to_buffer(str_buf, text);
+#endif
+               }
+       }
+
+       if (layout != NOTIFICATION_LY_ONGOING_EVENT) {
+               text = _noti_get_progress(noti, buf,  sizeof(buf));
+               if (text != NULL) {
+                       quickpanel_common_util_char_replace(text, _NEWLINE, _SPACE);
+#ifdef QP_SCREENREADER_ENABLE
+                       _check_and_add_to_buffer(str_buf, text);
+#endif
+               } else {
+                       _set_text_to_part(item, "elm.text.time", "");
+               }
+       } else {
+               const char *get_content;
+
+               get_content = elm_object_part_text_get(item, "elm.text.content");
+               if (get_content == NULL || strlen(get_content) == 0) {
+                       // if there is no content, move title to vertical center.
+                       elm_object_signal_emit(item, "title.move.center", "prog");
+               }
+       }
+
+       if (layout == NOTIFICATION_LY_ONGOING_PROGRESS && text_count != NULL) {
+               _set_text_to_part(item, "elm.text.count", text_count);
+               if (elm_object_part_text_get(item, "elm.text.count") != NULL) {
+                       elm_object_signal_emit(item, "content.short", "prog");
+                       elm_object_signal_emit(item, "count.show", "prog");
+               }
+       }
+
+#ifdef QP_SCREENREADER_ENABLE
+       if (ao != NULL && str_buf != NULL) {
+               elm_access_info_set(ao, ELM_ACCESS_INFO, eina_strbuf_string_get(str_buf));
+               eina_strbuf_free(str_buf);
+       }
+#endif
+}
+
+static Evas_Object *_create(notification_h noti, Evas_Object *parent)
+{
+       int view_height = 0;
+       Evas_Object *view = NULL;
+       const char *view_layout_group = NULL;
+       retif(parent == NULL, NULL, "Invalid parameter!");
+       retif(noti == NULL, NULL, "Invalid parameter!");
+
+       notification_ly_type_e layout = NOTIFICATION_LY_NOTI_EVENT_SINGLE;
+       notification_get_layout(noti, &layout);
+
+       if (layout == NOTIFICATION_LY_ONGOING_EVENT) {
+               view_layout_group = "quickpanel/listitem/event";
+               view_height = QP_THEME_LIST_ITEM_ONGOING_EVENT_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT;
+       } else if (layout == NOTIFICATION_LY_ONGOING_PROGRESS) {
+               view_layout_group = "quickpanel/listitem/progress";
+               view_height = QP_THEME_LIST_ITEM_ONGOING_PROGRESS_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT;
+       }
+
+       view = elm_layout_add(parent);
+       if (view != NULL) {
+               elm_layout_file_set(view, DEFAULT_EDJ, view_layout_group);
+               evas_object_size_hint_weight_set(view, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+               evas_object_size_hint_align_set(view, EVAS_HINT_FILL, EVAS_HINT_FILL);
+               quickpanel_uic_initial_resize(view, view_height);
+               evas_object_show(view);
+       } else {
+               ERR("failed to create ongoing notification view");
+       }
+
+       return view;
+}
+
+static void _update(noti_node_item *noti_node, notification_ly_type_e layout, Evas_Object *item)
+{
+       retif(item == NULL, , "Invalid parameter!");
+       retif(noti_node == NULL, , "Invalid parameter!");
+
+       _set_progressbar(item, noti_node->noti);
+       _set_icon(item, noti_node->noti);
+       _set_text(item, noti_node->noti);
+}
+
+Noti_View_H ongoing_noti_view_h = {
+       .name                   = "ongoing_noti_view",
+       .create                 = _create,
+       .update                 = _update,
+       .remove                 = NULL,
+};
diff --git a/daemon/notifications/noti_win.c b/daemon/notifications/noti_win.c
new file mode 100755 (executable)
index 0000000..75c4dc7
--- /dev/null
@@ -0,0 +1,300 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+#include <efl_util.h>
+
+#define NOTI_HEIGHT ELM_SCALE_SIZE(260)
+#define NOTI_START_Y ELM_SCALE_SIZE(36)
+
+
+#ifndef __UNUSED__
+#define __UNUSED__ __attribute__((unused))
+#endif
+/* Using this macro to emphasize that some portion like stacking and
+   rotation handling are implemented for X based platform
+ */
+
+#include "common.h"
+#include "noti_win.h"
+
+
+struct Internal_Data {
+       Evas_Object *content;
+       Ecore_Event_Handler *rotation_event_handler;
+       Evas_Coord scr_w;
+       Evas_Coord scr_h;
+       Evas_Coord w;
+       Evas_Coord h;
+       int angle;
+       enum Noti_Orient orient;
+};
+
+#define E_DATA_KEY "E_DATA_KEY"
+#define E_DATA_BASE_RECT "E_DATA_BASE_RECT"
+
+static void _show(void *data __UNUSED__, Evas *e __UNUSED__, Evas_Object *obj, void *event_info __UNUSED__)
+{
+       struct Internal_Data *wd = evas_object_data_get(obj, E_DATA_KEY);
+
+       if (!wd) {
+               return;
+       }
+
+       if (wd->content) {
+               evas_object_show(wd->content);
+       }
+
+}
+
+static void _content_changed_size_hints(void *data, Evas *e __UNUSED__, Evas_Object *obj, void *event_info __UNUSED__)
+{
+       Evas_Coord h = 0;
+       struct Internal_Data *wd = evas_object_data_get(data, E_DATA_KEY);
+
+       if (!wd) {
+               return;
+       }
+
+       evas_object_size_hint_min_get(obj, NULL, &h);
+       if ((h > 0)) {
+               evas_object_size_hint_min_set(obj, wd->w, wd->h);
+               evas_object_size_hint_min_set(data, wd->w, wd->h);
+               evas_object_resize(data, wd->w, wd->h);
+       }
+}
+
+static void _resized(void *data __UNUSED__, Evas *e __UNUSED__, Evas_Object *obj, void *event_info __UNUSED__)
+{
+       evas_object_show(obj);
+}
+
+static void _del(void *data __UNUSED__, Evas *e __UNUSED__, Evas_Object *obj, void *event_info __UNUSED__)
+{
+       struct Internal_Data *wd = evas_object_data_get(obj, E_DATA_KEY);
+
+       if (wd) {
+               if (wd->rotation_event_handler) {
+                       ecore_event_handler_del(wd->rotation_event_handler);
+               }
+               free(wd);
+       }
+
+       evas_object_data_set(data, E_DATA_KEY, NULL);
+}
+
+static void _win_rotated(Evas_Object *obj)
+{
+       int angle = 0;
+       struct Internal_Data *wd =  evas_object_data_get(obj, E_DATA_KEY);
+
+       if (!wd) {
+               return;
+       }
+
+       angle = elm_win_rotation_get(obj);
+       if (angle % 90) {
+               return;
+       }
+
+       angle %= 360;
+       if (angle < 0) {
+               angle += 360;
+       }
+       wd->angle = angle;
+
+       switch (angle) {
+       case 0:
+       case 180:
+               evas_object_size_hint_min_set(obj, wd->scr_w, wd->h);
+               evas_object_resize(obj, wd->scr_w, wd->h);
+               evas_object_move(obj, 0, NOTI_START_Y);
+               break;
+       case 90:
+               evas_object_size_hint_min_set(obj, wd->scr_h, wd->h);
+               evas_object_resize(obj, wd->scr_h, wd->h);
+               evas_object_move(obj, NOTI_START_Y, 0);
+               break;
+       case 270:
+               evas_object_size_hint_min_set(obj, wd->scr_h, wd->h);
+               evas_object_resize(obj, wd->scr_h, wd->h);
+               evas_object_move(obj, wd->scr_w - wd->h - NOTI_START_Y, 0);
+               break;
+       default:
+               ERR("cannot reach here");
+       }
+}
+
+static void _ui_rotation_wm_cb(void *data, Evas_Object *obj, void *event)
+{
+       int angle = 0;
+       angle = elm_win_rotation_get((Evas_Object *)obj);
+
+       DBG("ACTIVENOTI ROTATE:%d", angle);
+
+       _win_rotated(obj);
+}
+
+static void _resize_cb (void *data, Evas *e,  Evas_Object *eo, void *event_info)
+{
+       int x, y, w, h;
+       evas_object_geometry_get(eo, &x, &y, &w, &h);
+       DBG("%s: %d:%d:%d:%d\n", data, x, y, w, h);
+}
+
+HAPI Evas_Object *quickpanel_noti_win_add(Evas_Object *parent)
+{
+       Evas_Object *win;
+       struct Internal_Data *wd;
+       Evas_Coord w = 0, h = 0;
+       Evas *e = NULL;
+       Ecore_Evas *ee = NULL;
+
+       win = elm_win_add(parent, "noti_win", ELM_WIN_NOTIFICATION);
+       if (!win) {
+               return NULL;
+       }
+
+       e = evas_object_evas_get(win);
+       if (!e) {
+               evas_object_del(win);
+               return NULL;
+       }
+
+       ee = ecore_evas_ecore_evas_get(e);
+       if (!ee) {
+               evas_object_del(win);
+               return NULL;
+       }
+
+       ecore_evas_name_class_set(ee, "APP_POPUP", "APP_POPUP");
+
+       elm_win_alpha_set(win, EINA_FALSE);
+       elm_win_indicator_mode_set(win, ELM_WIN_INDICATOR_HIDE);
+       elm_win_title_set(win, "noti_win");
+       elm_win_borderless_set(win, EINA_TRUE);
+       elm_win_autodel_set(win, EINA_TRUE);
+       evas_object_size_hint_weight_set(win, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       evas_object_size_hint_align_set(win, EVAS_HINT_FILL, EVAS_HINT_FILL);
+
+       efl_util_set_notification_window_level(win, EFL_UTIL_NOTIFICATION_LEVEL_DEFAULT);
+       elm_win_prop_focus_skip_set(win, EINA_TRUE);
+       elm_win_aux_hint_add(win, "wm.policy.win.user.geometry", "1");
+
+       if (elm_win_wm_rotation_supported_get(win)) {
+               int rots[4] = { 0, 90, 180, 270 };
+               elm_win_wm_rotation_available_rotations_set(win, rots, 4);
+       }
+       evas_object_smart_callback_add(win, "wm,rotation,changed", _ui_rotation_wm_cb, NULL);
+       evas_object_event_callback_add(win, EVAS_CALLBACK_RESIZE, _resize_cb, "win");
+
+       wd = (struct Internal_Data *) calloc(1, sizeof(struct Internal_Data));
+       if (!wd) {
+               if (win) {
+                       evas_object_del(win);
+               }
+               return NULL;
+       }
+       evas_object_data_set(win, E_DATA_KEY, wd);
+       wd->angle = 0;
+       wd->orient = NOTI_ORIENT_TOP;
+       evas_object_move(win, 0, NOTI_START_Y);
+       elm_win_screen_size_get(win, NULL, NULL, &w, &h);
+
+       wd->scr_w = w;
+       wd->scr_h = h;
+       wd->w = w;
+       wd->h = NOTI_HEIGHT;
+
+       evas_object_resize(win, w, wd->h);
+       evas_object_event_callback_add(win, EVAS_CALLBACK_SHOW, _show, NULL);
+       evas_object_event_callback_add(win, EVAS_CALLBACK_DEL, _del, NULL);
+       evas_object_event_callback_add(win, EVAS_CALLBACK_RESIZE, _resized, NULL);
+
+       return win;
+}
+
+HAPI void quickpanel_noti_win_content_set(Evas_Object *obj, Evas_Object *content)
+{
+       struct Internal_Data *wd;
+
+       if (!obj) {
+               return;
+       }
+
+       wd = evas_object_data_get(obj, E_DATA_KEY);
+       if (!wd) {
+               return;
+       }
+
+       if (wd->content && content != NULL) {
+               evas_object_del(wd->content);
+               wd->content = NULL;
+       }
+
+       wd->content = content;
+
+       if (!content) {
+               return;
+       }
+
+       evas_object_size_hint_weight_set(content, EVAS_HINT_EXPAND,     EVAS_HINT_EXPAND);
+       evas_object_resize(obj, wd->w, wd->h);
+       elm_win_resize_object_add(obj, content);
+       evas_object_size_hint_min_set(content, wd->w, wd->h);
+       evas_object_event_callback_add(content, EVAS_CALLBACK_CHANGED_SIZE_HINTS, _content_changed_size_hints, obj);
+}
+
+HAPI void quickpanel_noti_win_resize(Evas_Object *obj, int btn_cnt)
+{
+       struct Internal_Data *wd;
+
+       if (!obj) {
+               return;
+       }
+
+       wd = evas_object_data_get(obj, E_DATA_KEY);
+       if (!wd) {
+               return;
+       }
+
+       evas_object_resize(obj, wd->w, wd->h);
+}
+
+HAPI void quickpanel_noti_win_orient_set(Evas_Object *obj, enum Noti_Orient orient)
+{
+       struct Internal_Data *wd = evas_object_data_get(obj, E_DATA_KEY);
+
+       if (!wd) {
+               return;
+       }
+
+       if (orient >= NOTI_ORIENT_LAST) {
+               return;
+       }
+       switch (orient) {
+       case NOTI_ORIENT_BOTTOM:
+               evas_object_move(obj, 0, wd->scr_h - wd->h);
+               wd->orient = NOTI_ORIENT_BOTTOM;
+               break;
+       case NOTI_ORIENT_TOP:
+       default:
+               evas_object_move(obj, 0, NOTI_START_Y);
+               wd->orient = NOTI_ORIENT_TOP;
+               break;
+       }
+}
diff --git a/daemon/notifications/noti_win.h b/daemon/notifications/noti_win.h
new file mode 100755 (executable)
index 0000000..91373a3
--- /dev/null
@@ -0,0 +1,45 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __NOTI_WIN_H__
+#define __NOTI_WIN_H__
+
+enum Noti_Orient {
+       NOTI_ORIENT_TOP = 0,
+       NOTI_ORIENT_BOTTOM,
+       NOTI_ORIENT_LAST
+} ;
+
+/* Creates and return a new window (of widget type elm_win) of width equal to
+   root window
+ */
+extern Evas_Object *quickpanel_noti_win_add(Evas_Object *parent);
+
+/* Sets an Evas Object as content of the notification window created using
+   noti_win_add
+ */
+extern void quickpanel_noti_win_content_set(Evas_Object *obj, Evas_Object *content);
+
+/* Sets the orientation of the notification window, this can be of type
+   Noti_Orient
+ */
+extern void quickpanel_noti_win_orient_set(Evas_Object *obj, enum Noti_Orient orient);
+
+extern void quickpanel_noti_win_resize(Evas_Object *obj, int btn_cnt);
+
+#endif
diff --git a/daemon/page/page_base.c b/daemon/page/page_base.c
new file mode 100755 (executable)
index 0000000..cab5729
--- /dev/null
@@ -0,0 +1,333 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+#include <stdbool.h>
+#include <glib.h>
+
+#include <vconf.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <notification.h>
+#include <system_settings.h>
+#include <E_DBus.h>
+
+#include "quickpanel-ui.h"
+#include "common.h"
+#include "common_uic.h"
+#include "pager.h"
+#include "pager_common.h"
+#include "list_util.h"
+#include "noti_node.h"
+#include "vi_manager.h"
+#include "setting_utils.h"
+#include "settings.h"
+#include "settings_view_featured.h"
+#include "noti.h"
+
+#ifdef QP_EMERGENCY_MODE_ENABLE
+#include "emergency_mode.h"
+#endif
+
+#define FICKUP_TIME_LIMIT 150
+#define FICKUP_DISTANCE_LIMIT 160
+
+static void _mapbuf_enable_set(Eina_Bool is_enable);
+static void _content_resize(int width, int height, const char *signal);
+static int _up_cb(void *event_info, void *data);
+static int _down_cb(void *event_info, void *data);
+static int _scroll_start_cb(void *event_info, void *data);
+static int _scroll_done_cb(void *event_info, void *data);
+static int _page_changed_cb(void *event_info, void *data);
+
+static struct info {
+       Evas_Object *mapbuf;
+       Evas_Object *view;
+       Evas_Object *view_scroller;
+       Evas_Object *view_box;
+
+       int flick_press_x;
+       int flick_press_y;
+       int flick_available;
+       int flick_time;
+} s_info = {
+       .mapbuf = NULL,
+       .view = NULL,
+       .view_scroller = NULL,
+       .view_box = NULL,
+
+       .flick_press_x = 0,
+       .flick_press_y = 0,
+       .flick_available = 0,
+       .flick_time = 0,
+};
+
+static QP_Page_Handler page_handler  = {
+       .status = 0,
+       .name = NULL,
+       /* func */
+       .mapbuf_enable_set = _mapbuf_enable_set,
+       .content_resize = _content_resize,
+       .down_cb = _down_cb,
+       .up_cb = _up_cb,
+       .scroll_start_cb = _scroll_start_cb,
+       .scroll_done_cb = _scroll_done_cb,
+       .page_changed_cb = _page_changed_cb,
+};
+
+static void _mapbuf_enable_set(Eina_Bool is_enable)
+{
+       Evas_Coord y;
+
+       if (s_info.mapbuf != NULL) {
+               elm_mapbuf_enabled_set(s_info.mapbuf, is_enable);
+       }
+
+       if (is_enable) {
+               evas_object_geometry_get(s_info.view_scroller, NULL, &y, NULL, NULL);
+               evas_object_move(s_info.view, 0, y);
+       }
+}
+
+static void _content_resize(int width, int height, const char *signal)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "invalid parameter");
+
+       if (s_info.view != NULL) {
+               elm_object_signal_emit(s_info.view, signal, "prog");
+               evas_object_size_hint_min_set(s_info.view, width, height);
+       }
+}
+
+void static _flick_mouse_down_cb(void *data, Evas *e, Evas_Object *obj, void *event_info)
+{
+       int limit_h = 0;
+       int limit_partial_h = 0;
+       int limit_partial_w = 0;
+       Evas_Event_Mouse_Down *ev = (Evas_Event_Mouse_Down *)event_info;
+       retif(ev == NULL, , "event_info is NULL");
+
+       s_info.flick_press_x = ev->canvas.x;
+       s_info.flick_press_y = ev->canvas.y;
+       s_info.flick_time = ev->timestamp;
+
+       quickpanel_noti_get_geometry(&limit_h, &limit_partial_h, &limit_partial_w);
+
+       if (s_info.flick_press_y > limit_h) {
+               s_info.flick_available = 1;
+       } else {
+               if (s_info.flick_press_x > limit_partial_w && s_info.flick_press_y > limit_partial_h) {
+                       s_info.flick_available = 1;
+               } else {
+                       s_info.flick_available = 0;
+               }
+       }
+}
+
+static void  _flick_mouse_move_cb(void* data, Evas* e, Evas_Object* obj, void* event_info)
+{
+       int delta_y = 0;
+       Evas_Event_Mouse_Move* ev = event_info;
+       retif(ev == NULL, , "event_info is NULL");
+
+       if (s_info.flick_available == 0) {
+               return;
+       }
+       if (ev->cur.output.y > ev->prev.output.y) {
+               s_info.flick_available = 0;
+               return;
+       }
+       if (abs(ev->cur.output.x - ev->prev.output.x) > 40) {
+               s_info.flick_available = 0;
+               return;
+       }
+       if (ev->timestamp - s_info.flick_time > FICKUP_TIME_LIMIT) {
+               s_info.flick_available = 0;
+               return;
+       }
+
+       delta_y = s_info.flick_press_y - ev->cur.output.y;
+
+       if (delta_y > FICKUP_DISTANCE_LIMIT) {
+               ERR("closed by flick up base area");
+               quickpanel_uic_close_quickpanel(false, 0);
+       }
+}
+
+static int _up_cb(void *event_info, void *data)
+{
+       quickpanel_page_scroll_hold_set(EINA_TRUE);
+       quickpanel_page_scroll_freeze_set(EINA_FALSE);
+
+       return QP_OK;
+}
+
+static int _down_cb(void *event_info, void *data)
+{
+       int x = 0, y = 0;
+       static int settings_y = -1, settings_h = -1;
+
+#ifdef QP_EMERGENCY_MODE_ENABLE
+       if (quickpanel_emergency_mode_is_on()) {
+               return QP_OK;
+       }
+#endif
+
+       if (settings_y == -1 || settings_h == -1) {
+               Evas_Object *obj_settings = NULL;
+               struct appdata *ad = quickpanel_get_app_data();
+               if (ad != NULL && ad->ly != NULL) {
+                       obj_settings = quickpanel_setting_box_get(ad->ly);
+                       if (obj_settings != NULL) {
+                               evas_object_geometry_get(obj_settings, NULL, &settings_y, NULL, &settings_h);
+                       }
+               }
+       }
+
+       quickpanel_page_get_touched_pos(&x, &y);
+
+       if (y >= settings_y && y <= settings_y + settings_h) {
+               if (quickpanel_settings_is_in_left_edge() == EINA_TRUE) {
+                       quickpanel_page_scroll_hold_set(EINA_FALSE);
+               }
+       } else {
+               quickpanel_page_scroll_freeze_set(EINA_TRUE);
+       }
+
+       return QP_OK;
+}
+
+static int _scroll_start_cb(void *event_info, void *data)
+{
+       quickpanel_vim_set_state_suspend();
+
+       return QP_OK;
+}
+
+static int _scroll_done_cb(void *event_info, void *data)
+{
+       quickpanel_vim_set_state_ready();
+
+       return QP_OK;
+}
+
+static int _page_changed_cb(void *event_info, void *data)
+{
+       quickpanel_setting_view_featured_initial_focus_set();
+
+       return QP_OK;
+}
+
+HAPI Evas_Object *quickpanel_page_base_create(Evas_Object *parent, void *data)
+{
+       Evas_Object *mapbuf = NULL;
+       Evas_Object *view = NULL;
+
+       retif(parent == NULL, NULL, "invalid parameter");
+
+       if (s_info.view != NULL) {
+               return s_info.view;
+       }
+
+       mapbuf = elm_mapbuf_add(parent);
+       elm_mapbuf_enabled_set(mapbuf, EINA_FALSE);
+       elm_mapbuf_smooth_set(mapbuf, EINA_FALSE);
+
+       evas_object_size_hint_weight_set(mapbuf, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       evas_object_size_hint_align_set(mapbuf, EVAS_HINT_FILL, EVAS_HINT_FILL);
+
+       view = quickpanel_uic_load_edj(mapbuf, DEFAULT_EDJ, "quickpanel/base", 0);
+       retif(view == NULL, NULL, "failed to load base layout");
+
+       Evas_Object *scroller = elm_scroller_add(parent);
+       retif(!scroller, NULL, "fail to add scroller");
+       //elm_object_style_set(scroller, "default");
+       elm_object_style_set(scroller, "bg/default");
+       elm_scroller_bounce_set(scroller, EINA_TRUE, EINA_TRUE);
+       elm_scroller_policy_set(scroller, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_OFF);
+       evas_object_size_hint_weight_set(scroller, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       evas_object_size_hint_fill_set(scroller, EVAS_HINT_FILL, EVAS_HINT_FILL);
+       evas_object_show(scroller);
+
+       Evas_Object *box = elm_box_add(scroller);
+       if (!box) {
+               ERR("fail to add box");
+               if (scroller != NULL) {
+                       evas_object_del(scroller);
+                       scroller = NULL;
+               }
+               return NULL;
+       }
+       evas_object_size_hint_weight_set(box, EVAS_HINT_EXPAND, 0);
+       elm_box_horizontal_set(box, EINA_FALSE);
+
+       elm_object_content_set(scroller, box);
+       elm_object_part_content_set(view, "qp.base.list.swallow", scroller);
+       evas_object_show(scroller);
+
+       Evas_Object *bg_touch = elm_bg_add(view);
+       if (bg_touch != NULL) {
+               evas_object_color_set(bg_touch, 255, 255, 255, 250);
+               //evas_object_color_set(bg_touch, 0, 0, 0, 0);
+               evas_object_event_callback_add(bg_touch,
+                               EVAS_CALLBACK_MOUSE_DOWN, _flick_mouse_down_cb, NULL);
+               evas_object_event_callback_add(bg_touch,
+                               EVAS_CALLBACK_MOUSE_MOVE, _flick_mouse_move_cb, NULL);
+               elm_object_part_content_set(view, "background.touch", bg_touch);
+       }
+
+
+       quickpanel_page_handler_set(mapbuf, &page_handler);
+
+       elm_object_content_set(mapbuf, view);
+       evas_object_show(mapbuf);
+
+
+       s_info.mapbuf = mapbuf;
+       s_info.view = view;
+       s_info.view_scroller = scroller;
+       s_info.view_box = box;
+
+#ifdef QP_EMERGENCY_MODE_ENABLE
+       if (quickpanel_emergency_mode_is_on()) {
+               quickpanel_page_scroll_freeze_set(EINA_TRUE);
+       }
+#endif
+
+       return s_info.mapbuf;
+}
+
+HAPI Evas_Object *quickpanel_page_base_view_get(const char *view_name)
+{
+       retif(view_name == NULL, NULL, "invalid parameter");
+
+       if (strcmp(view_name, "LAYOUT") == 0) {
+               return s_info.view;
+       } else if (strcmp(view_name, "SCROLLER") == 0) {
+               return s_info.view_scroller;
+       } else if (strcmp(view_name, "BOX") == 0) {
+               return s_info.view_box;
+       }
+
+       return NULL;
+}
+
+HAPI void quickpanel_page_base_focus_allow_set(Eina_Bool is_enable)
+{
+       elm_object_tree_focus_allow_set(s_info.mapbuf, is_enable);
+}
diff --git a/daemon/page/page_base.h b/daemon/page/page_base.h
new file mode 100755 (executable)
index 0000000..589acfe
--- /dev/null
@@ -0,0 +1,26 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __QUICKPANEL_PAGE_BASE_H__
+#define __QUICKPANEL_PAGE_BASE_H__
+
+extern Evas_Object *quickpanel_page_base_create(Evas_Object *parent, void *data);
+extern Evas_Object *quickpanel_page_base_view_get(const char *view_name);
+extern void quickpanel_page_base_focus_allow_set(Eina_Bool is_enable);
+
+#endif
diff --git a/daemon/page/page_edit.c b/daemon/page/page_edit.c
new file mode 100755 (executable)
index 0000000..95f4e7e
--- /dev/null
@@ -0,0 +1,311 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "quickpanel-ui.h"
+#include "common_uic.h"
+#include "common.h"
+#include "pager.h"
+#include "pager_common.h"
+#include "list_util.h"
+#include "vi_manager.h"
+#include "settings_gridbox.h"
+#include "quickpanel_def.h"
+
+static void _mapbuf_enable_set(Eina_Bool is_enable);
+static void _content_resize(int width, int height, const char *signal);
+static int _up_cb(void *event_info, void *data);
+static int _down_cb(void *event_info, void *data);
+static int _scroll_start_cb(void *event_info, void *data);
+static int _scroll_done_cb(void *event_info, void *data);
+
+static struct info {
+       int is_scroll_freezed;
+       Evas_Object *mapbuf;
+       Evas_Object *view;
+       Evas_Object *scroller;
+       Evas_Object *layout;
+       Evas_Object *view_section_1;
+       Evas_Object *view_section_2;
+       Evas_Object *view_active_buttons;
+       Evas_Object *view_reserved_buttons;
+} s_info = {
+       .is_scroll_freezed = 0,
+       .mapbuf = NULL,
+       .view = NULL,
+       .scroller = NULL,
+       .layout = NULL,
+       .view_section_1 = NULL,
+       .view_section_2 = NULL,
+       .view_active_buttons = NULL,
+       .view_reserved_buttons = NULL,
+};
+
+static QP_Page_Handler page_handler  = {
+       .status = 0,
+       .name = NULL,
+
+       .mapbuf_enable_set = _mapbuf_enable_set,
+       .content_resize = _content_resize,
+       .down_cb = _down_cb,
+       .up_cb = _up_cb,
+       .scroll_start_cb = _scroll_start_cb,
+       .scroll_done_cb = _scroll_done_cb,
+};
+
+static inline void _scroll_hold(Evas_Object *viewer)
+{
+       int hold_count = 0;
+       retif(viewer == NULL, , "Invalid parameter!");
+
+       hold_count = elm_object_scroll_hold_get(viewer);
+
+       if (hold_count <= 0) {
+               elm_object_scroll_hold_push(viewer);
+       }
+}
+
+static inline void _scroll_unhold(Evas_Object *viewer)
+{
+       int i = 0, hold_count = 0;
+       retif(viewer == NULL, , "Invalid parameter!");
+
+       hold_count = elm_object_scroll_hold_get(viewer);
+
+       for (i = 0 ; i < hold_count; i++) {
+               elm_object_scroll_hold_pop(viewer);
+       }
+}
+
+static void _mapbuf_enable_set(Eina_Bool is_enable)
+{
+       Evas_Coord y;
+
+       if (s_info.mapbuf != NULL) {
+               elm_mapbuf_enabled_set(s_info.mapbuf, is_enable);
+       }
+
+       if (is_enable) {
+               evas_object_geometry_get(s_info.mapbuf, NULL, &y, NULL, NULL);
+               evas_object_move(s_info.view, 0, y);
+       }
+}
+
+static void _content_resize(int width, int height, const char *signal)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "invalid parameter");
+
+       if (s_info.view != NULL) {
+               elm_object_signal_emit(s_info.view, signal, "prog");
+               evas_object_size_hint_min_set(s_info.view, ELM_SCALE_SIZE(width), ELM_SCALE_SIZE(height));
+       }
+       if (s_info.layout != NULL) {
+               elm_object_signal_emit(s_info.layout, signal, "prog");
+               if (strcmp(signal, "portrait") == 0) {
+                       evas_object_size_hint_min_set(s_info.layout, ELM_SCALE_SIZE(width), ELM_SCALE_SIZE(height));
+               } else {
+                       evas_object_size_hint_min_set(s_info.layout, ELM_SCALE_SIZE(width), ELM_SCALE_SIZE(height) + (ad->scale * 100));
+               }
+
+       }
+}
+
+static int _up_cb(void *event_info, void *data)
+{
+       if (s_info.is_scroll_freezed == 0) {
+               quickpanel_page_scroll_hold_set(EINA_TRUE);
+       }
+       quickpanel_vim_set_state_ready();
+
+       return QP_OK;
+}
+
+static int _down_cb(void *event_info, void *data)
+{
+       if (s_info.is_scroll_freezed == 0) {
+               quickpanel_page_scroll_hold_set(EINA_FALSE);
+       }
+
+       return QP_OK;
+}
+
+static int _scroll_start_cb(void *event_info, void *data)
+{
+       return QP_OK;
+}
+
+static int _scroll_done_cb(void *event_info, void *data)
+{
+       quickpanel_vim_set_state_suspend();
+
+       return QP_OK;
+}
+
+static void _deleted_cb(void *data, Evas *e, Evas_Object *obj, void *event_info)
+{
+       DBG("deleted view");
+       if (s_info.view_active_buttons != NULL) {
+               quickpanel_settings_gridbox_remove(s_info.view_active_buttons);
+       }
+       if (s_info.view_reserved_buttons != NULL) {
+               quickpanel_settings_gridbox_remove(s_info.view_reserved_buttons);
+       }
+       if (s_info.view_section_2 != NULL) {
+               evas_object_del(s_info.view_section_2);
+       }
+       if (s_info.view_section_1 != NULL) {
+               evas_object_del(s_info.view_section_1);
+       }
+       if (s_info.layout != NULL) {
+               evas_object_del(s_info.layout);
+       }
+       if (s_info.scroller != NULL) {
+               evas_object_del(s_info.scroller);
+       }
+       if (s_info.view != NULL) {
+               evas_object_del(s_info.view);
+       }
+
+       s_info.mapbuf = NULL;
+       s_info.view = NULL;
+       s_info.scroller = NULL;
+       s_info.layout = NULL;
+       s_info.view_section_1 = NULL;
+       s_info.view_section_2 = NULL;
+       s_info.view_active_buttons = NULL;
+       s_info.view_reserved_buttons = NULL;
+}
+
+HAPI Evas_Object *quickpanel_page_edit_create(Evas_Object *parent, void *data)
+{
+       Evas_Object *mapbuf = NULL;
+       Evas_Object *view = NULL;
+       Evas_Object *scroller = NULL;
+       Evas_Object *layout = NULL;
+
+       retif(parent == NULL, NULL, "invalid parameter");
+
+       if (s_info.view == NULL) {
+               mapbuf = elm_mapbuf_add(parent);
+               elm_mapbuf_enabled_set(mapbuf, EINA_FALSE);
+               elm_mapbuf_smooth_set(mapbuf, EINA_FALSE);
+
+               view = quickpanel_uic_load_edj(mapbuf, DEFAULT_EDJ, "quickpanel/page_edit_base", 0);
+               retif(view == NULL, NULL, "failed to load editing layout");
+
+               scroller = elm_scroller_add(view);
+               retif(!scroller, NULL, "fail to add scroller");
+               elm_object_style_set(scroller, "list_effect");
+               elm_scroller_bounce_set(scroller, EINA_FALSE, EINA_TRUE);
+               elm_scroller_policy_set(scroller, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_OFF);
+               evas_object_size_hint_weight_set(scroller, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+               evas_object_size_hint_fill_set(scroller, EVAS_HINT_FILL, EVAS_HINT_FILL);
+               evas_object_show(scroller);
+
+               layout = quickpanel_uic_load_edj(scroller, DEFAULT_EDJ, "quickpanel/page_edit", 0);
+               retif(layout == NULL, NULL, "failed to load editing layout");
+
+               quickpanel_page_handler_set(mapbuf, &page_handler);
+               evas_object_event_callback_add(mapbuf, EVAS_CALLBACK_DEL, _deleted_cb, NULL);
+
+               elm_object_content_set(scroller, layout);
+               elm_object_part_content_set(view, "object.layout", scroller);
+
+               elm_object_content_set(mapbuf, view);
+               evas_object_show(mapbuf);
+
+               s_info.mapbuf = mapbuf;
+               s_info.view = view;
+               s_info.scroller = scroller;
+               s_info.layout = layout;
+
+               elm_object_tree_focus_allow_set(s_info.mapbuf, EINA_FALSE);
+       }
+
+       return s_info.mapbuf;
+}
+
+HAPI Evas_Object *quickpanel_page_edit_view_get(const char *view_name)
+{
+       retif(view_name == NULL, NULL, "invalid parameter");
+
+       if (strcmp(view_name, "VIEW") == 0) {
+               return s_info.view;
+       } else if (strcmp(view_name, "LAYOUT") == 0) {
+               return s_info.layout;
+       } else if (strcmp(view_name, "SECTION.1") == 0) {
+               return s_info.view_section_1;
+       } else if (strcmp(view_name, "SECTION.2") == 0) {
+               return s_info.view_section_2;
+       } else if (strcmp(view_name, "ACTIVE.BUTTONS") == 0) {
+               return s_info.view_active_buttons;
+       } else if (strcmp(view_name, "RESERVED.BUTTONS") == 0) {
+               return s_info.view_reserved_buttons;
+       }
+
+       return NULL;
+}
+
+HAPI void quickpanel_page_edit_view_set(const char *view_name, Evas_Object *view)
+{
+       retif(s_info.view == NULL, , "invalid parameter");
+       retif(s_info.layout == NULL, , "invalid parameter");
+       retif(view_name == NULL, , "invalid parameter");
+       retif(view == NULL, , "invalid parameter");
+
+       if (strcmp(view_name, "SECTION.1") == 0) {
+               elm_object_part_content_set(s_info.layout, "object.section.1", view);
+               s_info.view_section_1 = view;
+       } else if (strcmp(view_name, "SECTION.2") == 0) {
+               elm_object_part_content_set(s_info.layout, "object.section.2", view);
+               s_info.view_section_2 = view;
+       } else if (strcmp(view_name, "ACTIVE.BUTTONS") == 0) {
+               elm_object_part_content_set(s_info.layout, "object.active.buttons", view);
+               s_info.view_active_buttons = view;
+       } else if (strcmp(view_name, "RESERVED.BUTTONS") == 0) {
+               elm_object_part_content_set(s_info.layout, "object.reserved.buttons", view);
+               s_info.view_reserved_buttons = view;
+       }
+}
+
+HAPI void quickpanel_page_edit_freeze_set(Eina_Bool is_freeze)
+{
+       if (is_freeze == EINA_TRUE) {
+               s_info.is_scroll_freezed = 1;
+               quickpanel_page_scroll_freeze_set(EINA_TRUE);
+               _scroll_hold(s_info.scroller);
+       } else {
+               s_info.is_scroll_freezed = 0;
+               quickpanel_page_scroll_freeze_set(EINA_FALSE);
+               _scroll_unhold(s_info.scroller);
+       }
+}
+
+HAPI Eina_Bool quickpanel_page_edit_is_page_showed(void)
+{
+       if (quickpanel_pager_current_page_get() == PAGE_IDX_EDITING) {
+               return EINA_TRUE;
+       }
+
+       return EINA_FALSE;
+}
diff --git a/daemon/page/page_edit.h b/daemon/page/page_edit.h
new file mode 100755 (executable)
index 0000000..83fb44b
--- /dev/null
@@ -0,0 +1,28 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __QUICKPANEL_PAGE_EDIT_H__
+#define __QUICKPANEL_PAGE_EDIT_H__
+
+extern Evas_Object *quickpanel_page_edit_create(Evas_Object *parent, void *data);
+extern Evas_Object *quickpanel_page_edit_view_get(const char *view_name);
+extern void quickpanel_page_edit_view_set(const char *view_name, Evas_Object *view);
+extern void quickpanel_page_edit_freeze_set(Eina_Bool is_freeze);
+extern Eina_Bool quickpanel_page_edit_is_page_showed(void);
+
+#endif
diff --git a/daemon/page/page_setting_all.c b/daemon/page/page_setting_all.c
new file mode 100755 (executable)
index 0000000..408b4c4
--- /dev/null
@@ -0,0 +1,298 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "quickpanel-ui.h"
+#include "common_uic.h"
+#include "common.h"
+#include "pager.h"
+#include "pager_common.h"
+#include "list_util.h"
+#include "vi_manager.h"
+#include "settings_gridbox.h"
+#include "settings_view_all.h"
+#include "quickpanel_def.h"
+
+static void _mapbuf_enable_set(Eina_Bool is_enable);
+static void _content_resize(int width, int height, const char *signal);
+static int _up_cb(void *event_info, void *data);
+static int _down_cb(void *event_info, void *data);
+static int _scroll_start_cb(void *event_info, void *data);
+static int _scroll_done_cb(void *event_info, void *data);
+static int _page_changed_cb(void *event_info, void *data);
+
+static struct info {
+       int is_scroll_freezed;
+       Evas_Object *mapbuf;
+       Evas_Object *view;
+       Evas_Object *scroller;
+       Evas_Object *layout;
+       Evas_Object *view_section_1;
+       Evas_Object *view_active_buttons;
+} s_info = {
+       .is_scroll_freezed = 0,
+       .mapbuf = NULL,
+       .view = NULL,
+       .scroller = NULL,
+       .layout = NULL,
+       .view_section_1 = NULL,
+       .view_active_buttons = NULL,
+};
+
+static QP_Page_Handler page_handler  = {
+       .status = 0,
+       .name = NULL,
+
+       .mapbuf_enable_set = _mapbuf_enable_set,
+       .content_resize = _content_resize,
+       .down_cb = _down_cb,
+       .up_cb = _up_cb,
+       .scroll_start_cb = _scroll_start_cb,
+       .scroll_done_cb = _scroll_done_cb,
+       .page_changed_cb = _page_changed_cb,
+};
+
+static inline void _scroll_hold(Evas_Object *viewer)
+{
+       int hold_count = 0;
+       retif(viewer == NULL, , "Invalid parameter!");
+
+       hold_count = elm_object_scroll_hold_get(viewer);
+
+       if (hold_count <= 0) {
+               elm_object_scroll_hold_push(viewer);
+       }
+}
+
+static inline void _scroll_unhold(Evas_Object *viewer)
+{
+       int i = 0, hold_count = 0;
+       retif(viewer == NULL, , "Invalid parameter!");
+
+       hold_count = elm_object_scroll_hold_get(viewer);
+
+       for (i = 0 ; i < hold_count; i++) {
+               elm_object_scroll_hold_pop(viewer);
+       }
+}
+
+static void _mapbuf_enable_set(Eina_Bool is_enable)
+{
+       Evas_Coord y;
+
+       if (s_info.mapbuf != NULL) {
+               elm_mapbuf_enabled_set(s_info.mapbuf, is_enable);
+       }
+
+       if (is_enable) {
+               evas_object_geometry_get(s_info.mapbuf, NULL, &y, NULL, NULL);
+               evas_object_move(s_info.view, 0, y);
+       }
+}
+
+static void _content_resize(int width, int height, const char *signal)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "invalid parameter");
+
+       if (s_info.view != NULL) {
+               elm_object_signal_emit(s_info.view, signal, "prog");
+               evas_object_size_hint_min_set(s_info.view, ELM_SCALE_SIZE(width), ELM_SCALE_SIZE(height));
+       }
+       if (s_info.layout != NULL) {
+               elm_object_signal_emit(s_info.layout, signal, "prog");
+               if (strcmp(signal, "portrait") == 0) {
+                       evas_object_size_hint_min_set(s_info.layout, ELM_SCALE_SIZE(width), ELM_SCALE_SIZE(height));
+               } else {
+                       evas_object_size_hint_min_set(s_info.layout, ELM_SCALE_SIZE(width), ELM_SCALE_SIZE(height));
+               }
+       }
+}
+
+static int _up_cb(void *event_info, void *data)
+{
+       if (s_info.is_scroll_freezed == 0) {
+               quickpanel_page_scroll_hold_set(EINA_TRUE);
+       }
+
+       return QP_OK;
+}
+
+static int _down_cb(void *event_info, void *data)
+{
+       if (s_info.is_scroll_freezed == 0) {
+               quickpanel_page_scroll_hold_set(EINA_FALSE);
+       }
+
+       return QP_OK;
+}
+
+static int _scroll_start_cb(void *event_info, void *data)
+{
+       return QP_OK;
+}
+
+static int _scroll_done_cb(void *event_info, void *data)
+{
+       quickpanel_vim_set_state_suspend();
+
+       return QP_OK;
+}
+
+static int _page_changed_cb(void *event_info, void *data)
+{
+       return QP_OK;
+}
+
+static void _deleted_cb(void *data, Evas *e, Evas_Object *obj, void *event_info)
+{
+       DBG("deleted view");
+       if (s_info.view_active_buttons != NULL) {
+               quickpanel_settings_gridbox_remove(s_info.view_active_buttons);
+       }
+       if (s_info.view_section_1 != NULL) {
+               evas_object_del(s_info.view_section_1);
+       }
+       if (s_info.layout != NULL) {
+               evas_object_del(s_info.layout);
+       }
+       if (s_info.scroller != NULL) {
+               evas_object_del(s_info.scroller);
+       }
+       if (s_info.view != NULL) {
+               evas_object_del(s_info.view);
+       }
+
+       s_info.mapbuf = NULL;
+       s_info.view = NULL;
+       s_info.scroller = NULL;
+       s_info.layout = NULL;
+       s_info.view_section_1 = NULL;
+       s_info.view_active_buttons = NULL;
+}
+
+HAPI Evas_Object *quickpanel_page_setting_all_create(Evas_Object *parent, void *data)
+{
+       Evas_Object *mapbuf = NULL;
+       Evas_Object *view = NULL;
+       Evas_Object *scroller = NULL;
+       Evas_Object *layout = NULL;
+
+       retif(parent == NULL, NULL, "invalid parameter");
+
+       if (s_info.view == NULL) {
+               mapbuf = elm_mapbuf_add(parent);
+               elm_mapbuf_enabled_set(mapbuf, EINA_FALSE);
+               elm_mapbuf_smooth_set(mapbuf, EINA_FALSE);
+
+               view = quickpanel_uic_load_edj(mapbuf, DEFAULT_EDJ, "quickpanel/page_setting_all_base", 0);
+               retif(view == NULL, NULL, "failed to load editing layout");
+
+               scroller = elm_scroller_add(view);
+               retif(!scroller, NULL, "fail to add scroller");
+               elm_object_style_set(scroller, "list_effect");
+               elm_scroller_bounce_set(scroller, EINA_FALSE, EINA_TRUE);
+               elm_scroller_policy_set(scroller, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_OFF);
+               evas_object_size_hint_weight_set(scroller, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+               evas_object_size_hint_fill_set(scroller, EVAS_HINT_FILL, EVAS_HINT_FILL);
+               evas_object_show(scroller);
+
+               layout = quickpanel_uic_load_edj(scroller, DEFAULT_EDJ, "quickpanel/page_setting_all", 0);
+               retif(layout == NULL, NULL, "failed to load editing layout");
+
+               quickpanel_page_handler_set(mapbuf, &page_handler);
+               evas_object_event_callback_add(mapbuf, EVAS_CALLBACK_DEL, _deleted_cb, NULL);
+
+               elm_object_content_set(scroller, layout);
+               elm_object_part_content_set(view, "object.layout", scroller);
+
+               elm_object_content_set(mapbuf, view);
+               evas_object_show(mapbuf);
+
+               s_info.mapbuf = mapbuf;
+               s_info.view = view;
+               s_info.scroller = scroller;
+               s_info.layout = layout;
+       }
+
+       return s_info.mapbuf;
+}
+
+HAPI Evas_Object *quickpanel_page_setting_all_view_get(const char *view_name)
+{
+       retif(view_name == NULL, NULL, "invalid parameter");
+
+       if (strcmp(view_name, "VIEW") == 0) {
+               return s_info.view;
+       } else if (strcmp(view_name, "LAYOUT") == 0) {
+               return s_info.layout;
+       } else if (strcmp(view_name, "SECTION.1") == 0) {
+               return s_info.view_section_1;
+       } else if (strcmp(view_name, "ACTIVE.BUTTONS") == 0) {
+               return s_info.view_active_buttons;
+       }
+
+       return NULL;
+}
+
+HAPI void quickpanel_page_setting_all_view_set(const char *view_name, Evas_Object *view)
+{
+       retif(s_info.view == NULL, , "invalid parameter");
+       retif(s_info.layout == NULL, , "invalid parameter");
+       retif(view_name == NULL, , "invalid parameter");
+       retif(view == NULL, , "invalid parameter");
+
+       if (strcmp(view_name, "SECTION.1") == 0) {
+               elm_object_part_content_set(s_info.layout, "object.section.1", view);
+               s_info.view_section_1 = view;
+       } else if (strcmp(view_name, "ACTIVE.BUTTONS") == 0) {
+               elm_object_part_content_set(s_info.layout, "object.active.buttons", view);
+               s_info.view_active_buttons = view;
+       }
+}
+
+HAPI void quickpanel_page_setting_all_freeze_set(Eina_Bool is_freeze)
+{
+       if (is_freeze == EINA_TRUE) {
+               s_info.is_scroll_freezed = 1;
+               quickpanel_page_scroll_freeze_set(EINA_TRUE);
+               _scroll_hold(s_info.scroller);
+       } else {
+               s_info.is_scroll_freezed = 0;
+               quickpanel_page_scroll_freeze_set(EINA_FALSE);
+               _scroll_unhold(s_info.scroller);
+       }
+}
+
+HAPI Eina_Bool quickpanel_page_setting_all_is_page_showed(void)
+{
+       if (quickpanel_pager_current_page_get() == PAGE_IDX_EDITING) {
+               return EINA_TRUE;
+       }
+
+       return EINA_FALSE;
+}
+
+HAPI void quickpanel_page_setting_all_focus_allow_set(Eina_Bool is_enable)
+{
+       elm_object_tree_focus_allow_set(s_info.mapbuf, is_enable);
+}
diff --git a/daemon/page/page_setting_all.h b/daemon/page/page_setting_all.h
new file mode 100755 (executable)
index 0000000..b3c7a70
--- /dev/null
@@ -0,0 +1,30 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __QUICKPANEL_PAGE_SETTING_ALL_H__
+#define __QUICKPANEL_PAGE_SETTING_ALL_H__
+
+
+extern Evas_Object *quickpanel_page_setting_all_create(Evas_Object *parent, void *data);
+extern Evas_Object *quickpanel_page_setting_all_view_get(const char *view_name);
+extern void quickpanel_page_setting_all_view_set(const char *view_name, Evas_Object *view);
+extern void quickpanel_page_setting_all_freeze_set(Eina_Bool is_freeze);
+extern Eina_Bool quickpanel_page_setting_all_is_page_showed(void);
+extern void quickpanel_page_setting_all_focus_allow_set(Eina_Bool is_enable);
+
+#endif
diff --git a/daemon/page/pager.c b/daemon/page/pager.c
new file mode 100755 (executable)
index 0000000..8be4093
--- /dev/null
@@ -0,0 +1,566 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "common.h"
+#include "pager.h"
+#include "pager_common.h"
+#include "quickpanel-ui.h"
+#include "quickpanel_def.h"
+
+static int _init(void *data);
+static void _init_job_cb(void *data);
+static int _fini(void *data);
+static int _resume(void *data);
+static void _opened(void *data);
+static void _closed(void *data);
+static void _refresh(void *data);
+static inline void _page_mapbuf_enable_set(Evas_Object *box, int is_enable);
+
+#define ENABLE_MAPBUF 0
+
+typedef enum _qp_pager_state_type {
+       PAGER_STATE_NOT_READY = 0,
+       PAGER_STATE_IDLE,
+       PAGER_STATE_WILL_SCROLL,
+       PAGER_STATE_SCROLLING,
+       PAGER_STATE_FINISHED_SCROLLING,
+} qp_pager_state_type;
+
+QP_Module pager = {
+       .name = "pager",
+       .init = _init,
+       .init_job_cb = _init_job_cb,
+       .fini = _fini,
+       .resume = _resume,
+       .qp_opened = _opened,
+       .qp_closed = _closed,
+       .refresh = _refresh,
+};
+
+static struct info {
+       qp_pager_state_type state;
+       int last_page;
+       int is_in_edge;
+
+       Evas_Object *view_scroller;
+       Evas_Object *view_box;
+
+       Ecore_Event_Handler *hdl_move;
+       Ecore_Event_Handler *hdl_up;
+       Ecore_Event_Handler *hdl_down;
+
+       Ecore_Timer *timer_scroll_adj;
+
+       int scroll_start_from;
+} s_info = {
+       .state = PAGER_STATE_NOT_READY,
+       .last_page = PAGE_IDX_MAIN,
+       .is_in_edge = 0,
+
+       .view_scroller = NULL,
+       .view_box = NULL,
+
+       .hdl_move = NULL,
+       .hdl_up = NULL,
+       .hdl_down = NULL,
+
+       .timer_scroll_adj = NULL,
+
+       .scroll_start_from = -1,
+};
+
+static inline void _set_state(qp_pager_state_type state)
+{
+       if (state == PAGER_STATE_IDLE) {
+               _page_mapbuf_enable_set(s_info.view_box, 0);
+       } else  if (state == PAGER_STATE_WILL_SCROLL || state == PAGER_STATE_SCROLLING) {
+               _page_mapbuf_enable_set(s_info.view_box, 1);
+       }
+       s_info.state = state;
+}
+
+static inline qp_pager_state_type _get_state(void)
+{
+       return s_info.state;
+}
+
+static inline int _last_page_get(void)
+{
+       return s_info.last_page;
+}
+
+static inline void _page_show(int page_index)
+{
+       elm_scroller_page_show(s_info.view_scroller, page_index, 0);
+       s_info.last_page = page_index;
+}
+
+static Eina_Bool _page_adjust_timer_cb(void *data)
+{
+       int index = 0;
+
+       if (s_info.timer_scroll_adj != NULL) {
+               ecore_timer_del(s_info.timer_scroll_adj);
+               s_info.timer_scroll_adj = NULL;
+       }
+
+       elm_scroller_current_page_get(s_info.view_scroller, &index, NULL);
+       elm_scroller_page_bring_in(s_info.view_scroller, index, 0);
+       s_info.last_page = index;
+
+       return ECORE_CALLBACK_CANCEL;
+}
+
+static inline void _page_adjust(int is_use_timer)
+{
+       if (s_info.timer_scroll_adj != NULL) {
+               ecore_timer_del(s_info.timer_scroll_adj);
+               s_info.timer_scroll_adj = NULL;
+       }
+
+       if (is_use_timer) {
+               s_info.timer_scroll_adj = ecore_timer_add(0.1, _page_adjust_timer_cb, NULL);
+       } else {
+               _page_adjust_timer_cb(NULL);
+       }
+}
+
+static inline int _current_page_index_get(void)
+{
+       int index = 0;
+
+       elm_scroller_current_page_get(s_info.view_scroller, &index, NULL);
+
+       return index;
+}
+
+static inline Evas_Object *_current_page_get(void)
+{
+       int index = 0;
+       int list_cnt = 0;
+       Eina_List *list = NULL;
+       static int last_page = -1;
+       Evas_Object *obj = NULL;
+
+       elm_scroller_current_page_get(s_info.view_scroller, &index, NULL);
+
+       if (last_page != index) {
+               DBG("current selected page:%d", index);
+               last_page = index;
+       }
+
+       list = elm_box_children_get(s_info.view_box);
+       if (list != NULL) {
+               list_cnt = eina_list_count(list);
+
+               if (index < list_cnt) {
+                       obj = (Evas_Object *)eina_list_nth(list, index);
+               }
+               eina_list_free(list);
+       }
+
+       return obj;
+}
+
+#if ENABLE_MAPBUF
+static void _mapbuf_job_cb(void *data)
+{
+       Eina_List *list = NULL;
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *box = s_info.view_box;
+       Evas_Object *item = NULL;
+       int is_enable = (int)data;
+       QP_Page_Handler *page_handler = NULL;
+       retif(box == NULL, , "invalid parameter");
+
+       list = elm_box_children_get(box);
+       retif(list == NULL, , "empty box");
+
+       SDBG("mapbuf enable:%d", is_enable);
+
+       EINA_LIST_FOREACH_SAFE(list, l, l_next, item) {
+               page_handler = quickpanel_page_handler_get(item);
+               if (page_handler != NULL) {
+                       if (page_handler->mapbuf_enable_set != NULL) {
+                               if (elm_config_access_get() == EINA_FALSE) {
+                                       if (is_enable == 1) {
+                                               page_handler->mapbuf_enable_set(EINA_TRUE);
+                                       } else {
+                                               page_handler->mapbuf_enable_set(EINA_FALSE);
+                                       }
+                               } else {
+                                       page_handler->mapbuf_enable_set(EINA_FALSE);
+                               }
+                       }
+               }
+       }
+
+       eina_list_free(list);
+}
+#endif
+
+static inline void _page_mapbuf_enable_set(Evas_Object *box, int is_enable)
+{
+#if ENABLE_MAPBUF
+       ecore_job_add(_mapbuf_job_cb, (void *)is_enable);
+#endif
+}
+
+static inline void _page_resize(Evas_Object *box, int width, int height, const char *signal)
+{
+       Eina_List *list = NULL;
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *item = NULL;
+       QP_Page_Handler *page_handler = NULL;
+       retif(box == NULL, , "invalid parameter");
+
+       list = elm_box_children_get(box);
+       retif(list == NULL, , "empty box");
+
+       EINA_LIST_FOREACH_SAFE(list, l, l_next, item) {
+               page_handler = quickpanel_page_handler_get(item);
+
+               if (page_handler != NULL) {
+                       if (page_handler->content_resize != NULL) {
+                               page_handler->content_resize(width, height, signal);
+                       }
+               }
+       }
+
+       eina_list_free(list);
+}
+
+static inline void _page_rotation(void *data)
+{
+       struct appdata *ad = (struct appdata *)data;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       if (ad->angle == 90 || ad->angle == 270) {
+               _page_resize(s_info.view_box, ad->win_height, ad->win_width - ELM_SCALE_SIZE((QP_DATE_H + QP_HANDLE_H)), "landscape");
+       } else {
+               _page_resize(s_info.view_box, ad->win_width, ad->win_height - ELM_SCALE_SIZE((QP_DATE_H + QP_HANDLE_H)), "portrait");
+       }
+}
+
+static Eina_Bool _up_cb(void *data, int type, void *event)
+{
+       Evas_Object *page = _current_page_get();
+       QP_Page_Handler *page_handler = NULL;
+       retif(page == NULL, EINA_FALSE, "Invalid parameter!");
+
+       if (_get_state() == PAGER_STATE_WILL_SCROLL) {
+               _set_state(PAGER_STATE_SCROLLING);
+               _page_adjust(1);
+       }
+
+       page_handler = quickpanel_page_handler_get(page);
+       retif(page_handler == NULL, EINA_FALSE, "no page handler found");
+
+       if (page_handler->up_cb != NULL) {
+               page_handler->up_cb(event, NULL);
+       }
+
+       if (_get_state() == PAGER_STATE_SCROLLING) {
+               _page_adjust(1);
+       }
+
+       return EINA_TRUE;
+}
+
+static Eina_Bool _down_cb(void *data, int type, void *event)
+{
+       Evas_Object *page = _current_page_get();
+       QP_Page_Handler *page_handler = NULL;
+       retif(page == NULL, EINA_FALSE, "Invalid parameter!");
+
+       page_handler = quickpanel_page_handler_get(page);
+       retif(page_handler == NULL, EINA_FALSE, "no page handler found");
+
+       if (page_handler->down_cb != NULL) {
+               page_handler->down_cb(event, NULL);
+       }
+
+       return EINA_TRUE;
+}
+
+static void _scroller_anim_start_cb(void *data, Evas_Object *scroller, void *event_info)
+{
+       Evas_Object *page = _current_page_get();
+       QP_Page_Handler *page_handler = NULL;
+       retif(page == NULL, , "Invalid parameter!");
+
+       s_info.scroll_start_from = _current_page_index_get();
+
+       if (_get_state() == PAGER_STATE_IDLE) {
+               _set_state(PAGER_STATE_WILL_SCROLL);
+
+               page_handler = quickpanel_page_handler_get(page);
+               retif(page_handler == NULL, , "no page handler found");
+
+               if (page_handler->scroll_start_cb != NULL) {
+                       page_handler->scroll_start_cb(event_info, NULL);
+               }
+       }
+}
+
+static void _scroller_anim_stop_cb(void *data, Evas_Object *scroller, void *event_info)
+{
+       Evas_Object *page = _current_page_get();
+       QP_Page_Handler *page_handler = NULL;
+       retif(page == NULL, , "Invalid parameter!");
+
+       if (s_info.is_in_edge == 1 || _get_state() == PAGER_STATE_FINISHED_SCROLLING) {
+               _set_state(PAGER_STATE_IDLE);
+
+               page_handler = quickpanel_page_handler_get(page);
+               retif(page_handler == NULL, , "no page handler found");
+
+               if (page_handler->scroll_done_cb != NULL) {
+                       page_handler->scroll_done_cb(event_info, NULL);
+               }
+
+               _page_mapbuf_enable_set(s_info.view_box, 0);
+       }
+}
+
+static void _scroller_edge_cb(void *data, Evas_Object *scroller, void *event_info)
+{
+       if (_get_state() == PAGER_STATE_WILL_SCROLL
+                       || _get_state() == PAGER_STATE_SCROLLING) {
+               _set_state(PAGER_STATE_FINISHED_SCROLLING);
+               s_info.is_in_edge = 1;
+               _page_adjust(0);
+       }
+}
+
+static void _scroller_scroll_cb(void *data, Evas_Object *scroller, void *event_info)
+{
+       s_info.is_in_edge = 0;
+}
+
+/*****************************************************************************
+ *
+ * Util functions
+ *
+ *****************************************************************************/
+static int _init(void *data)
+{
+       struct appdata *ad = (struct appdata *)data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+       retif(s_info.view_scroller == NULL, QP_FAIL, "Invalid parameter!");
+
+       s_info.hdl_up = ecore_event_handler_add(ECORE_EVENT_MOUSE_BUTTON_UP, _up_cb
+                       , s_info.view_scroller);
+       s_info.hdl_down = ecore_event_handler_add(ECORE_EVENT_MOUSE_BUTTON_DOWN, _down_cb
+                       , s_info.view_scroller);
+
+       evas_object_smart_callback_add(s_info.view_scroller, "scroll,drag,start",
+                       _scroller_anim_start_cb, s_info.view_scroller);
+       evas_object_smart_callback_add(s_info.view_scroller, "scroll,anim,stop",
+                       _scroller_anim_stop_cb, s_info.view_scroller);
+       evas_object_smart_callback_add(s_info.view_scroller, "scroll,drag,stop",
+                       _scroller_anim_stop_cb, s_info.view_scroller);
+       evas_object_smart_callback_add(s_info.view_scroller, "scroll",
+                       _scroller_scroll_cb, s_info.view_scroller);
+
+       evas_object_smart_callback_add(s_info.view_scroller, "edge,left",
+                       _scroller_edge_cb, s_info.view_scroller);
+       evas_object_smart_callback_add(s_info.view_scroller, "edge,right",
+                       _scroller_edge_cb, s_info.view_scroller);
+
+       _set_state(PAGER_STATE_IDLE);
+
+       return QP_OK;
+}
+
+static void _init_job_cb(void *data)
+{
+       struct appdata *ad = (struct appdata *)data;
+       retif(ad == NULL, , "Invalid parameter!");
+       retif(s_info.view_scroller == NULL, , "Invalid parameter!");
+
+       _page_rotation(ad);
+
+       _page_show(PAGE_IDX_MAIN);
+       evas_object_show(s_info.view_scroller);
+}
+
+static int _fini(void *data)
+{
+       struct appdata *ad = (struct appdata *)data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+       if (s_info.hdl_up != NULL) {
+               ecore_event_handler_del(s_info.hdl_up);
+       }
+       if (s_info.hdl_down != NULL) {
+               ecore_event_handler_del(s_info.hdl_down);
+       }
+
+       return QP_OK;
+}
+
+static int _resume(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+       return QP_OK;
+}
+
+static void _opened(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       _page_mapbuf_enable_set(s_info.view_box, 0);
+
+       quickpanel_page_editing_icon_visible_status_update();
+}
+
+static void _closed(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+       retif(s_info.view_scroller == NULL, , "Invalid parameter!");
+
+       _page_show(PAGE_IDX_MAIN);
+       _page_mapbuf_enable_set(s_info.view_box, 0);
+
+       quickpanel_page_editing_icon_visible_status_update();
+}
+
+static void _refresh(void *data) {
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+       retif(s_info.view_box == NULL, , "Invalid parameter!");
+       retif(s_info.view_scroller == NULL, , "Invalid parameter!");
+
+       _page_rotation(ad);
+}
+
+static void _scroller_resized_cb(void *data, Evas * e,
+               Evas_Object * obj, void *event_info)
+{
+       _page_show(PAGE_IDX_MAIN);
+       evas_object_event_callback_del(s_info.view_scroller, EVAS_CALLBACK_RESIZE, _scroller_resized_cb);
+}
+
+HAPI Evas_Object *quickpanel_pager_new(Evas_Object *parent, void *data)
+{
+       Evas_Object *box = NULL;
+       Evas_Object *scroller = NULL;
+
+       retif(parent == NULL, NULL, "failed to memory allocation");
+
+       if (s_info.view_scroller != NULL && s_info.view_box != NULL) {
+               return s_info.view_scroller;
+       }
+
+       scroller = elm_scroller_add(parent);
+       retif(!scroller, NULL, "fail to add scroller");
+       elm_scroller_bounce_set(scroller, EINA_TRUE, EINA_TRUE);
+       elm_scroller_propagate_events_set(scroller, EINA_FALSE);
+       elm_scroller_policy_set(scroller, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_OFF);
+       evas_object_size_hint_weight_set(scroller, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       evas_object_size_hint_fill_set(scroller, EVAS_HINT_FILL, EVAS_HINT_FILL);
+       elm_scroller_page_relative_set (scroller, 1.0, 0.0);
+
+       box = elm_box_add(scroller);
+       if (!box) {
+               ERR("fail to add box");
+               if (scroller != NULL) {
+                       evas_object_del(scroller);
+                       scroller = NULL;
+               }
+               return EINA_FALSE;
+       }
+       evas_object_size_hint_weight_set(box, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       evas_object_size_hint_fill_set(box, EVAS_HINT_FILL, EVAS_HINT_FILL);
+       elm_box_horizontal_set(box, EINA_TRUE);
+       evas_object_show(box);
+
+       elm_object_content_set(scroller, box);
+
+       s_info.view_scroller = scroller;
+       s_info.view_box = box;
+
+       evas_object_event_callback_add(s_info.view_scroller, EVAS_CALLBACK_RESIZE, _scroller_resized_cb, NULL);
+
+       return scroller;
+}
+
+HAPI void quickpanel_pager_destroy(void)
+{
+       if (s_info.view_box != NULL) {
+               elm_box_unpack_all(s_info.view_box);
+               evas_object_del(s_info.view_box);
+               s_info.view_box = NULL;
+       }
+       if (s_info.view_scroller != NULL) {
+               evas_object_del(s_info.view_scroller);
+               s_info.view_scroller = NULL;
+       }
+}
+
+HAPI Evas_Object *quickpanel_pager_view_get(const char *view_name)
+{
+       retif(view_name == NULL, NULL, "invalid parameter");
+
+       if (strcmp(view_name, "SCROLLER") == 0) {
+               return s_info.view_scroller;
+       } else if (strcmp(view_name, "BOX") == 0) {
+               return s_info.view_box;
+       }
+
+       return NULL;
+}
+
+HAPI int quickpanel_pager_current_page_get(void)
+{
+       int index = 0;
+
+       elm_scroller_current_page_get(s_info.view_scroller, &index, NULL);
+
+       return index;
+}
+
+HAPI void quickpanel_pager_page_set(int page_index, int need_resize)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "invalid parameter");
+
+       if (need_resize) {
+               _page_rotation(ad);
+       }
+       _page_show(page_index);
+
+       evas_object_show(s_info.view_scroller);
+}
+
+HAPI void quickpanel_pager_mapbuf_set(int is_enable)
+{
+       _page_mapbuf_enable_set(s_info.view_box, is_enable);
+}
diff --git a/daemon/page/pager.h b/daemon/page/pager.h
new file mode 100755 (executable)
index 0000000..3034348
--- /dev/null
@@ -0,0 +1,49 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __QUICKPANEL_PAGER_H__
+#define __QUICKPANEL_PAGER_H__
+
+
+typedef struct _QP_Page_Handler {
+       int status;
+       char *name;
+       /* func */
+       void (*content_resize)(int width, int height, const char *signal);
+       void (*mapbuf_enable_set)(Eina_Bool is_enable);
+       int (*down_cb)(void *, void *);
+       int (*move_cb)(void *, void *);
+       int (*up_cb)(void *, void *);
+       int (*scroll_start_cb)(void *, void *);
+       int (*scroll_done_cb)(void *, void *);
+       int (*page_changed_cb)(void *, void *);
+} QP_Page_Handler;
+
+typedef enum _qp_pager_page_type {
+       PAGE_IDX_MAIN = 0,
+       PAGE_IDX_EDITING,       // Not supported
+} qp_pager_page_type;
+
+extern Evas_Object *quickpanel_pager_new(Evas_Object *parent, void *data);
+extern void quickpanel_pager_destroy(void);
+extern Evas_Object *quickpanel_pager_view_get(const char *view_name);
+extern int quickpanel_pager_current_page_get(void);
+extern void quickpanel_pager_page_set(int page_index, int need_resize);
+extern void quickpanel_pager_mapbuf_set(int is_enable);
+
+#endif
diff --git a/daemon/page/pager_common.c b/daemon/page/pager_common.c
new file mode 100755 (executable)
index 0000000..f2fa159
--- /dev/null
@@ -0,0 +1,201 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "quickpanel-ui.h"
+#include "common.h"
+#include "pager.h"
+#include "datetime.h"
+
+#define EVAS_DATA_PAGE_HANDLER "page_handler"
+
+static inline void _scroll_hold(Evas_Object *viewer)
+{
+       int hold_count = 0;
+       retif(viewer == NULL, , "Invalid parameter!");
+
+       hold_count = elm_object_scroll_hold_get(viewer);
+
+       if (hold_count <= 0) {
+               elm_object_scroll_hold_push(viewer);
+       }
+}
+
+static inline void _scroll_unhold(Evas_Object *viewer)
+{
+       int i = 0, hold_count = 0;
+       retif(viewer == NULL, , "Invalid parameter!");
+
+       hold_count = elm_object_scroll_hold_get(viewer);
+
+       for (i = 0 ; i < hold_count; i++) {
+               elm_object_scroll_hold_pop(viewer);
+       }
+}
+
+static inline void _scroll_freeze(Evas_Object *viewer)
+{
+       int freezed_count = 0;
+       retif(viewer == NULL, , "Invalid parameter!");
+
+       freezed_count = elm_object_scroll_freeze_get(viewer);
+
+       if (freezed_count <= 0) {
+               elm_object_scroll_freeze_push(viewer);
+       }
+}
+
+static inline void _scroll_unfreeze(Evas_Object *viewer)
+{
+       int i = 0, freezed_count = 0;
+       retif(viewer == NULL, , "Invalid parameter!");
+
+       freezed_count = elm_object_scroll_freeze_get(viewer);
+
+       for (i = 0 ; i < freezed_count; i++) {
+               elm_object_scroll_freeze_pop(viewer);
+       }
+}
+
+HAPI void quickpanel_page_handler_set(Evas_Object *page, QP_Page_Handler *handler)
+{
+       retif(page == NULL, , "invalid parameter");
+
+       evas_object_data_set(page, EVAS_DATA_PAGE_HANDLER, handler);
+}
+
+HAPI QP_Page_Handler *quickpanel_page_handler_get(Evas_Object *page)
+{
+       retif(page == NULL, NULL, "invalid parameter");
+
+       return evas_object_data_get(page, EVAS_DATA_PAGE_HANDLER);
+}
+
+HAPI void quickpanel_page_scroll_freeze_set(Eina_Bool is_freeze)
+{
+       Evas_Object *pager_scroller = quickpanel_pager_view_get("SCROLLER");
+       retif(pager_scroller == NULL, , "pager null");
+
+       if (is_freeze) {
+               _scroll_freeze(pager_scroller);
+       } else {
+               _scroll_unfreeze(pager_scroller);
+       }
+}
+
+HAPI void quickpanel_page_scroll_hold_set(Eina_Bool is_freeze)
+{
+       Evas_Object *pager_scroller = quickpanel_pager_view_get("SCROLLER");
+       retif(pager_scroller == NULL, , "pager null");
+
+       if (is_freeze) {
+               _scroll_hold(pager_scroller);
+       } else {
+               _scroll_unhold(pager_scroller);
+       }
+}
+
+HAPI void quickpanel_page_get_recoordinated_pos(int local_x, int local_y, int *x, int *y)
+{
+       int rot_x = 0;
+       int rot_y = 0;
+       int width = 0;
+       int height = 0;
+       retif(x == NULL && y == NULL, , "invalid parameter");
+
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "invalid parameter");
+
+       elm_win_screen_size_get(ad->win, NULL, NULL, &width, &height);
+
+       switch (ad->angle) {
+       case 0:
+               rot_x = local_x;
+               rot_y = local_y;
+               break;
+       case 90:
+               rot_x = height - local_y;
+               rot_y = local_x;
+               break;
+       case 180:
+               rot_x = width - local_x;
+               rot_y = height - local_y;
+               break;
+       case 270:
+               rot_x = local_y;
+               rot_y = width - local_x;
+               break;
+       default:
+               break;
+       }
+
+       if (x != NULL) {
+               *x = rot_x;
+       }
+
+       if (y != NULL) {
+               *y = rot_y;
+       }
+}
+
+HAPI void quickpanel_page_get_touched_pos(int *x, int *y)
+{
+       int rot_x = 0;
+       int rot_y = 0;
+       int local_x = 0;
+       int local_y = 0;
+       retif(x == NULL && y == NULL, , "invalid parameter");
+
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "invalid parameter");
+
+#if defined(WINSYS_X11)
+       ecore_x_pointer_last_xy_get(&local_x, &local_y);
+#endif
+
+       quickpanel_page_get_recoordinated_pos(local_x, local_y, &rot_x, &rot_y);
+
+       if (x != NULL) {
+               *x = rot_x;
+       }
+
+       if (y != NULL) {
+               *y = rot_y;
+       }
+}
+
+HAPI void quickpanel_page_editing_icon_visible_status_update(void)
+{
+       int is_visible = 0;
+       struct appdata *ad;
+
+       ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "invalid parameter");
+
+       if (quickpanel_pager_current_page_get() == PAGE_IDX_EDITING) {
+               is_visible = 1;
+       } else {
+               is_visible = 0;
+       }
+
+       quickpanel_datetime_editing_icon_visibility_set(is_visible);
+}
diff --git a/daemon/page/pager_common.h b/daemon/page/pager_common.h
new file mode 100755 (executable)
index 0000000..fcae57f
--- /dev/null
@@ -0,0 +1,30 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __QUICKPANEL_PAGER_COMMON_H__
+#define __QUICKPANEL_PAGER_COMMON_H__
+
+extern void quickpanel_page_handler_set(Evas_Object *page, QP_Page_Handler *handler);
+extern QP_Page_Handler *quickpanel_page_handler_get(Evas_Object *page);
+extern void quickpanel_page_scroll_hold_set(Eina_Bool is_freeze);
+extern void quickpanel_page_scroll_freeze_set(Eina_Bool is_freeze);
+extern void quickpanel_page_get_touched_pos(int *x, int *y);
+extern void quickpanel_page_get_recoordinated_pos(int local_x, int local_y, int *x, int *y);
+extern void quickpanel_page_editing_icon_visible_status_update(void);
+
+#endif
diff --git a/daemon/preference.c b/daemon/preference.c
new file mode 100755 (executable)
index 0000000..185b0db
--- /dev/null
@@ -0,0 +1,233 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#include <stdio.h>
+#include <fcntl.h>
+#include <unistd.h>
+
+#include <iniparser.h>
+#include <Elementary.h>
+
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+#include <app_common.h>
+
+#include "preference.h"
+#include "common.h"
+
+
+#include "quickpanel-ui.h"
+
+#define PREFERENCE_FILE_NAME "preference.ini"
+
+static char *_get_preference_file_path()
+{
+       char *data_path = NULL;
+       char file_path[MAX_FILE_PATH_LEN] = {0, };
+
+
+       data_path = app_get_data_path();
+       retif(data_path == NULL, NULL, "failed to app_get_data_path()");
+
+       snprintf(file_path, sizeof(file_path), "%s%s", data_path, PREFERENCE_FILE_NAME);
+       free(data_path);
+
+       return strdup(file_path);
+}
+
+static const char *_default_preference_get(const char *key)
+{
+       retif(key == NULL, NULL, "invalid parameter");
+
+       if (strcmp(key, PREF_BRIGHTNESS) == 0) {
+               return "OFF";
+       } else if (strcmp(key, PREF_QUICKSETTING_ORDER) == 0){
+               return "wifi,gps,sound,rotate,bluetooth,mobile_data,assisitvelight,u_power_saving,wifi_hotspot,flightmode";
+       } else if (strcmp(key, PREF_QUICKSETTING_FEATURED_NUM) == 0){
+               return "11";
+       } else if (strcmp(key, PREF_SHORTCUT_ENABLE) == 0){
+               return "ON";
+       } else if (strcmp(key, PREF_SHORTCUT_EARPHONE_ORDER) == 0){
+               return "org.tizen.music-player,org.tizen.videos,org.tizen.phone,srfxzv8GKR.YouTube,org.tizen.voicerecorder";
+       }
+
+       return NULL;
+}
+
+static inline int _key_validation_check(const char *key)
+{
+       if (strcmp(key, PREF_BRIGHTNESS) == 0) {
+               return 1;
+       } else if (strcmp(key, PREF_QUICKSETTING_ORDER) == 0){
+               return 1;
+       } else if (strcmp(key, PREF_QUICKSETTING_FEATURED_NUM) == 0){
+               return 1;
+       } else if (strcmp(key, PREF_SHORTCUT_ENABLE) == 0){
+               return 1;
+       } else if (strcmp(key, PREF_SHORTCUT_EARPHONE_ORDER) == 0){
+               return 1;
+       }
+
+       return 0;
+}
+
+static inline int _is_file_exist(void)
+{
+       char *file_path = _get_preference_file_path();
+       retif(file_path == NULL, 0, "failed to _get_preference_file_path()");
+
+       if (access(file_path, O_RDWR) == 0) {
+               return 1;
+       }
+
+       if (file_path != NULL) {
+               free(file_path);
+       }
+
+       return 0;
+}
+
+static void _default_file_create(void)
+{
+       FILE    *fp = NULL ;
+       char *file_path = _get_preference_file_path();
+       retif(file_path == NULL, , "failed to _get_preference_file_path()");
+
+       fp = fopen(file_path, "w");
+       retif(fp == NULL, , "fatal:failed to create preference file %s", file_path);
+
+       fprintf(fp, "\n\
+                       [%s]\n\
+                       %s = %s ;\n\
+                       %s = %s ;\n\
+                       %s = %s ;\n\
+                       %s = %s ;\n\
+                       %s = %s ;\n\
+                       \n"
+                       , PREF_SECTION
+                       , PREF_BRIGHTNESS_KEY, _default_preference_get(PREF_BRIGHTNESS)
+                       , PREF_QUICKSETTING_ORDER_KEY, _default_preference_get(PREF_QUICKSETTING_ORDER)
+                       , PREF_QUICKSETTING_FEATURED_NUM_KEY, _default_preference_get(PREF_QUICKSETTING_FEATURED_NUM)
+                       , PREF_SHORTCUT_ENABLE_KEY, _default_preference_get(PREF_SHORTCUT_ENABLE)
+                       , PREF_SHORTCUT_EARPHONE_ORDER_KEY, _default_preference_get(PREF_SHORTCUT_EARPHONE_ORDER)
+                  );
+
+       fclose(fp);
+
+       if (file_path != NULL) {
+               free(file_path);
+       }
+}
+
+HAPI int quickpanel_preference_get(const char *key, char *value)
+{
+       int ret = QP_OK;
+       dictionary      *ini = NULL;
+       const char *value_r = NULL;
+       char *file_path = NULL;
+       retif(key == NULL, QP_FAIL, "Invalid parameter!");
+       retif(value == NULL, QP_FAIL, "Invalid parameter!");
+
+       file_path = _get_preference_file_path();
+       retif(file_path == NULL, QP_FAIL, "failed to _get_preference_file_path()");
+
+       ini = iniparser_load(file_path);
+       if (ini == NULL) {
+               DBG("failed to load ini file");
+               _default_file_create();
+               value_r = _default_preference_get(key);
+               goto END;
+       }
+
+       value_r = iniparser_getstring(ini, key, NULL);
+       if (value_r == NULL) {
+               value_r = _default_preference_get(key);
+               if (_key_validation_check(key) == 1) {
+                       _default_file_create();
+               }
+       } else {
+               DBG("get:[%s]", value_r);
+       }
+
+
+END:
+       if (value_r != NULL) {
+               strncpy(value, value_r, strlen(value_r));
+               ret = QP_OK;
+       }
+
+       if (ini != NULL) {
+               iniparser_freedict(ini);
+       }
+
+       if (file_path != NULL) {
+               free(file_path);
+       }
+
+       return ret;
+}
+
+HAPI const char *quickpanel_preference_default_get(const char *key)
+{
+       retif(key == NULL, NULL, "Invalid parameter!");
+
+       return _default_preference_get(key);
+}
+
+HAPI int quickpanel_preference_set(const char *key, char *value)
+{
+       int ret = QP_FAIL;
+       FILE *fp = NULL;
+       dictionary      *ini = NULL;
+       retif(key == NULL, QP_FAIL, "Invalid parameter!");
+       retif(value == NULL, QP_FAIL, "Invalid parameter!");
+
+       if (_is_file_exist() == 0) {
+               _default_file_create();
+       }
+
+       char *file_path = _get_preference_file_path();
+       retif(file_path == NULL, QP_FAIL, "failed to _get_preference_file_path()");
+
+       ini = iniparser_load(file_path);
+       retif(ini == NULL, QP_FAIL, "failed to load ini file");
+
+       if (iniparser_set(ini, (char *)key, value) == 0) {
+               ret = QP_OK;
+       } else {
+               ERR("failed to write %s=%s", key, value);
+       }
+
+       fp = fopen(file_path, "w");
+       if (fp != NULL) {
+               iniparser_dump_ini(ini, fp);
+               fclose(fp);
+       }
+
+       iniparser_freedict(ini);
+
+       if (file_path != NULL) {
+               free(file_path);
+       }
+
+       return ret;
+}
+
+
+
diff --git a/daemon/preference.h b/daemon/preference.h
new file mode 100755 (executable)
index 0000000..ba26de6
--- /dev/null
@@ -0,0 +1,41 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __QP_PREFERENCE_H_
+#define __QP_PREFERENCE_H_
+
+#define PREF_LEN_VALUE_MAX 256
+
+#define PREF_SECTION "quickpanel"
+#define PREF_BRIGHTNESS_KEY "brightness"
+#define PREF_QUICKSETTING_ORDER_KEY "quicksetting_order"
+#define PREF_QUICKSETTING_FEATURED_NUM_KEY "quicksetting_featured_num"
+#define PREF_SHORTCUT_ENABLE_KEY "shortcut_enable"
+#define PREF_SHORTCUT_EARPHONE_ORDER_KEY "shortcut_earphone"
+
+#define PREF_BRIGHTNESS PREF_SECTION":"PREF_BRIGHTNESS_KEY
+#define PREF_QUICKSETTING_ORDER PREF_SECTION":"PREF_QUICKSETTING_ORDER_KEY
+#define PREF_QUICKSETTING_FEATURED_NUM PREF_SECTION":"PREF_QUICKSETTING_FEATURED_NUM_KEY
+#define PREF_SHORTCUT_ENABLE PREF_SECTION":"PREF_SHORTCUT_ENABLE_KEY
+#define PREF_SHORTCUT_EARPHONE_ORDER PREF_SECTION":"PREF_SHORTCUT_EARPHONE_ORDER_KEY
+
+extern int quickpanel_preference_get(const char *key, char *value);
+extern const char *quickpanel_preference_default_get(const char *key);
+extern int quickpanel_preference_set(const char *key, char *value);
+
+#endif
diff --git a/daemon/quickpanel-ui.c b/daemon/quickpanel-ui.c
new file mode 100755 (executable)
index 0000000..cefa22c
--- /dev/null
@@ -0,0 +1,955 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#include <stdio.h>
+#include <signal.h>
+#include <sys/utsname.h>
+#include <Elementary.h>
+#include <Ecore_Input.h>
+#include <unistd.h>
+#include <malloc.h>
+
+#include <app.h>
+#include <vconf.h>
+#include <E_DBus.h>
+#include <tapi_common.h>
+#include <ITapiSim.h>
+#include <tzsh_quickpanel_service.h>
+#include <notification.h>
+#include <sound_manager.h>
+#include <media.h>
+#include <system_settings.h>
+
+/* quickpanel basics */
+#include "common.h"
+#include "common_uic.h"
+#include "quickpanel-ui.h"
+#include "modules.h"
+#include "quickpanel_def.h"
+#include "list_util.h"
+#include "noti_node.h"
+#include "vi_manager.h"
+#include "pager.h"
+#include "page_base.h"
+#include "page_setting_all.h"
+
+#include "sim_controller.h"
+#include "noti.h"
+
+/* services */
+#include "keyboard.h"
+#include "uninstall.h"
+#ifdef QP_REMINDER_ENABLE
+#include "reminder.h"
+#endif
+#ifdef QP_EMERGENCY_MODE_ENABLE
+#include "emergency_mode.h"
+#endif
+#include "minictrl.h"
+#include "util-time.h"
+
+#define QP_WINDOW_PRIO 300
+
+static struct appdata *g_app_data = NULL;
+
+static void _ui_rotate(void *data, int new_angle);
+static void _ui_geometry_info_set(void *data);
+static void _ui_handler_info_set(void *data);
+static void _ui_efl_cache_flush(void *evas);
+
+HAPI void *quickpanel_get_app_data(void)
+{
+       return g_app_data;
+}
+
+/******************************************************************************
+ *
+ * UI
+ *
+ ****************************************************************************/
+static void _ui_efl_cache_flush(void *evas)
+{
+       int file_cache;
+       int collection_cache;
+       int image_cache;
+       int font_cache;
+
+       retif(evas == NULL, , "Evas is NULL\n");
+       file_cache = edje_file_cache_get();
+       collection_cache = edje_collection_cache_get();
+       image_cache = evas_image_cache_get(evas);
+       font_cache = evas_font_cache_get(evas);
+
+       edje_file_cache_set(file_cache);
+       edje_collection_cache_set(collection_cache);
+       evas_image_cache_set(evas, 0);
+       evas_font_cache_set(evas, 0);
+
+       evas_image_cache_flush(evas);
+       evas_render_idle_flush(evas);
+       evas_font_cache_flush(evas);
+
+       edje_file_cache_flush();
+       edje_collection_cache_flush();
+
+       edje_file_cache_set(file_cache);
+       edje_collection_cache_set(collection_cache);
+       evas_image_cache_set(evas, image_cache);
+       evas_font_cache_set(evas, font_cache);
+
+       elm_cache_all_flush();
+       malloc_trim(0);
+}
+
+static void _ui_handler_input_region_set(void *data, int contents_height)
+{
+       struct appdata *ad = NULL;
+       tzsh_region_h region;
+       unsigned int window_input_region[4] = {0,};
+
+       retif(data == NULL,  , "Invialid parameter!");
+       ad = data;
+       
+       region = tzsh_region_create(ad->tzsh);
+
+       switch (ad->angle) {
+       case 0:
+               window_input_region[0] = 0; //X
+               window_input_region[1] = contents_height; // Y
+               window_input_region[2] = ad->win_width; // Width
+               window_input_region[3] = ELM_SCALE_SIZE(QP_HANDLE_H); // height
+               break;
+       case 90:
+               window_input_region[0] = contents_height; //X
+               window_input_region[1] = 0; // Y
+               window_input_region[2] = ELM_SCALE_SIZE(QP_HANDLE_H); // Width
+               window_input_region[3] = ad->win_height; // height
+               break;
+       case 180:
+               window_input_region[0] = 0; //X
+               window_input_region[1] = ad->win_height - contents_height - ELM_SCALE_SIZE(QP_HANDLE_H); // Y
+               window_input_region[2] = ad->win_width; // Width
+               window_input_region[3] = ELM_SCALE_SIZE(QP_HANDLE_H); // height
+               break;
+       case 270:
+               window_input_region[0] = ad->win_width - contents_height - ELM_SCALE_SIZE(QP_HANDLE_H); //X
+               window_input_region[1] = 0; // Y
+               window_input_region[2] = ELM_SCALE_SIZE(QP_HANDLE_H); // Width
+               window_input_region[3] = ad->win_height; // height
+               break;
+       }
+
+       INFO("win_input_0:%d\nwin_input_1:%d\nwin_input_2:%d\nwin_input_3:%d\n"
+                       ,window_input_region[0]
+                       ,window_input_region[1]
+                       ,window_input_region[2]
+                       ,window_input_region[3]
+               );
+
+       tzsh_region_add(region, window_input_region[0], window_input_region[1], window_input_region[2], window_input_region[3]);
+       tzsh_quickpanel_service_handler_region_set(ad->quickpanel_service, ad->angle, region);
+       tzsh_region_destroy(region);
+}
+
+static void _ui_handler_content_region_set(void *data, int contents_height)
+{
+       struct appdata *ad = NULL;
+
+       tzsh_region_h region;
+
+       unsigned int window_contents_region[4] = {0,};
+
+       retif(data == NULL,  , "Invialid parameter!");
+       ad = data;
+
+       region = tzsh_region_create(ad->tzsh);
+
+       switch (ad->angle) {
+       case 0:
+               window_contents_region[0] = 0; //X
+               window_contents_region[1] = 0; // Y
+               window_contents_region[2] = ad->win_width; // Width
+               window_contents_region[3] = contents_height; // height
+               break;
+       case 90:
+               window_contents_region[0] = 0; //X
+               window_contents_region[1] = 0; // Y
+               window_contents_region[2] = contents_height; // Width
+               window_contents_region[3] = ad->win_height; // height
+               break;
+       case 180:
+               window_contents_region[0] = 0; //X
+               window_contents_region[1] = ad->win_height - contents_height; // Y
+               window_contents_region[2] = ad->win_width; // Width
+               window_contents_region[3] = contents_height; // height
+               break;
+       case 270:
+               window_contents_region[0] = ad->win_width - contents_height ; //X
+               window_contents_region[1] = 0; // Y
+               window_contents_region[2] = contents_height; // Width
+               window_contents_region[3] = ad->win_height; // height
+               break;
+       }
+
+       DBG("win_contents_0:%d\nwin_contents_1:%d\nwin_contents_2:%d\nwin_contents_3:%d\n"
+                       ,window_contents_region[0]
+                       ,window_contents_region[1]
+                       ,window_contents_region[2]
+                       ,window_contents_region[3]
+          );
+
+       tzsh_region_add(region, window_contents_region[0], window_contents_region[1], window_contents_region[2], window_contents_region[3]);
+       tzsh_quickpanel_service_content_region_set(ad->quickpanel_service, ad->angle, region);
+       tzsh_region_destroy(region);
+
+}
+
+static void _ui_handler_info_set(void *data)
+{
+       int contents_height = 0;
+       struct appdata *ad = NULL;
+
+       retif(data == NULL, , "data is NULL");
+       ad = data;
+
+       contents_height = ad->gl_distance_from_top + ad->gl_limit_height;
+
+       _ui_handler_input_region_set(ad, contents_height);
+       _ui_handler_content_region_set(ad, contents_height);
+}
+
+static void _ui_geometry_info_set(void *data)
+{
+       struct appdata *ad = NULL;
+       int max_height_window = 0;
+       Evas_Coord genlist_y = 0;
+
+       retif(data == NULL, , "data is NULL");
+       ad = data;
+
+       if (ad->angle == 90 || ad->angle == 270 ) {
+               max_height_window = ad->win_width;
+       } else {
+               max_height_window = ad->win_height;
+       }
+
+       edje_object_part_geometry_get(_EDJ(ad->ly), "qp.base.list.swallow", NULL, &genlist_y, NULL, NULL);
+
+       ad->gl_distance_from_top = genlist_y;
+       ad->gl_distance_to_bottom = ELM_SCALE_SIZE(QP_HANDLE_H);
+       ad->gl_limit_height = max_height_window - ad->gl_distance_from_top - ad->gl_distance_to_bottom;
+}
+
+/*****************************************************************************
+ *
+ * ui rotation functions
+ *
+ ****************************************************************************/
+static void _ui_rotation_wm_cb(void *data, Evas_Object *obj, void *event)
+{
+       int angle = 0;
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       angle = elm_win_rotation_get((Evas_Object *)obj);
+
+       DBG("ROTATE:%d", angle);
+
+       quickpanel_minictrl_rotation_report(angle);
+
+       _ui_rotate(ad, angle);
+}
+
+static int _ui_rotation_angle_get(void *data)
+{
+       struct appdata *ad = (struct appdata *)data;
+       retif(ad == NULL, 0, "Invalid parameter!");
+       retif(ad->win == NULL, 0, "Invalid parameter!");
+
+       return elm_win_rotation_get(ad->win);
+}
+
+static void _ui_handler_enable_set(Eina_Bool is_enable)
+{
+       const char *signal = NULL;
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "invalid data.");
+       retif(ad->view_root == NULL, , "data is NULL");
+
+       if (is_enable == EINA_TRUE) {
+               signal = "mouse,down,1";
+       } else {
+               signal = "mouse,up,1";
+       }
+
+       elm_object_signal_emit(ad->view_root, signal, "qp.handler.bg");
+}
+
+static void _ui_rotation_handler(struct appdata *ad, int angle)
+{
+       const char *signal = NULL;
+
+       retif(ad == NULL, , "data is NULL");
+       retif(ad->view_root == NULL, , "data is NULL");
+
+
+       if (angle == 90 || angle == 270) {
+               signal = "quickpanel.landscape";
+       } else {
+               signal = "quickpanel.portrait";
+       }
+
+       elm_object_signal_emit(ad->view_root, signal, "quickpanel.prog");
+}
+
+static void _ui_rotate(void *data, int new_angle)
+{
+       struct appdata *ad = data;
+       retif(data == NULL, , "Invalid parameter!");
+
+       DBG("ROTATION: new:%d old:%d", new_angle, ad->angle);
+
+       if (new_angle == 0 || new_angle == 90 || new_angle == 180 || new_angle == 270) {
+               if (new_angle != ad->angle) {
+                       ad->angle = new_angle;
+                       quickpanel_modules_refresh(ad);
+                       _ui_geometry_info_set(ad);
+                       _ui_handler_info_set(ad);
+                       _ui_rotation_handler(ad, ad->angle);
+               }
+       }
+}
+#if 1
+static int _tzsh_set(Evas_Object *win)
+{
+       tzsh_h tzsh = NULL;
+       tzsh_quickpanel_service_h quickpanel_service = NULL;
+       tzsh_window tz_win;
+
+       retif(!win, QP_FAIL, "Invialid parameter!");
+
+       tzsh = tzsh_create(TZSH_TOOLKIT_TYPE_EFL);
+       retif(!tzsh, QP_FAIL, "tzsh_create ERROR!");
+
+       struct appdata *ad = quickpanel_get_app_data();
+
+       ad->tzsh = tzsh;
+
+       tz_win = elm_win_window_id_get(win);
+       if (!tz_win) {
+               tzsh_destroy(tzsh);
+               return QP_FAIL;
+       }
+
+       quickpanel_service = tzsh_quickpanel_service_create(tzsh, tz_win);
+       if (!quickpanel_service) {
+               tzsh_destroy(tzsh);
+               return QP_FAIL;
+       }
+       ad->quickpanel_service = quickpanel_service;
+
+       return QP_OK;
+}
+
+static void _tzsh_unset(void)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+
+       if (ad->quickpanel_service) {
+               tzsh_quickpanel_service_destroy(ad->quickpanel_service);
+               ad->quickpanel_service = NULL;
+       }
+
+       if (ad->tzsh) {
+               tzsh_destroy(ad->tzsh);
+               ad->tzsh = NULL;
+       }
+}
+#endif
+
+/*****************************************************************************
+ *
+ * ui creation/deletion functions
+ *
+ ****************************************************************************/
+static Evas_Object *_ui_window_add(const char *name, int prio)
+{
+       Evas_Object *eo = NULL;
+
+       eo = elm_win_add(NULL, name, ELM_WIN_BASIC);
+
+       if (eo != NULL) {
+               elm_win_alpha_set(eo, EINA_TRUE);
+               elm_win_indicator_mode_set(eo, ELM_WIN_INDICATOR_HIDE);
+
+               elm_win_title_set(eo, name);
+               elm_win_borderless_set(eo, EINA_TRUE);
+               elm_win_autodel_set(eo, EINA_TRUE);
+
+               /* set this window as a quickpanel */
+               elm_win_quickpanel_set(eo, 1);
+               elm_win_quickpanel_priority_major_set(eo, prio);
+
+               if (elm_win_wm_rotation_supported_get(eo)) {
+                       int rots[4] = { 0, 90, 180, 270 };
+                       elm_win_wm_rotation_available_rotations_set(eo, rots, 4);
+               }
+
+               evas_object_show(eo);
+
+               if( QP_OK != _tzsh_set(eo)) {
+                       ERR("Failed to set tzsh");
+               }
+       }
+
+       return eo;
+}
+
+static int _ui_gui_create(void *data)
+{
+       struct appdata *ad = data;
+       int w = 0, h = 0;
+       int initial_angle = 0;
+       Evas_Object *page_base = NULL;
+
+       retif(data == NULL, QP_FAIL, "Invialid parameter!");
+
+       ad->win = _ui_window_add("Quickpanel Window",
+                       QP_WINDOW_PRIO);
+       retif(ad->win == NULL, QP_FAIL, "Failed to create main window");
+       //build error
+       //elm_win_focus_allow_set(ad->win, EINA_TRUE);
+
+       evas_object_smart_callback_add(ad->win, "wm,rotation,changed",
+                       _ui_rotation_wm_cb, ad);
+
+       ad->background = elm_bg_add(ad->win);
+       if (ad->background  != NULL) {
+               evas_object_size_hint_weight_set(ad->background,
+                               EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+               elm_win_resize_object_add(ad->win, ad->background);
+               evas_object_show(ad->background);
+       } else {
+               ERR("failed to create background");
+       }
+
+       ad->view_root = quickpanel_uic_load_edj(ad->background,
+                       DEFAULT_EDJ, "quickpanel/root", 0);
+       retif(ad->view_root == NULL, QP_FAIL, "Failed to create main page");
+
+       Evas_Object *pager_scroller = quickpanel_pager_new(ad->view_root, NULL);
+       Evas_Object *pager_box = quickpanel_pager_view_get("BOX");
+
+       page_base = quickpanel_page_base_create(pager_box, NULL);
+       retif(page_base == NULL, QP_FAIL, "Failed to create main page");
+       ad->ly = quickpanel_page_base_view_get("LAYOUT");
+       retif(ad->ly == NULL, QP_FAIL, "Failed to create main page");
+
+       elm_box_pack_end(pager_box, page_base);
+       elm_win_resize_object_add(ad->win, ad->view_root);
+       elm_object_part_content_set(ad->view_root, "qp.root.swallow", pager_scroller);
+
+       /* get noti evas */
+       ad->evas = evas_object_evas_get(ad->win);
+       ad->list = quickpanel_page_base_view_get("BOX");
+       ad->scroller = quickpanel_page_base_view_get("SCROLLER");
+
+       //ecore_x_window_size_get(ecore_x_window_root_first_get(), &w, &h);
+       elm_win_screen_size_get(ad->win, NULL, NULL, &w, &h);
+       evas_object_resize(ad->win, w, h);
+
+       ad->win_width = w;
+       ad->win_height = h;
+
+       _ui_geometry_info_set(ad);
+
+       initial_angle = _ui_rotation_angle_get(ad);
+       _ui_rotate(ad, initial_angle);
+
+       quickpanel_pager_page_set(PAGE_IDX_MAIN, 1);
+
+       sim_controller_init(ad->ly);
+
+       quickpanel_noti_init_noti_section();
+
+       return 0;
+}
+
+static int _ui_gui_destroy(void *data)
+{
+       struct appdata *ad = data;
+       retif(data == NULL, QP_FAIL, "Invialid parameter!");
+
+       if (ad->list != NULL) {
+               evas_object_del(ad->list);
+               ad->list = NULL;
+       }
+       if (ad->scroller != NULL) {
+               evas_object_del(ad->scroller);
+               ad->scroller = NULL;
+       }
+       if (ad->ly != NULL) {
+               evas_object_del(ad->ly);
+               ad->ly = NULL;
+       }
+       if (ad->win != NULL) {
+               evas_object_del(ad->win);
+               ad->win = NULL;
+       }
+
+       _tzsh_unset();
+
+       return QP_OK;
+}
+
+static void _ui_setting_visibility_set(struct appdata *ad, int show)
+{
+       retif(ad == NULL, , "data is NULL");
+       retif(ad->ly == NULL, , "data is NULL");
+
+       elm_object_signal_emit(ad->ly, "quickpanel.setting.show",
+                       "quickpanel.prog");
+}
+
+/*****************************************************************************
+ *
+ * event handler initialization functions
+ *
+ ****************************************************************************/
+static void _vconf_event_powerff_cb(keynode_t *node,
+               void *data)
+{
+       int val;
+       if (vconf_get_int(VCONFKEY_SYSMAN_POWER_OFF_STATUS, &val) == 0 &&
+                       (val == VCONFKEY_SYSMAN_POWER_OFF_DIRECT || val == VCONFKEY_SYSMAN_POWER_OFF_RESTART)) {
+               ui_app_exit();
+       }
+}
+
+static void _vconf_event_lcdoff_cb(keynode_t *node,
+               void *data)
+{
+       int ret = 0;
+       int pm_state = VCONFKEY_PM_STATE_NORMAL;
+
+       ret = vconf_get_int(VCONFKEY_PM_STATE, &pm_state);
+
+       if (ret == 0 && pm_state == VCONFKEY_PM_STATE_LCDOFF) {
+               quickpanel_uic_close_quickpanel(false, 0);
+       }
+}
+
+
+void _event_message_cb(void *data, Evas_Object *obj, void *event_info)
+ {
+       bool visiblity = (bool)event_info;
+       struct appdata *ad = data;
+
+       if(visiblity == 1) { // show
+               DBG("quickpanel is opened");
+
+               ad->is_opened = 1;
+               quickpanel_util_time_timer_enable_set(1);
+               quickpanel_keyboard_openning_init(ad);
+               quickpanel_modules_opened(data);
+               quickpanel_uic_opened_reason_set(OPENED_NO_REASON);
+       } else {
+               DBG("quickpanel is closed");
+
+               ad->is_opened = 0;
+               quickpanel_util_time_timer_enable_set(0);
+               quickpanel_keyboard_closing_fini(ad);
+               quickpanel_modules_closed(data);
+       }
+       quickpanel_media_player_stop();
+ }
+
+static void _vconf_init(struct appdata *ad)
+{
+       int ret = 0;
+
+       ret = vconf_notify_key_changed(VCONFKEY_PM_STATE,
+                       _vconf_event_lcdoff_cb, ad);
+       if (ret != 0) {
+               ERR("VCONFKEY_PM_STATE: %d", ret);
+       }
+
+       ret = vconf_notify_key_changed(VCONFKEY_SYSMAN_POWER_OFF_STATUS,
+                       _vconf_event_powerff_cb, ad);
+       if (ret != 0) {
+               ERR("VCONFKEY_PM_STATE: %d", ret);
+       }
+}
+
+static void _vconf_fini(struct appdata *ad)
+{
+       int ret = 0;
+
+       ret = vconf_ignore_key_changed(VCONFKEY_PM_STATE,
+                       _vconf_event_lcdoff_cb);
+       if (ret != 0) {
+               ERR("VCONFKEY_PM_STATE: %d", ret);
+       }
+
+       ret = vconf_ignore_key_changed(VCONFKEY_SYSMAN_POWER_OFF_STATUS,
+                       _vconf_event_powerff_cb);
+       if (ret != 0) {
+               ERR("VCONFKEY_PM_STATE: %d", ret);
+       }
+}
+
+static void _edbus_init(struct appdata *ad)
+{
+       e_dbus_init();
+       ad->dbus_connection = e_dbus_bus_get(DBUS_BUS_SYSTEM);
+       if (ad->dbus_connection == NULL) {
+               ERR("noti register : failed to get dbus bus");
+       }
+}
+
+static void _edbus_fini(struct appdata *ad)
+{
+       if (ad->dbus_connection != NULL) {
+               e_dbus_connection_close(ad->dbus_connection);
+               ad->dbus_connection = NULL;
+               e_dbus_shutdown();
+       }
+}
+
+static void _ecore_event_init(struct appdata *ad)
+{
+       DBG("");
+       evas_object_smart_callback_add(ad->win, "visibility,changed", _event_message_cb, ad);
+}
+
+static void _ecore_event_fini(struct appdata *ad)
+{
+       if (ad->hdl_client_message != NULL) {
+               ecore_event_handler_del(ad->hdl_client_message);
+               ad->hdl_client_message = NULL;
+       }
+}
+
+/*****************************************************************************
+ *
+ * App efl main interface
+ *
+ ****************************************************************************/
+static void _sigaction_terminate_handler(int signum, siginfo_t *info, void *unused)
+{
+       ERR("quickpanel going to be terminated");
+       ui_app_exit();
+}
+
+static void _service_request_process(app_control_h service, void *data)
+{
+       char *value = NULL;
+       retif(service == NULL, , "Invialid parameter!");
+
+       if (!app_control_get_extra_data(service, "HIDE_LAUNCH", &value))
+       {
+               if (value != NULL) {
+                       ERR("HIDE_LAUNCH: %s", value);
+                       if (!strcmp(value, "1")) {
+                               quickpanel_uic_close_quickpanel(false, 0);
+                       } else {
+                               quickpanel_uic_open_quickpanel(OPENED_BY_CMD_HIDE_LAUNCH);
+                       }
+
+                       free(value);
+               }
+       } else if (!app_control_get_extra_data(service, "SHOW_SETTINGS", &value)) {
+               if (value != NULL) {
+                       ERR("SHOW_SETTINGS: %s", value);
+                       if (!strcmp(value, "1")) {
+                               quickpanel_pager_page_set(PAGE_IDX_EDITING, 0);
+                               quickpanel_uic_open_quickpanel(OPENED_BY_CMD_SHOW_SETTINGS);
+                       }
+
+                       free(value);
+               }
+       }
+#ifdef QP_EMERGENCY_MODE_ENABLE
+       else if (!app_control_get_extra_data(service, "EMERGENCY_MODE_LAUNCH", &value)) {
+               if (value != NULL) {
+                       ERR("EMERGENCY_MODE_LAUNCH: %s", value);
+                       if (!strcmp(value, "1")) {
+                               if (quickpanel_emergency_mode_syspopup_launch() == QP_FAIL) {
+                                       ERR("failed to launch emergency mode syspopup");
+                               } else {
+                                       quickpanel_uic_close_quickpanel(true, 0);
+                               }
+                       }
+
+                       free(value);
+               }
+       }
+#endif
+}
+
+static Eina_Bool _appcore_cache_flush_timer_cb(void *data)
+{
+       if (!quickpanel_uic_is_suspended()) {
+               return ECORE_CALLBACK_CANCEL;
+       }
+
+       return ECORE_CALLBACK_CANCEL;
+}
+
+static Eina_Bool _ui_refresh_idler_cb(void *data)
+{
+       DBG("");
+       struct appdata *ad = data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+       quickpanel_modules_refresh(ad);
+       _ui_geometry_info_set(ad);
+       _ui_handler_info_set(ad);
+
+       /*      Cache memory is cleared when the application paused (every time, after 5 seconds (in appcore)),
+        *      but after running in a minimized mode application have status AS_RUNNING.
+        *      Application have status AS_PAUSED only after change of visibility to hidden condition by user (on hiding window)
+        *      Cleaning must be performed only once after application loading in hidden condition
+        *      (and stay in a hidden condition at time of cleaning).
+        */
+       ecore_timer_add(10, _appcore_cache_flush_timer_cb, NULL);
+
+       return EINA_FALSE;
+}
+
+static void _quickpanel_initialize(void *data)
+{
+       int ret = 0;
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invialid parameter!");
+
+       INFO(">> Creating Quickpanel");
+       /* Check emulator */
+       ad->is_emul = quickpanel_uic_is_emul();
+       INFO("quickpanel run in %s", ad->is_emul ? "Emul" : "Device");
+
+       int w, h;
+       elm_win_screen_size_get(ad->win, NULL, NULL, &w, &h);
+       ad->scale = elm_config_scale_get();
+       if (ad->scale < 0) {
+               ad->scale = 1.0;
+       }
+
+       INFO("quickpanel scale %f", ad->scale);
+
+       ad->is_suspended = 1;
+
+       /* Get theme */
+       elm_theme_extension_add(NULL, DEFAULT_THEME_EDJ);
+       /* create quickpanel window */
+       ret = _ui_gui_create(ad);
+       retif(ret != QP_OK, , "Failed to create window!");
+
+       quickpanel_media_init();
+
+       _ecore_event_init(ad);
+       _vconf_init(ad);
+       _edbus_init(ad);
+
+       quickpanel_uninstall_init(ad);
+#ifdef QP_EMERGENCY_MODE_ENABLE
+       quickpanel_emergency_mode_init(ad);
+#endif
+       quickpanel_keyboard_init(ad);
+#ifdef QP_REMINDER_ENABLE
+       quickpanel_reminder_init(ad);
+#endif
+
+#ifdef QP_SETTING_ENABLE
+       _ui_setting_visibility_set(ad, 1);
+#else /* QP_SETTING_ENABLE */
+       _ui_setting_visibility_set(ad, 0);
+#endif /* QP_SETTING_ENABLE */
+
+       /* init quickpanel modules */
+       quickpanel_modules_init(ad);
+       ecore_idler_add(_ui_refresh_idler_cb, ad);
+}
+
+static bool _app_create_cb(void *data)
+{
+       ERR("");
+
+       elm_app_base_scale_set(1.8);
+
+       pid_t pid;
+       int r;
+       char err_buf[128] = {0,};
+
+       // signal handler
+       struct sigaction act;
+       act.sa_sigaction = _sigaction_terminate_handler;
+       act.sa_flags = SA_SIGINFO;
+
+       int ret = sigemptyset(&act.sa_mask);
+       if (ret < 0) {
+               strerror_r(errno, err_buf, sizeof(err_buf));
+               ERR("Failed to sigemptyset[%d / %s]", errno, err_buf);
+       }
+       ret = sigaddset(&act.sa_mask, SIGTERM);
+       if (ret < 0) {
+               strerror_r(errno, err_buf, sizeof(err_buf));
+               ERR("Failed to sigaddset[%d / %s]", errno, err_buf);
+       }
+       ret = sigaction(SIGTERM, &act, NULL);
+       if (ret < 0) {
+               strerror_r(errno, err_buf, sizeof(err_buf));
+               ERR("Failed to sigaction[%d / %s]", errno, err_buf);
+       }
+
+       pid = setsid();
+       if (pid < 0) {
+               WARN("Failed to set session id!");
+       }
+
+       r = nice(2);
+       if (r == -1) {
+               WARN("Failed to set nice value!");
+       }
+
+       return TRUE;
+}
+
+static void _app_service_cb(app_control_h service, void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invialid parameter!");
+
+       if (ad->win == NULL && ad->ly == NULL) {
+               _quickpanel_initialize(data);
+       } else {
+               _service_request_process(service, data);
+       }
+}
+
+static void _app_terminate_cb(void *data)
+{
+       ERR("");
+
+       struct appdata *ad = data;
+       retif(ad == NULL, , "invalid data.");
+
+       quickpanel_media_fini();
+
+       /* fini quickpanel modules */
+       quickpanel_modules_fini(ad);
+       _edbus_fini(ad);
+       _vconf_fini(ad);
+       _ecore_event_fini(ad);
+
+       quickpanel_keyboard_fini(ad);
+       quickpanel_uninstall_fini(ad);
+#ifdef QP_REMINDER_ENABLE
+       quickpanel_reminder_fini(ad);
+#endif
+#ifdef QP_EMERGENCY_MODE_ENABLE
+       quickpanel_emergency_mode_fini(ad);
+#endif
+
+       /* delete quickpanel window */
+       _ui_gui_destroy(ad);
+
+       INFO("Quickpanel is terminated");
+}
+
+static void _app_resume_cb(void *data)
+{
+       DBG("");
+       struct appdata *ad = data;
+       retif(ad == NULL,, "invalid data.");
+
+       ad->is_suspended = 0;
+       _ui_handler_enable_set(EINA_FALSE);
+
+       quickpanel_modules_resume(data);
+
+       sim_controller_resume();
+}
+
+static void _app_pause_cb(void *data)
+{
+       DBG("");
+       struct appdata *ad = data;
+       retif(ad == NULL,, "invalid data.");
+
+
+       quickpanel_modules_suspend(ad);
+
+       ad->is_suspended = 1;
+
+       if (ad->evas != NULL) {
+               _ui_efl_cache_flush(ad->evas);
+               evas_event_feed_mouse_cancel(ad->evas, ecore_time_get(), NULL);
+       }
+}
+
+static void _app_language_changed_cb(app_event_info_h event_info, void *data)
+{
+       DBG("");
+       quickpanel_modules_lang_change(data);
+
+       sim_controller_on_language_change();
+}
+
+static void _app_region_format_changed_cb(app_event_info_h event_info, void *data)
+{
+       DBG("");
+       quickpanel_modules_lang_change(data);
+}
+
+int main(int argc, char *argv[])
+{
+       INFO("BUILD START: %s %s", __DATE__, __TIME__);
+       ERR("BUILD START: %s %s", __DATE__, __TIME__);
+
+       int ret = 0;
+       struct appdata ad;
+       ui_app_lifecycle_callback_s event_callback = {0,};
+       app_event_handler_h handlers[5] = {NULL, };
+
+       ERR("quickpanel is forked");
+
+       event_callback.create = _app_create_cb;
+       event_callback.terminate = _app_terminate_cb;
+       event_callback.pause = _app_pause_cb;
+       event_callback.resume = _app_resume_cb;
+       event_callback.app_control = _app_service_cb;
+
+//     ui_app_add_event_handler(&handlers[APP_EVENT_LOW_BATTERY], APP_EVENT_LOW_BATTERY, NULL, NULL);
+//     ui_app_add_event_handler(&handlers[APP_EVENT_LOW_MEMORY], APP_EVENT_LOW_MEMORY, NULL, NULL);
+//     ui_app_add_event_handler(&handlers[APP_EVENT_DEVICE_ORIENTATION_CHANGED], APP_EVENT_DEVICE_ORIENTATION_CHANGED, NULL, NULL);
+       ui_app_add_event_handler(&handlers[APP_EVENT_LANGUAGE_CHANGED], APP_EVENT_LANGUAGE_CHANGED, _app_language_changed_cb, &ad);
+       ui_app_add_event_handler(&handlers[APP_EVENT_REGION_FORMAT_CHANGED], APP_EVENT_REGION_FORMAT_CHANGED, _app_region_format_changed_cb, &ad);
+
+       memset(&ad, 0x0, sizeof(struct appdata));
+
+       g_app_data = &ad;
+
+       ret = ui_app_main(argc, argv, &event_callback, (void *)&ad);
+       if (ret != APP_ERROR_NONE) {
+               ERR("ui_app_main() is failed. err = %d", ret);
+       }
+
+       return ret;
+
+}
diff --git a/daemon/quickpanel-ui.h b/daemon/quickpanel-ui.h
new file mode 100755 (executable)
index 0000000..6c8606b
--- /dev/null
@@ -0,0 +1,142 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __QUICKPANEL_UI_H__
+#define __QUICKPANEL_UI_H__
+
+#if !defined(PACKAGE)
+#  define PACKAGE      "quickpanel"
+#endif
+
+#if !defined(LOCALEDIR)
+#  define LOCALEDIR    "/usr/apps/org.tizen.quickpanel/res/locale"
+#endif
+
+#if !defined(EDJDIR)
+#  define EDJDIR       "/usr/apps/org.tizen.quickpanel/res/edje"
+#endif
+
+#if !defined(SHARED_DIR)
+#  define SHARED_DIR   "/usr/apps/org.tizen.quickpanel/shared/res"
+#endif
+
+/* EDJ theme */
+#define DEFAULT_EDJ            EDJDIR"/"PACKAGE".edj"
+#define DEFAULT_THEME_EDJ      EDJDIR"/"PACKAGE"_theme.edj"
+#define SLIDER_THEME_EDJ EDJDIR"/"PACKAGE"_slider_theme.edj"
+#define ACTIVENOTI_EDJ         EDJDIR"/"PACKAGE"_activenoti.edj"
+
+#define _EDJ(o) elm_layout_edje_get(o)
+
+#undef _
+#define _(str) gettext(str)
+#define _NOT_LOCALIZED(str) (str)
+
+#define STR_ATOM_WINDOW_INPUT_REGION    "_E_COMP_WINDOW_INPUT_REGION"
+#define STR_ATOM_WINDOW_CONTENTS_REGION "_E_COMP_WINDOW_CONTENTS_REGION"
+
+#define MAX_NAM_LEN 4096
+#define MAX_FILE_PATH_LEN 1024
+
+#define INDICATOR_COVER_W 64
+#define INDICATOR_COVER_H 60
+
+#define _NEWLINE '\n'
+#define _SPACE ' '
+
+#define QP_DBUS_NAME "org.tizen.quickpanel"
+#define QP_DBUS_PATH "/Org/Tizen/Quickpanel"
+
+#define QP_DBUS_CLIENT_NAME "org.tizen.quickpanelsetting"
+#define QP_DBUS_CLIENT_PATH "/Org/Tizen/Quickpanelsetting"
+
+#if !defined(VENDOR)
+#define QP_PKG_QUICKPANEL      "org.tizen.quickpanel"
+#define QP_SETTING_PKG_SETTING "org.tizen.setting"
+#define QP_MINIAPPTRAY_PKG "org.tizen.mini-apps"
+#else
+#define QP_PKG_QUICKPANEL      VENDOR".quickpanel"
+#define QP_SETTING_PKG_SETTING VENDOR".setting"
+#define QP_MINIAPPTRAY_PKG VENDOR".mini-apps"
+#endif
+#define QP_SEARCH_PKG "org.tizen.sfinder"
+
+struct appdata {
+       Evas_Object *win;
+       tzsh_h tzsh;
+       tzsh_quickpanel_service_h quickpanel_service;
+
+       Evas_Object *background;
+       Evas_Object *view_root;
+       Evas_Object *view_page_zero;
+       Evas_Object *ly; //view_base
+
+       Evas *evas;
+
+       Evas_Object *scroller;
+       Evas_Object *list;
+       Evas_Object *popup;
+       int angle;
+       double scale;
+       char *theme;
+
+       int win_width;
+       int win_height;
+       int gl_limit_height;
+       int gl_distance_from_top;
+       int gl_distance_to_bottom;
+
+       int is_emul; /* 0 : target, 1 : emul */
+       int is_suspended;
+       int is_opened;
+       int opening_reason;
+
+       Ecore_Event_Handler *hdl_client_message;
+       Ecore_Event_Handler *hdl_hardkey_down;
+       Ecore_Event_Handler *hdl_hardkey_up;
+       Eina_Bool is_hardkey_cancel;
+
+       E_DBus_Connection *dbus_connection;
+};
+
+typedef struct _QP_Module {
+       char *name;
+       /* func */
+       int (*init) (void *);
+       void (*init_job_cb) (void *);
+       int (*fini) (void *);
+       int (*suspend) (void *);
+       int (*resume) (void *);
+       int (*hib_enter) (void *);
+       int (*hib_leave) (void *);
+       void (*lang_changed) (void *);
+       void (*refresh) (void *);
+       unsigned int (*get_height) (void *);
+       void (*qp_opened) (void *);
+       void (*qp_closed) (void *);
+       void (*mw_enabled) (void *);
+       void (*mw_disabled) (void *);
+
+       /* do not modify this area */
+       /* internal data */
+       Eina_Bool state;
+} QP_Module;
+
+extern void *quickpanel_get_app_data(void);
+
+#endif                         /* __QUICKPANEL_UI_H__ */
diff --git a/daemon/service/animated_icon.c b/daemon/service/animated_icon.c
new file mode 100755 (executable)
index 0000000..3fcdb4c
--- /dev/null
@@ -0,0 +1,96 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "quickpanel-ui.h"
+#include "common.h"
+#include "quickpanel_def.h"
+#include "animated_icon.h"
+
+#define E_DATA_ANI_ICON_TYPE "ANI_ICON_TYPE"
+#define PATH_DOWNLOAD "reserved://quickpanel/ani/downloading"
+#define PATH_UPLOAD "reserved://quickpanel/ani/uploading"
+#define PATH_INSTALL "reserved://quickpanel/ani/install"
+
+static qp_animated_icon_type _animated_type_get(const char *path)
+{
+       retif_nomsg(path == NULL, QP_ANIMATED_ICON_NONE);
+
+       if (strncasecmp(path, PATH_DOWNLOAD, MIN(strlen(PATH_DOWNLOAD), strlen(path))) == 0) {
+               return QP_ANIMATED_ICON_DOWNLOAD;
+       } else if (strncasecmp(path, PATH_UPLOAD, MIN(strlen(PATH_UPLOAD), strlen(path))) == 0) {
+               return QP_ANIMATED_ICON_UPLOAD;
+       } else if (strncasecmp(path, PATH_INSTALL, MIN(strlen(PATH_INSTALL), strlen(path))) == 0) {
+               return QP_ANIMATED_ICON_INSTALL;
+       }
+
+       return QP_ANIMATED_ICON_NONE;
+}
+
+HAPI Evas_Object *quickpanel_animated_icon_get(Evas_Object *parent, const char *path)
+{
+       qp_animated_icon_type type = QP_ANIMATED_ICON_NONE;
+       const char *layout_icon = NULL;
+       Evas_Object *layout = NULL;
+       retif_nomsg(parent == NULL, NULL);
+       retif_nomsg(path == NULL, NULL);
+
+       type = _animated_type_get(path);
+
+       if (type == QP_ANIMATED_ICON_DOWNLOAD) {
+               layout_icon = "quickpanel/animated_icon_download";
+       } else if (type == QP_ANIMATED_ICON_UPLOAD) {
+               layout_icon = "quickpanel/animated_icon_upload";
+       } else if (type == QP_ANIMATED_ICON_INSTALL) {
+               layout_icon = "quickpanel/animated_icon_install";
+       } else {
+               return NULL;
+       }
+
+       layout = elm_layout_add(parent);
+       if (layout != NULL) {
+               elm_layout_file_set(layout, DEFAULT_EDJ, layout_icon);
+               evas_object_size_hint_weight_set(layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+               evas_object_size_hint_align_set(layout, EVAS_HINT_FILL, EVAS_HINT_FILL);
+               evas_object_data_set(layout, E_DATA_ANI_ICON_TYPE, (void *)type);
+               evas_object_show(layout);
+       }
+
+       return layout;
+}
+
+HAPI int quickpanel_animated_icon_is_same_icon(Evas_Object *view, const char *path)
+{
+       qp_animated_icon_type type = QP_ANIMATED_ICON_NONE;
+       qp_animated_icon_type type_old = QP_ANIMATED_ICON_NONE;
+       retif_nomsg(view == NULL, 0);
+       retif_nomsg(path == NULL, 0);
+
+       type = _animated_type_get(path);
+       type_old = (qp_animated_icon_type)evas_object_data_get(view,
+                       E_DATA_ANI_ICON_TYPE);
+
+       if (type == type_old) {
+               return 1;
+       }
+
+       return 0;
+}
diff --git a/daemon/service/animated_icon.h b/daemon/service/animated_icon.h
new file mode 100755 (executable)
index 0000000..0c970a7
--- /dev/null
@@ -0,0 +1,34 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+
+#ifndef _QP_SERVICE_ANIMATED_ICON_DEF_
+#define _QP_SERVICE_ANIMATED_ICON_DEF_
+
+
+typedef enum _qp_animated_icon_type {
+       QP_ANIMATED_ICON_NONE = -1,
+       QP_ANIMATED_ICON_DOWNLOAD = 1,
+       QP_ANIMATED_ICON_UPLOAD,
+       QP_ANIMATED_ICON_INSTALL,
+} qp_animated_icon_type;
+
+extern Evas_Object *quickpanel_animated_icon_get(Evas_Object *parent, const char *path);
+extern int quickpanel_animated_icon_is_same_icon(Evas_Object *view, const char *path);
+
+#endif
diff --git a/daemon/service/emergency_mode.c b/daemon/service/emergency_mode.c
new file mode 100755 (executable)
index 0000000..9ced1c2
--- /dev/null
@@ -0,0 +1,330 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+
+#include <vconf.h>
+
+
+#include <syspopup_caller.h>
+
+#include <package_manager.h>
+#include <bundle_internal.h>
+#include <notification.h>
+#include <notification_internal.h>
+#include <notification_list.h>
+
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "common.h"
+#include "modules.h"
+#include "datetime.h"
+#include "emergency_mode.h"
+#include "quickpanel-ui.h"
+
+#ifdef QP_SETTING_ENABLE
+extern QP_Module settings_view_featured;
+#endif
+#ifdef QP_BRIGHTNESS_ENABLE
+extern QP_Module brightness_ctrl;
+#endif
+
+#define SETTING_SYSPOPUP "mode-syspopup"
+#define BT_SHARE_DAEMON "/usr/bin/bluetooth-share"
+#define BT_SHARE_SERVER "bluetooth-share-opp-server"
+#define BT_SHARE_CLIENT "bluetooth-share-opp-client"
+#define SCREEN_SHOT "shot-tizen"
+
+static struct _info {
+       int is_enabled;
+       Eina_List *permitted_apps;
+} s_info = {
+       .is_enabled = 0,
+       .permitted_apps = NULL,
+};
+
+static void _delete_unpermitted_app(void)
+{
+       notification_list_h noti_list = NULL;
+       notification_list_h list_traverse = NULL;
+       notification_h noti = NULL;
+
+       notification_get_list(NOTIFICATION_TYPE_NONE, -1, &noti_list);
+
+       list_traverse = noti_list;
+
+       while (list_traverse != NULL) {
+               noti = notification_list_get_data(list_traverse);
+
+               quickpanel_emergency_mode_notification_filter(noti, 1);
+
+               list_traverse = notification_list_get_next(list_traverse);
+       }
+
+       if (noti_list != NULL) {
+               notification_free_list(noti_list);
+               noti_list = NULL;
+       }
+}
+
+static void _emergency_mode_start(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       if (s_info.is_enabled) {
+               return;
+       }
+
+       quickpanel_datetime_datentime_event_set(0);
+#ifdef QP_SETTING_ENABLE
+       if (settings_view_featured.fini != NULL) {
+               settings_view_featured.fini(ad);
+       }
+#endif
+#ifdef QP_BRIGHTNESS_ENABLE
+       if (brightness_ctrl.fini != NULL) {
+               brightness_ctrl.fini(ad);
+       }
+#endif
+
+       _delete_unpermitted_app();
+       s_info.is_enabled = 1;
+       ERR("emergency mode is enabled");
+}
+
+static void _emergency_mode_stop(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       if (!s_info.is_enabled) {
+               return;
+       }
+
+       quickpanel_datetime_datentime_event_set(1);
+
+#ifdef QP_SETTING_ENABLE
+       if (settings_view_featured.init != NULL) {
+               settings_view_featured.init(ad);
+       }
+       if (settings_view_featured.init_job_cb != NULL) {
+               settings_view_featured.init_job_cb(ad);
+       }
+#endif
+#ifdef QP_BRIGHTNESS_ENABLE
+       if (brightness_ctrl.init != NULL) {
+               brightness_ctrl.init(ad);
+       }
+#endif
+
+       _delete_unpermitted_app();
+       s_info.is_enabled = 0;
+       ERR("emergency mode is disabled");
+}
+
+static void _vconf_cb(keynode_t *node, void *data)
+{
+       int mode = 0;
+
+       if (vconf_get_int(VCONFKEY_SETAPPL_PSMODE, &mode) == 0) {
+               if (mode == SETTING_PSMODE_EMERGENCY) {
+                       _emergency_mode_start(data);
+               } else {
+                       _emergency_mode_stop(data);
+               }
+       } else {
+               ERR("failed to get the value of VCONFKEY_SETAPPL_PSMODE");
+       }
+}
+
+static bool _app_list_cb(package_info_h handle, void *user_data)
+{
+       char *appid = NULL;
+       char *permitted_appid = NULL;
+
+       /* NEED TO CHANGE */
+       package_info_get_package(handle, &appid);
+
+       permitted_appid = strdup(appid);
+
+       s_info.permitted_apps = eina_list_append(s_info.permitted_apps, permitted_appid);
+       DBG("%s is permitted.", permitted_appid);
+
+       return 0;
+}
+
+
+static int _register_permitted_apps(void)
+{
+       DBG("");
+       int ret = 0;
+       package_manager_filter_h handle;
+
+       s_info.permitted_apps = eina_list_append(s_info.permitted_apps, BT_SHARE_DAEMON);
+       s_info.permitted_apps = eina_list_append(s_info.permitted_apps, SCREEN_SHOT);
+       s_info.permitted_apps = eina_list_append(s_info.permitted_apps, BT_SHARE_SERVER);
+       s_info.permitted_apps = eina_list_append(s_info.permitted_apps, BT_SHARE_CLIENT);
+
+       ret = package_manager_filter_create(&handle);
+       if (ret != PACKAGE_MANAGER_ERROR_NONE) {
+               return -1;
+       }
+       
+#if defined(WINSYS_X11)
+       /* NEED TO CHANGE */
+       ret = package_manager_filter_add_bool(handle, PMINFO_APPINFO_PROP_APP_SUPPORT_MODE, 1);
+       if (ret != PACKAGE_MANAGER_ERROR_NONE) {
+               package_manager_filter_destroy(handle);
+               return -1;
+       }
+#endif
+
+       ret = package_manager_filter_foreach_package_info(handle, _app_list_cb, NULL);
+       if (ret != PACKAGE_MANAGER_ERROR_NONE) {
+               package_manager_filter_destroy(handle);
+               return -1;
+       }
+
+       package_manager_filter_destroy(handle);
+       return 0;
+
+}
+
+static int _delete_permitted_apps(void)
+{
+       Eina_List *list = NULL;
+       char *appid = NULL;
+
+       if (!s_info.permitted_apps) {
+               EINA_LIST_FOREACH(s_info.permitted_apps, list, appid)
+                       free(appid);
+               eina_list_free(s_info.permitted_apps);
+               s_info.permitted_apps = NULL;
+       }
+
+       return 0;
+}
+
+HAPI void quickpanel_emergency_mode_init(void *data)
+{
+       int ret = 0;
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       ret = _register_permitted_apps();
+       msgif(ret !=0, "failed to register permitted apps");
+
+       ret = vconf_notify_key_changed(VCONFKEY_SETAPPL_PSMODE,
+                       _vconf_cb, ad);
+       msgif(ret != 0, "failed to notify key(VCONFKEY_SETAPPL_PSMODE) : %d", ret);
+
+       if (quickpanel_emergency_mode_is_on()) {
+               s_info.is_enabled = 1;
+       }
+}
+
+HAPI void quickpanel_emergency_mode_fini(void *data)
+{
+       int ret = 0;
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       ret = _delete_permitted_apps();
+       msgif(ret !=0, "failed to delete permitted apps");
+
+       ret = vconf_ignore_key_changed(VCONFKEY_SETAPPL_PSMODE, _vconf_cb);
+       msgif(ret != 0, "failed to ignore key(VCONFKEY_SETAPPL_PSMODE) : %d", ret);
+}
+
+HAPI int quickpanel_emergency_mode_is_permitted_app(const char *appid)
+{
+       int i = 0;
+       int count = 0;
+       char *permitted_app = NULL;
+       retif(appid == NULL, 0, "Invalid parameter!");
+
+       count = eina_list_count(s_info.permitted_apps);
+       for(i = 0; i < count; i++) {
+               permitted_app = (char *)eina_list_nth(s_info.permitted_apps, i);
+               if (permitted_app != NULL && strcmp(permitted_app, appid) == 0) {
+                       return 1;
+               }
+       }
+
+       return 0;
+}
+
+HAPI int quickpanel_emergency_mode_is_on(void)
+{
+       int mode = 0;
+
+       if (vconf_get_int(VCONFKEY_SETAPPL_PSMODE, &mode) == 0) {
+               if (mode == SETTING_PSMODE_EMERGENCY) {
+                       return 1;
+               }
+       }
+
+       return 0;
+}
+
+HAPI int quickpanel_emergency_mode_notification_filter(notification_h noti, int is_delete)
+{
+       int priv_id = 0;
+       char *pkgname = NULL;
+
+       notification_get_pkgname(noti, &pkgname);
+       notification_get_id(noti, NULL, &priv_id);
+
+       DBG("Emergency mode filter is called: %s", pkgname);
+       if (!quickpanel_emergency_mode_is_permitted_app(pkgname)) {
+               if (is_delete) {
+                       notification_delete_by_priv_id(pkgname, NOTIFICATION_TYPE_NONE, priv_id);
+               }
+               return 1;
+       }
+
+       return 0;
+}
+
+HAPI int quickpanel_emergency_mode_syspopup_launch(void)
+{
+       int ret;
+       bundle *b = NULL;
+
+       DBG("");
+
+       b = bundle_create();
+       if (b == NULL) {
+               return QP_FAIL;
+       }
+
+       bundle_add(b, "_MODE_SYSTEM_POPUP_TYPE_", "POPUP_EMERGENCY_PSMODE");
+       ret = syspopup_launch(SETTING_SYSPOPUP, b);
+       if (ret < 0) {
+               ERR("failed to launch syspopup (%s):%d\n", SETTING_SYSPOPUP, ret);
+               bundle_free(b);
+               return QP_FAIL;
+       }
+
+       DBG("");
+
+       bundle_free(b);
+       return QP_OK;
+}
diff --git a/daemon/service/emergency_mode.h b/daemon/service/emergency_mode.h
new file mode 100755 (executable)
index 0000000..6ca6290
--- /dev/null
@@ -0,0 +1,31 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef _QP_EMERGENCY_MODE_DEF_
+#define _QP_EMERGENCY_MODE_DEF_
+
+#define PACKAGE_EMERGENCY_MODE_SETTING "setting-emergency-efl"
+
+extern void quickpanel_emergency_mode_init(void *data);
+extern void quickpanel_emergency_mode_fini(void *data);
+extern int quickpanel_emergency_mode_is_permitted_app(const char *appid);
+extern int quickpanel_emergency_mode_is_on(void);
+extern int quickpanel_emergency_mode_notification_filter(notification_h noti, int is_delete);
+extern int quickpanel_emergency_mode_syspopup_launch(void);
+
+#endif
diff --git a/daemon/service/keyboard.c b/daemon/service/keyboard.c
new file mode 100755 (executable)
index 0000000..3fe19dc
--- /dev/null
@@ -0,0 +1,167 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+#include <vconf.h>
+#include <Ecore_Input.h>
+#include <feedback.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <notification.h>
+
+#include <E_DBus.h>
+
+#include "quickpanel-ui.h" // appdata
+#include "common_uic.h"
+#include "common.h"
+#include "noti_util.h"
+#include "keyboard.h"
+
+#define KEY_BACK       "XF86Back"
+#define KEY_CANCEL     "Cancel"
+#define KEY_MENU       "XF86Menu"
+#define KEY_QUICKPANEL "XF86QuickPanel"
+#define KEY_HOME       "XF86Home"
+
+static Eina_Bool _service_hardkey_up_cb(void *data, int type, void *event)
+{
+       struct appdata *ad = NULL;
+       Ecore_Event_Key *key_event = NULL;
+
+       retif(data == NULL || event == NULL, EINA_FALSE, "Invalid parameter!");
+       ad = data;
+       key_event = event;
+
+       if (!strcmp(key_event->keyname, KEY_HOME)) {
+               if (ad->is_hardkey_cancel == EINA_FALSE) {
+                       quickpanel_uic_close_quickpanel(false, 0);
+               } else {
+                       DBG("Cancel status, do nothing");
+               }
+       } else if (!strcmp(key_event->keyname, KEY_CANCEL)) {
+               ad->is_hardkey_cancel = EINA_FALSE;
+       } else if (!strcmp(key_event->keyname, KEY_BACK)) {
+               if (ad->popup != NULL) {
+                       Evas_Smart_Cb back_cb = evas_object_data_get(ad->popup, EDATA_BACKKEY_CB);
+                       if (back_cb != NULL) {
+                               back_cb(ad->popup, ad->popup, NULL);
+                       }
+               } else {
+                       quickpanel_uic_close_quickpanel(false, 0);
+               }
+       }
+       return EINA_FALSE;
+}
+
+static Eina_Bool _service_hardkey_down_cb(void *data, int type, void *event)
+{
+       Ecore_Event_Key *key_event = event;
+       struct appdata *ad = data;
+       retif(key_event == NULL, EINA_FALSE, "Invalid parameter!");
+       retif(ad == NULL, EINA_FALSE, "Invalid parameter!");
+
+       if (!strcmp(key_event->keyname, KEY_CANCEL)) {
+               ad->is_hardkey_cancel = EINA_TRUE;
+       } else if (!strcmp(key_event->keyname, KEY_QUICKPANEL)) {
+               quickpanel_uic_toggle_openning_quickpanel();
+       }
+       return EINA_FALSE;
+}
+
+HAPI void quickpanel_keyboard_init(void *data)
+{
+       struct appdata *ad = data;
+       Ecore_Event_Handler *hdl_key_down = NULL;
+       Ecore_Event_Handler *hdl_key_up = NULL;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       if (elm_win_keygrab_set(ad->win, KEY_QUICKPANEL, 0, 0, 0, ELM_WIN_KEYGRAB_SHARED) == EINA_FALSE) {
+               ERR("failed to grab KEY_QUICKPANEL");
+       }
+
+       hdl_key_down = ecore_event_handler_add(ECORE_EVENT_KEY_DOWN, _service_hardkey_down_cb, ad);
+       if (hdl_key_down == NULL) {
+               ERR("failed to add handler(ECORE_EVENT_KEY_DOWN)");
+       }
+       ad->hdl_hardkey_down = hdl_key_down;
+
+       hdl_key_up = ecore_event_handler_add(ECORE_EVENT_KEY_UP, _service_hardkey_up_cb, ad);
+       if (hdl_key_up == NULL) {
+               ERR("failed to add handler(ECORE_EVENT_KEY_UP)");
+       }
+       ad->hdl_hardkey_up = hdl_key_up;
+       ad->is_hardkey_cancel = EINA_FALSE;
+}
+
+HAPI void quickpanel_keyboard_fini(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       if (ad->hdl_hardkey_up != NULL) {
+               ecore_event_handler_del(ad->hdl_hardkey_up);
+               ad->hdl_hardkey_up = NULL;
+       }
+
+       if (ad->hdl_hardkey_down != NULL) {
+               ecore_event_handler_del(ad->hdl_hardkey_down);
+               ad->hdl_hardkey_down = NULL;
+       }
+
+       if (elm_win_keygrab_unset(ad->win, KEY_QUICKPANEL, 0, 0) == EINA_FALSE) {
+               ERR("failed to ungrab KEY_QUICKPANEL");
+       }
+}
+
+HAPI void quickpanel_keyboard_openning_init(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       if (elm_win_keygrab_set(ad->win, KEY_BACK, 0, 0, 0, ELM_WIN_KEYGRAB_EXCLUSIVE)  == EINA_FALSE) {
+               ERR("failed to grab KEY_BACK");
+       }
+
+       if (elm_win_keygrab_set(ad->win, KEY_MENU, 0, 0, 0, ELM_WIN_KEYGRAB_EXCLUSIVE) == EINA_FALSE) {
+               ERR("failed to grab KEY_MENU");
+       }
+
+       if (elm_win_keygrab_set(ad->win, KEY_HOME, 0, 0, 0, ELM_WIN_KEYGRAB_SHARED)  == EINA_FALSE) {
+               ERR("failed to grab KEY_HOME");
+       }
+
+}
+
+HAPI void quickpanel_keyboard_closing_fini(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       if (elm_win_keygrab_unset(ad->win, KEY_BACK, 0, 0) == EINA_FALSE) {
+               ERR("failed to ungrab KEY_BACK");
+       }
+
+       if (elm_win_keygrab_unset(ad->win, KEY_MENU, 0, 0) == EINA_FALSE) {
+               ERR("failed to ungrab KEY_MENU");
+       }
+
+       if (elm_win_keygrab_unset(ad->win, KEY_HOME, 0, 0) == EINA_FALSE) {
+               ERR("failed to ungrab KEY_HOME");
+       }
+}
+
+
diff --git a/daemon/service/keyboard.h b/daemon/service/keyboard.h
new file mode 100755 (executable)
index 0000000..15f8a3b
--- /dev/null
@@ -0,0 +1,28 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef _QP_SERVICE_KEYBOARD_DEF_
+#define _QP_SERVICE_KEYBOARD_DEF_
+
+
+extern void quickpanel_keyboard_init(void *data);
+extern void quickpanel_keyboard_fini(void *data);
+extern void quickpanel_keyboard_openning_init(void *data);
+extern void quickpanel_keyboard_closing_fini(void *data);
+
+#endif
diff --git a/daemon/service/noti_led.c b/daemon/service/noti_led.c
new file mode 100755 (executable)
index 0000000..c4568a2
--- /dev/null
@@ -0,0 +1,375 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+#include <glib.h>
+
+#include <vconf.h>
+#include <notification.h>
+#include <notification_internal.h>
+
+#include "common.h"
+#include "noti_util.h"
+#include "noti_led.h"
+#include "noti_node.h"
+
+#define LED_ON 1
+#define LED_OFF 0
+#define LED_MISSED_NOTI        5
+
+typedef struct _QP_LED {
+       int priv_id;
+       notification_led_op_e op;
+       int argb;
+       int timestamp;
+       int time_on;
+       int time_off;
+} QP_LED_T;
+
+static struct _s_led_info {
+       Eina_List *list;
+       int is_turned_on;
+} s_led_info = {
+       .list = NULL,
+       .is_turned_on = 0,
+};
+
+static QP_LED_T * _led_entry_new(int priv_id, notification_led_op_e op, int argb, int time_on, int time_off)
+{
+       QP_LED_T *led_entry = (QP_LED_T *)calloc(1, sizeof(QP_LED_T));
+
+       retif(led_entry == NULL, NULL, "failed to memory allocation");
+
+       led_entry->priv_id = priv_id;
+       led_entry->op = op;
+       led_entry->argb = argb;
+       led_entry->time_on = (time_on <= 0) ? -1 : time_on ;
+       led_entry->time_off = (time_off <= 0) ? -1 : time_off;
+       led_entry->timestamp = (int)time(NULL);
+
+       return led_entry;
+}
+
+static void _led_entry_del(QP_LED_T *led_entry)
+{
+       retif(led_entry == NULL, ,"invalid parameter");
+
+       free(led_entry);
+}
+
+static int _led_list_sort_cb(const void *data1, const void *data2)
+{
+       QP_LED_T *entry_1 = (QP_LED_T *)data1;
+       QP_LED_T *entry_2 = (QP_LED_T *)data2;
+
+       if (entry_1 == NULL || entry_2 == NULL) {
+               return 0;
+       }
+
+       return entry_2->timestamp - entry_1->timestamp;
+}
+
+static void _led_list_add(QP_LED_T *led_entry)
+{
+       retif(led_entry == NULL, ,"invalid parameter");
+
+       s_led_info.list = eina_list_sorted_insert(s_led_info.list, _led_list_sort_cb, led_entry);
+}
+
+static void _led_list_del(QP_LED_T *led_entry)
+{
+       retif(led_entry == NULL, ,"invalid parameter");
+
+       s_led_info.list = eina_list_remove(s_led_info.list, led_entry);
+}
+
+static void _led_list_sort(void)
+{
+       retif(s_led_info.list == NULL, ,"invalid parameter");
+
+       s_led_info.list = eina_list_sort(s_led_info.list, 0, _led_list_sort_cb);
+}
+
+static QP_LED_T *_led_list_find_by_priv_id(int priv_id)
+{
+       Eina_List *l;
+       Eina_List *n;
+       QP_LED_T *led_entry = NULL;
+
+       retif(s_led_info.list == NULL, NULL,"invalid parameter");
+
+       EINA_LIST_FOREACH_SAFE(s_led_info.list, l, n, led_entry) {
+               if (led_entry != NULL) {
+                       if (led_entry->priv_id == priv_id) return led_entry;
+               }
+       }
+
+       return NULL;
+}
+
+static void _led_list_clean_up(void)
+{
+       Eina_List *l;
+       Eina_List *n;
+       QP_LED_T *led_entry = NULL;
+       Eina_List *list_temp = NULL;
+
+       retif(s_led_info.list == NULL, ,"invalid parameter");
+
+       list_temp = s_led_info.list;
+       s_led_info.list = NULL;
+       EINA_LIST_FOREACH_SAFE(list_temp, l, n, led_entry) {
+               if (led_entry != NULL) {
+                       _led_entry_del(led_entry);
+               }
+       }
+
+       eina_list_free(list_temp);
+
+}
+
+static QP_LED_T *_led_list_get_first(void)
+{
+       return eina_list_nth(s_led_info.list, 0);
+}
+
+static inline int _is_led_enabled(void)
+{
+       int ret = -1;
+       int status = 1;
+
+       ret = vconf_get_bool(VCONFKEY_SETAPPL_LED_INDICATOR_NOTIFICATIONS, &status);
+
+       if (ret == 0) {
+               if (status == 0) {
+                       ERR("LED notification turned off");
+                       return 0;
+               }
+       } else {
+               ERR("failed to get value of VCONFKEY_SETAPPL_LED_INDICATOR_NOTIFICATIONS:%d", ret);
+       }
+
+       return 1;
+}
+
+static int _led_set_mode(int mode, bool val, int on, int off, unsigned int color)
+{
+       // TODO: Kiran device does not support front led.
+       // Because H/W is not fixed, if led should work, use dbus method call.
+       //
+       // bus name : org.tizen.system.deviced
+       // object path : /Org/Tizen/System/DeviceD/Led
+       // interface name : org.tizen.system.deviced.Led
+       // method name : SetMode
+       // input argument : "iiiiu" (int32:mode,
+       //                                                      int32:on(1)/off(0),
+       //                                                      int32:[custom]on duty (default:-1),
+       //                                                      int32:[custom]off duty (default:-1),
+       //                                                      uint32:[custom]color (default:0))
+       // mode LED_MISSED_NOTI = 5, LED_VOICE_RECORDING = 6, LED_REMOTE_CONTROLLER = 7, LED_AIR_WAKEUP = 8
+       // custom : only support for MISSED_NOTI and VOICE_RECORDING case
+       // output argument : "i" (int32:result)
+
+       return -1;
+}
+
+static void _noti_led_on(QP_LED_T *led_entry)
+{
+       int ret = 0;
+       retif(led_entry == NULL, , "invalid data");
+
+       DBG("turn on LED with OP:%d ARGB:%x ON:%d OFF:%d",
+                       led_entry->op, led_entry->argb, led_entry->time_on, led_entry->time_off);
+
+       if (led_entry->op == NOTIFICATION_LED_OP_ON) {
+               if ((ret = _led_set_mode(LED_MISSED_NOTI, LED_ON, led_entry->time_on, led_entry->time_off, 0)) == -1) {
+                       ERR("failed led_set_mode:%d", ret);
+               } else {
+                       s_led_info.is_turned_on = 1;
+               }
+       } else if (led_entry->op == NOTIFICATION_LED_OP_ON_CUSTOM_COLOR) {
+               if ((ret = _led_set_mode(LED_MISSED_NOTI, LED_ON, led_entry->time_on, led_entry->time_off, led_entry->argb)) == -1) {
+                       ERR("failed led_set_mode:%d", ret);
+               } else {
+                       s_led_info.is_turned_on = 1;
+               }
+       } else {
+               ERR("NOTIFICATION_LED_OP_OFF");
+       }
+}
+
+static void _noti_led_off(int is_force)
+{
+       int ret = 0;
+
+       ERR("try to turn off LED");
+       retif(s_led_info.is_turned_on == 0 && is_force == 1, , "LED already turned off");
+
+       if ((ret = _led_set_mode(LED_MISSED_NOTI, LED_OFF, 0, 0, 0)) == -1) {
+               ERR("failed led_set_mode:%d", ret);
+       } else {
+               s_led_info.is_turned_on = 0;
+       }
+}
+
+HAPI void quickpanel_noti_led_proc(notification_h noti, int op_type)
+{
+       int priv_id = 0;
+       int led_argb = 0;
+       int time_on = 0;
+       int time_off = 0;
+       QP_LED_T *led_entry = NULL;
+       notification_led_op_e led_op = -1;
+       retif(noti == NULL, , "Invalid parameter!");
+
+       notification_get_id(noti, NULL, &priv_id);
+       notification_get_led(noti, &led_op, &led_argb);
+       notification_get_led_time_period(noti, &time_on, &time_off);
+
+       DBG("on:%d off:%d", time_on, time_off);
+
+       if (op_type == NOTIFICATION_OP_INSERT || op_type == NOTIFICATION_OP_UPDATE) {
+               led_entry = _led_list_find_by_priv_id(priv_id);
+               if (led_entry != NULL) {
+                       if (led_op == NOTIFICATION_LED_OP_OFF) {
+                               _led_list_del(led_entry);
+                               _led_entry_del(led_entry);
+                       } else {
+                               led_entry->op = led_op;
+                               led_entry->argb = led_argb;
+                               led_entry->time_on = (time_on <= 0) ? -1 : time_on ;
+                               led_entry->time_off = (time_off <= 0) ? -1 : time_off;
+                               led_entry->timestamp = (int)time(NULL);
+                               _led_list_sort();
+                       }
+               } else {
+                       if (led_op >= NOTIFICATION_LED_OP_ON) {
+                               led_entry = _led_entry_new(priv_id, led_op, led_argb, time_on, time_off);
+                               _led_list_add(led_entry);
+                       }
+               }
+       } else if (op_type == NOTIFICATION_OP_DELETE) {
+               led_entry = _led_list_find_by_priv_id(priv_id);
+               if (led_entry != NULL) {
+                       _led_list_del(led_entry);
+                       _led_entry_del(led_entry);
+               }
+       }
+
+       //turn on or off LED
+       if (_is_led_enabled() == 1) {
+               led_entry = _led_list_get_first();
+               if (led_entry != NULL) {
+                       _noti_led_on(led_entry);
+               } else {
+                       _noti_led_off(0);
+               }
+       } else {
+               _noti_led_off(0);
+       }
+}
+
+static void _led_option_vconf_cb(keynode_t *node, void *data)
+{
+       QP_LED_T *led_entry = NULL;
+
+       if (_is_led_enabled() == 1) {
+               DBG("led notification is enabled");
+               led_entry = _led_list_get_first();
+               if (led_entry != NULL) {
+                       DBG("try to turn on LED, op:%d argb:%x", led_entry->op, led_entry->argb);
+                       _noti_led_on(led_entry);
+               } else {
+                       _noti_led_off(1);
+               }
+       } else {
+               DBG("led notification is disabled");
+               _noti_led_off(1);
+       }
+}
+
+static void _led_init_data_cb(gpointer key, gpointer value, gpointer user_data)
+{
+       int priv_id = 0;
+       int led_argb = 0;
+       int time_on = 0;
+       int time_off = 0;
+       notification_led_op_e led_op = -1;
+       noti_node_item *node = (noti_node_item *)value;
+       retif(node == NULL, , "Invalid parameter!");
+       retif(node->noti == NULL, , "Invalid parameter!");
+
+       notification_get_id(node->noti, NULL, &priv_id);
+       notification_get_led(node->noti, &led_op, &led_argb);
+       notification_get_led_time_period(node->noti, &time_on, &time_off);
+       if (led_op >= NOTIFICATION_LED_OP_ON) {
+               QP_LED_T *new_entry = _led_entry_new(priv_id, led_op, led_argb, time_on, time_off);
+               _led_list_add(new_entry);
+       }
+}
+
+static void _led_init_data(noti_node *nodes)
+{
+       QP_LED_T *led_entry = NULL;
+       retif(nodes == NULL, , "Invalid parameter!");
+       retif(nodes->table == NULL, , "Invalid parameter!");
+
+       g_hash_table_foreach(nodes->table, _led_init_data_cb, NULL);
+
+       if (_is_led_enabled() == 1) {
+               led_entry = _led_list_get_first();
+               if (led_entry != NULL) {
+                       _noti_led_on(led_entry);
+               } else {
+                       _noti_led_off(1);
+               }
+       } else {
+               _noti_led_off(1);
+       }
+}
+
+HAPI void quickpanel_noti_led_init(void *data, void *nodes)
+{
+       int ret = 0;
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       ret = vconf_notify_key_changed(VCONFKEY_SETAPPL_LED_INDICATOR_NOTIFICATIONS,_led_option_vconf_cb, ad);
+
+       if (ret != 0) {
+               ERR("failed to notify key[%s] : %d",
+                               VCONFKEY_SETAPPL_AUTO_ROTATE_SCREEN_BOOL, ret);
+       }
+
+       if (nodes != NULL) {
+               _led_init_data((noti_node *)nodes);
+       }
+}
+
+HAPI void quickpanel_noti_led_fini(void *data)
+{
+       int ret = 0;
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       ret = vconf_ignore_key_changed(VCONFKEY_SETAPPL_LED_INDICATOR_NOTIFICATIONS,_led_option_vconf_cb);
+       if (ret != 0) {
+               ERR("failed to ignore key[%s] : %d", VCONFKEY_SETAPPL_LED_INDICATOR_NOTIFICATIONS, ret);
+       }
+
+       _led_list_clean_up();
+}
diff --git a/daemon/service/noti_led.h b/daemon/service/noti_led.h
new file mode 100755 (executable)
index 0000000..f3593da
--- /dev/null
@@ -0,0 +1,26 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef _QP_NOTI_LED_DEF_
+#define _QP_NOTI_LED_DEF_
+
+extern void quickpanel_noti_led_init(void *data, void *noti_node);
+extern void quickpanel_noti_led_fini(void *data);
+extern void quickpanel_noti_led_proc(notification_h noti, int op_type);
+
+#endif
diff --git a/daemon/service/reminder.c b/daemon/service/reminder.c
new file mode 100755 (executable)
index 0000000..9a99639
--- /dev/null
@@ -0,0 +1,312 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+#include <glib.h>
+
+#include <alarm.h>
+#include <time.h>
+#include <unistd.h>
+#include <vconf.h>
+#include <system_settings.h>
+#include <notification.h>
+#include <notification_internal.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <feedback.h>
+#include <player.h>
+#include <E_DBus.h>
+
+#include "quickpanel-ui.h"
+#include "common_uic.h"
+#include "common.h"
+#include "noti_node.h"
+#include "media.h"
+#include "noti.h"
+
+#define REMINDER_MIN_INTERVAL 2
+
+static struct info {
+       int alarm_id;
+} s_info = {
+       .alarm_id = -1,
+};
+
+static void _feedback_sound_play(void)
+{
+       int ret = 0;
+       noti_node_item *node = NULL;
+       notification_h noti;
+       int priv_id = 0;
+       const char *nsound_path = NULL;
+       notification_sound_type_e nsound_type = NOTIFICATION_SOUND_TYPE_NONE;
+       int is_play_default = 0;
+
+       // check first noti sound
+       node = quickpanel_noti_node_get_first_noti();
+       if (node) {
+               noti = node->noti;
+               if (noti) {
+                       notification_get_id(noti, NULL, &priv_id);
+                       notification_get_sound(noti, &nsound_type, &nsound_path);
+                       SDBG("reminded notification sound type[%d] path[%s]", nsound_type, nsound_path);
+
+                       switch (nsound_type) {
+                       case NOTIFICATION_SOUND_TYPE_USER_DATA:
+                               /*
+                                *  if user data file isn't playable, play the default ringtone
+                                */
+                               if (nsound_path != NULL) {
+                                       if (quickpanel_media_playable_check(nsound_path) == EINA_TRUE) {
+                                               ret = quickpanel_media_player_play(SOUND_TYPE_NOTIFICATION, nsound_path);
+                                               if (ret == PLAYER_ERROR_NONE) {
+                                                       quickpanel_media_player_id_set(priv_id);
+                                               } else {
+                                                       ERR("failed to play notification sound[%d]", ret);
+                                                       is_play_default = 1;
+                                               }
+                                       }
+                               }
+                               break;
+                       case NOTIFICATION_SOUND_TYPE_DEFAULT:
+                               is_play_default = 1;
+                               break;
+                       case NOTIFICATION_SOUND_TYPE_MAX:
+                       case NOTIFICATION_SOUND_TYPE_NONE:
+                               break;
+                       }
+               }
+       }
+
+       if (is_play_default) {
+               char *default_msg_tone = NULL;
+
+               ret = system_settings_get_value_string(SYSTEM_SETTINGS_KEY_SOUND_NOTIFICATION, &default_msg_tone);
+               msgif(ret != SYSTEM_SETTINGS_ERROR_NONE, "ailed to set key(%s) : %d", SYSTEM_SETTINGS_KEY_SOUND_NOTIFICATION, ret);
+               SDBG("Reminded setting sound[%s]", default_msg_tone);
+
+               if (default_msg_tone != NULL) {
+                       ret = quickpanel_media_player_play(SOUND_TYPE_NOTIFICATION, default_msg_tone);
+                       free(default_msg_tone);
+                       quickpanel_media_player_id_set(0);
+                       if (ret != PLAYER_ERROR_NONE) {
+                               ERR("failed to play feedback sound");
+                       }
+               }
+
+               if (quickpanel_media_is_vib_enabled() == 1) {
+                       feedback_play_type(FEEDBACK_TYPE_VIBRATION, FEEDBACK_PATTERN_MESSAGE);
+               }
+       }
+}
+
+static int _reminder_interval_get(void)
+{
+       int key = 0;
+       int min = 0;
+       int ret = -1;
+
+       ret = vconf_get_int(VCONFKEY_SETAPPL_NOTI_MSG_ALERT_REP_TYPE_INT, &key);
+       retif(ret != 0, 0, "failed to get vconf VCONFKEY_SETAPPL_NOTI_MSG_ALERT_REP_TYPE_INT");
+
+       switch (key) {
+               case 1:
+                       min = 2;
+                       break;
+               case 2:
+                       min = 5;
+                       break;
+               case 3:
+                       min = 10;
+                       break;
+       }
+
+       DBG("interval:%d", min);
+
+       return min;
+}
+
+static int _alarm_delete_cb(alarm_id_t id, void * user_param)
+{
+       int ret = ALARMMGR_RESULT_SUCCESS;
+
+       ret = alarmmgr_remove_alarm(id);
+       if (ret != ALARMMGR_RESULT_SUCCESS) {
+               ERR("alarmmgr_enum_alarm_ids() failed");
+       }
+
+       return 0;
+}
+
+static void _alarm_unset(void)
+{
+       int ret = ALARMMGR_RESULT_SUCCESS;
+
+       if (s_info.alarm_id != -1){
+               ERR("try to delete alarm_id(%d)", s_info.alarm_id);
+               ret = alarmmgr_remove_alarm(s_info.alarm_id);
+               if (ret != ALARMMGR_RESULT_SUCCESS) {
+                       ERR("alarmmgr_remove_alarm(%d) failed", s_info.alarm_id);
+                       ret = alarmmgr_enum_alarm_ids(_alarm_delete_cb, NULL);
+                       if (ret != ALARMMGR_RESULT_SUCCESS) {
+                               ERR("alarmmgr_enum_alarm_ids() failed");
+                       }
+               }
+               s_info.alarm_id = -1;
+       }
+}
+
+static Eina_Bool _alarm_set_from_now(int min, void *data)
+{
+       int ret = ALARMMGR_RESULT_SUCCESS;
+       time_t current_time;
+       struct tm current_tm;
+       alarm_entry_t *alarm_info = NULL;
+       alarm_id_t alarm_id;
+       alarm_date_t alarm_time;
+
+       /* delete before registering alarm ids */
+       _alarm_unset();
+
+       /* set alarm after sec */
+       time(&current_time);
+
+       DBG(" %s, after %d MIN alarm set", ctime(&current_time), min);
+       localtime_r(&current_time, &current_tm);
+
+       alarm_info = alarmmgr_create_alarm();
+       if (alarm_info == NULL) {
+               ERR("alarmmgr_create_alarm() is failed\n");
+               return EINA_FALSE;
+       }
+
+       alarm_time.year = 0;
+       alarm_time.month = 0;
+       alarm_time.day = 0;
+       alarm_time.hour = current_tm.tm_hour;
+       alarm_time.min = current_tm.tm_min + min;
+       alarm_time.sec = current_tm.tm_sec;
+
+       alarmmgr_set_repeat_mode(alarm_info, ALARM_REPEAT_MODE_ONCE, 0);
+       alarmmgr_set_time(alarm_info, alarm_time);
+       alarmmgr_set_type(alarm_info, ALARM_TYPE_VOLATILE);
+
+       ret = alarmmgr_add_alarm_with_localtime(alarm_info, NULL, &alarm_id);
+       if (ret != ALARMMGR_RESULT_SUCCESS) {
+               ERR("alarmmgr_add_alarm_with_localtime() failed:%d", ret);
+               alarmmgr_free_alarm(alarm_info) ;
+               return EINA_FALSE;
+       }
+
+       DBG("alarm id(%d) is set", alarm_id);
+       s_info.alarm_id = alarm_id;
+       alarmmgr_free_alarm(alarm_info) ;
+
+       return EINA_TRUE;
+}
+
+static int _alarm_cb(alarm_id_t alarm_id, void *data)
+{
+       DBG("");
+
+       int min = _reminder_interval_get();
+
+       if (min >= REMINDER_MIN_INTERVAL) {
+               _alarm_set_from_now(min, data);
+       } else {
+               _alarm_unset();
+       }
+
+       if (!quickpanel_uic_is_opened()) {
+               _feedback_sound_play();
+       } else {
+               ERR("quickpanel is opened, skip remind sound");
+       }
+
+       return 1;
+}
+
+static void _alarm_setting_changed_cb(keynode_t *key, void* data)
+{
+       int min = _reminder_interval_get();
+
+       if (quickpanel_noti_get_count() <= 0) {
+               _alarm_unset();
+       } else {
+               if (min >= REMINDER_MIN_INTERVAL) {
+                       _alarm_set_from_now(min, data);
+               } else {
+                       _alarm_unset();
+               }
+       }
+}
+
+HAPI void quickpanel_reminder_init(void *data)
+{
+       DBG("");
+
+       int ret = 0;
+
+       ret = alarmmgr_init("org.tizen.quickpanel");
+       retif(ret < 0, , "alarmmgr_init() failed (%d)", ret);
+
+       ret = alarmmgr_set_cb(_alarm_cb, NULL);
+       retif(ret < 0, , "alarmmgr_init() failed (%d)", ret);
+
+       ret = vconf_notify_key_changed(VCONFKEY_SETAPPL_NOTI_MSG_ALERT_REP_TYPE_INT,
+                       _alarm_setting_changed_cb, data);
+       if (ret != 0) {
+               ERR("failed to register a cb key:%s err:%d",
+                               "VCONFKEY_SETAPPL_NOTI_MSG_ALERT_REP_TYPE_INT", ret);
+       }
+
+       s_info.alarm_id = -1;
+}
+
+HAPI void quickpanel_reminder_fini(void *data)
+{
+       DBG("");
+
+       int ret = 0;
+
+       _alarm_unset();
+
+       alarmmgr_fini();
+
+       ret = vconf_ignore_key_changed(VCONFKEY_SETAPPL_NOTI_MSG_ALERT_REP_TYPE_INT, _alarm_setting_changed_cb);
+       if (ret != 0) {
+               ERR("failed to unregister a cb key:%s err:%d", "VCONFKEY_SETAPPL_NOTI_MSG_ALERT_REP_TYPE_INT", ret);
+       }
+}
+
+HAPI void quickpanel_reminder_start(void *data)
+{
+       DBG("");
+
+       int min = _reminder_interval_get();
+
+       if (min >= REMINDER_MIN_INTERVAL) {
+               _alarm_set_from_now(min, data);
+       }
+}
+
+HAPI void quickpanel_reminder_stop(void *data)
+{
+       DBG("");
+
+       _alarm_unset();
+}
diff --git a/daemon/service/reminder.h b/daemon/service/reminder.h
new file mode 100755 (executable)
index 0000000..56d44b3
--- /dev/null
@@ -0,0 +1,27 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef _QP_REMINDER_DEF_
+#define _QP_REMINDER_DEF_
+
+extern void quickpanel_reminder_init(void *data);
+extern void quickpanel_reminder_fini(void *data);
+extern void quickpanel_reminder_start(void *data);
+extern void quickpanel_reminder_stop(void *data);
+
+#endif
diff --git a/daemon/service/uninstall.c b/daemon/service/uninstall.c
new file mode 100755 (executable)
index 0000000..df7e953
--- /dev/null
@@ -0,0 +1,146 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+#include <Eina.h>
+
+#include <vconf.h>
+#include <package_manager.h>
+#include <notification.h>
+#include <notification_internal.h>
+#include <badge.h>
+
+#include "common.h"
+#include "uninstall.h"
+
+typedef struct _pkg_event {
+       char *pkgname;
+       int is_done;
+} Pkg_Event;
+
+static struct _s_info {
+       package_manager_h client;
+       Eina_List *event_list;
+} s_info = {
+       .client = NULL,
+       .event_list = NULL,
+};
+
+static void _item_del(Pkg_Event *item_event)
+{
+       if (item_event != NULL) {
+               free(item_event->pkgname);
+       }
+
+       free(item_event);
+}
+
+static int _is_item_exist(const char *pkgid, int remove_if_exist)
+{
+       int ret = 0;
+       Eina_List *l = NULL;
+       Pkg_Event *event_item = NULL;
+       retif(pkgid == NULL, 0, "invalid parameter");
+
+       EINA_LIST_FOREACH(s_info.event_list, l, event_item) {
+               if (event_item != NULL) {
+                       if (strcmp(event_item->pkgname, pkgid) == 0) {
+                               ret = 1;
+                               break;
+                       }
+               }
+       }
+
+       if (ret == 1 && remove_if_exist == 1) {
+               s_info.event_list = eina_list_remove(s_info.event_list, event_item);
+               _item_del(event_item);
+       }
+
+       return ret;
+}
+
+static void _pkgmgr_event_cb(const char *type, const char *package,
+       package_manager_event_type_e event_type,
+       package_manager_event_state_e event_state, int progress,
+       package_manager_error_e error, void *user_data)
+{
+       if (error != PACKAGE_MANAGER_ERROR_NONE) {
+               ERR("_pkgmgr_event_cb error in cb");
+               return;
+       }
+
+       if (event_type != PACKAGE_MANAGER_EVENT_TYPE_UNINSTALL) {
+               return;
+       }
+
+       SDBG("type : %s event_type:%d event_state:%d [%s]", type, event_type, event_state, package);
+
+       if (event_state == PACKAGE_MANAGER_EVENT_STATE_STARTED) {
+
+               DBG("Pkg:%s is being uninstalled", package);
+
+               Pkg_Event *event = calloc(1, sizeof(Pkg_Event));
+               if (event != NULL) {
+                       event->pkgname = strdup(package);
+                       s_info.event_list = eina_list_append(s_info.event_list, event);
+               } else {
+                       ERR("failed to create event item");
+               }
+       } else if (event_state == PACKAGE_MANAGER_EVENT_STATE_COMPLETED) {
+
+               if (_is_item_exist(package, 1) == 1) {
+                       DBG("Pkg:%s is uninstalled, delete related resource", package);
+
+                       notification_delete_all_by_type(package, NOTIFICATION_TYPE_NOTI);
+                       notification_delete_all_by_type(package, NOTIFICATION_TYPE_ONGOING);
+                       badge_remove(package);
+               }
+       }
+}
+
+
+HAPI void quickpanel_uninstall_init(void *data)
+{
+       int ret = -1;
+
+       ret = package_manager_create(&s_info.client);
+       if (ret == PACKAGE_MANAGER_ERROR_NONE) {
+               if (package_manager_set_event_cb(s_info.client, (void*)_pkgmgr_event_cb, data) != PACKAGE_MANAGER_ERROR_NONE) {
+                       ERR("Failed to set package manager event:%d", ret);
+               }
+       } else {
+               ERR("Failed to create package manager : %d ", ret);
+       }
+
+}
+
+HAPI void quickpanel_uninstall_fini(void *data)
+{
+       int ret = -1;
+
+       Pkg_Event *event_item = NULL;
+
+       ret = package_manager_destroy(s_info.client);
+       if (ret != PACKAGE_MANAGER_ERROR_NONE) {
+               ERR("Failed to destory package manager:%d", ret);
+       }
+
+       EINA_LIST_FREE(s_info.event_list, event_item) {
+               _item_del(event_item);
+       }
+       s_info.event_list = NULL;
+}
diff --git a/daemon/service/uninstall.h b/daemon/service/uninstall.h
new file mode 100755 (executable)
index 0000000..77bcf73
--- /dev/null
@@ -0,0 +1,26 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef _QP_SERVICE_UNINSTALL_DEF_
+#define _QP_SERVICE_UNINSTALL_DEF_
+
+
+extern void quickpanel_uninstall_init(void *data);
+extern void quickpanel_uninstall_fini(void *data);
+
+#endif
diff --git a/daemon/settings/modules/bluetooth.c b/daemon/settings/modules/bluetooth.c
new file mode 100755 (executable)
index 0000000..e32764b
--- /dev/null
@@ -0,0 +1,244 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+
+#include <bluetooth.h>
+#include <vconf.h>
+#include <bluetooth_internal.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "common.h"
+#include "quickpanel-ui.h"
+#include "settings.h"
+#include "setting_utils.h"
+#include "setting_module_api.h"
+#include "settings_icon_common.h"
+
+#define BUTTON_LABEL _("IDS_ST_BUTTON2_BLUETOOTH_ABB")
+#define BUTTON_ICON_NORMAL "quick_icon_bluetooth.png"
+#define BUTTON_ICON_HIGHLIGHT NULL
+#define BUTTON_ICON_DIM NULL
+#define PACKAGE_SETTING_MENU "ug-bluetooth-efl"
+
+static void _mouse_clicked_cb(void *data, Evas_Object *obj, const char *emission, const char *source);
+
+static const char *_label_get(void)
+{
+       return BUTTON_LABEL;
+}
+
+static const char *_icon_get(qp_setting_icon_image_type type)
+{
+       if (type == QP_SETTING_ICON_NORMAL) {
+               return BUTTON_ICON_NORMAL;
+       } else if (type == QP_SETTING_ICON_HIGHLIGHT) {
+               return BUTTON_ICON_HIGHLIGHT;
+       } else if (type == QP_SETTING_ICON_DIM) {
+#ifdef BUTTON_ICON_DIM
+               return BUTTON_ICON_DIM;
+#endif
+       }
+
+       return NULL;
+}
+
+static void _long_press_cb(void *data)
+{
+#ifdef PACKAGE_SETTING_MENU
+       quickpanel_setting_icon_handler_longpress(PACKAGE_SETTING_MENU, NULL);
+#endif
+}
+
+static void _view_update(Evas_Object *view, int state, int flag_extra_1, int flag_extra_2)
+{
+       Evas_Object *image = NULL;
+       const char *icon_path = NULL;
+
+       quickpanel_setting_icon_state_set(view, state);
+
+       if (state == ICON_VIEW_STATE_ON) {
+#ifdef BUTTON_ICON_HIGHLIGHT
+               icon_path = BUTTON_ICON_HIGHLIGHT;
+#endif
+       } else if (state == ICON_VIEW_STATE_DIM) {
+#ifdef BUTTON_ICON_DIM
+               icon_path = BUTTON_ICON_DIM;
+#endif
+       } else {
+               icon_path = BUTTON_ICON_NORMAL;
+       }
+
+       if (icon_path == NULL) {
+               icon_path = BUTTON_ICON_NORMAL;
+       }
+       image = quickpanel_setting_icon_image_new(view, icon_path);
+       quickpanel_setting_icon_content_set(view, image);
+       quickpanel_setting_icon_text_set(view, BUTTON_LABEL, state);
+}
+
+static void _status_update(QP_Module_Setting *module, int flag_extra_1, int flag_extra_2)
+{
+       int ret = 0;
+       bt_adapter_state_e adapter_state = BT_ADAPTER_DISABLED;
+       retif(module == NULL, , "Invalid parameter!");
+
+       ret = bt_adapter_get_state(&adapter_state);
+       retif(ret != BT_ERROR_NONE, , "bt_adapter_get_state failed");
+
+       if (adapter_state == BT_ADAPTER_ENABLED) {
+               quickpanel_setting_module_icon_state_set(module, ICON_VIEW_STATE_ON);
+       } else {
+               quickpanel_setting_module_icon_state_set(module, ICON_VIEW_STATE_OFF);
+       }
+
+       quickpanel_setting_module_progress_mode_set(module, FLAG_DISABLE, FLAG_TURN_OFF);
+       quickpanel_setting_module_icon_timer_del(module);
+
+       quickpanel_setting_module_icon_view_update(module,
+                       quickpanel_setting_module_icon_state_get(module),
+                       FLAG_VALUE_VOID);
+}
+
+static void _mouse_clicked_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
+{
+       int ret;
+       int is_on = 0;
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       if (quickpanel_setting_module_is_icon_clickable(module) == 0) {
+               return;
+       }
+
+       if (quickpanel_setting_module_icon_state_get(module) == ICON_VIEW_STATE_ON) {
+               ret = bt_adapter_disable();
+               retif(ret != BT_ERROR_NONE, , "failed to disable BT adapter");
+
+               is_on = 0;
+       } else {
+               ret = bt_adapter_enable();
+               retif(ret != BT_ERROR_NONE, , "failed to enable BT adapter");
+
+               is_on = 1;
+       }
+
+       if (is_on == 1) {
+               quickpanel_setting_module_progress_mode_set(module, FLAG_ENABLE, FLAG_TURN_ON);
+       } else {
+               quickpanel_setting_module_progress_mode_set(module, FLAG_ENABLE, FLAG_TURN_OFF);
+       }
+       quickpanel_setting_module_icon_timer_add(module);
+}
+
+static void _bluetooth_status_changed_cb(int result, bt_adapter_state_e adapter_state, void *user_data)
+{
+       QP_Module_Setting *module = (QP_Module_Setting *)user_data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       INFO("bluetooth state : %d", adapter_state);
+       quickpanel_setting_module_icon_timer_del(module);
+
+       if (result != BT_ERROR_NONE) {
+               ERR("BT adapter operation is failed");
+               _status_update(module, FLAG_VALUE_VOID, FLAG_VALUE_VOID);
+               return;
+       }
+
+       _status_update(module, FLAG_VALUE_VOID, FLAG_VALUE_VOID);
+}
+
+static int _register_module_event_handler(void *data)
+{
+       int ret = 0;
+
+       ret = bt_initialize();
+       msgif(ret != BT_ERROR_NONE, "bt_initialize failed");
+
+       ret = bt_adapter_set_state_changed_cb(_bluetooth_status_changed_cb, data);
+       msgif(ret != BT_ERROR_NONE, "bt_adapter_set_state_changed_cb failed");
+
+       return QP_OK;
+}
+
+static int _unregister_module_event_handler(void *data)
+{
+       int ret = 0;
+
+       ret = bt_adapter_unset_state_changed_cb();
+       msgif(ret != BT_ERROR_NONE, "bt_adapter_unset_state_changed_cb failed");
+
+       ret = bt_deinitialize();
+       msgif(ret != BT_ERROR_NONE, "bt_deinitialize failed");
+
+       return QP_OK;
+}
+
+/****************************************************************************
+ *
+ * Quickpanel Item functions
+ *
+ ****************************************************************************/
+static int _init(void *data)
+{
+       int ret = QP_OK;
+
+       ret = _register_module_event_handler(data);
+
+       return ret;
+}
+
+static int _fini(void *data)
+{
+       int ret = QP_OK;
+
+       ret = _unregister_module_event_handler(data);
+
+       return ret;
+}
+
+static void _lang_changed(void *data)
+{
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_icon_view_update_text(module);
+}
+
+static void _refresh(void *data)
+{
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_icon_view_update_text(module);
+}
+
+QP_Module_Setting bluetooth = {
+       .name                           = "bluetooth",
+       .init                           = _init,
+       .fini                           = _fini,
+       .lang_changed           = _lang_changed,
+       .refresh                        = _refresh,
+       .icon_get                       = _icon_get,
+       .label_get                      = _label_get,
+       .view_update            = _view_update,
+       .status_update          = _status_update,
+       .handler_longpress      = _long_press_cb,
+       .handler_press          = _mouse_clicked_cb,
+};
diff --git a/daemon/settings/modules/gps.c b/daemon/settings/modules/gps.c
new file mode 100755 (executable)
index 0000000..16e7c01
--- /dev/null
@@ -0,0 +1,362 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+
+#include <vconf.h>
+#include <syspopup_caller.h>
+#include <app_control.h>
+#include <locations.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "common.h"
+#include "quickpanel-ui.h"
+#include "settings.h"
+#include "setting_utils.h"
+#include "setting_module_api.h"
+#include "settings_icon_common.h"
+
+
+#define BUTTON_LABEL _("IDS_QP_BUTTON2_LOCATION_ABB")
+#define BUTTON_ICON_NORMAL "quick_icon_location.png"
+#define BUTTON_ICON_HIGHLIGHT NULL
+#define BUTTON_ICON_DIM NULL
+#define PACKAGE_SETTING_MENU "org.tizen.setting-location"
+#define OPERATION_SETTING_MENU "http://tizen.org/appcontrol/operation/configure/location"
+#define PACKAGE_SYSPOPUP "gps-syspopup"
+
+static void _mouse_clicked_cb(void *data, Evas_Object *obj, const char *emission, const char *source);
+
+static const char *_label_get(void)
+{
+       return BUTTON_LABEL;
+}
+
+static const char *_icon_get(qp_setting_icon_image_type type)
+{
+       if (type == QP_SETTING_ICON_NORMAL) {
+               return BUTTON_ICON_NORMAL;
+       } else if (type == QP_SETTING_ICON_HIGHLIGHT) {
+               return BUTTON_ICON_HIGHLIGHT;
+       } else if (type == QP_SETTING_ICON_DIM) {
+#ifdef BUTTON_ICON_DIM
+               return BUTTON_ICON_DIM;
+#endif
+       }
+
+       return NULL;
+}
+
+static void _long_press_cb(void *data)
+{
+#ifdef PACKAGE_SETTING_MENU
+       quickpanel_setting_icon_handler_longpress(PACKAGE_SETTING_MENU, NULL);
+#endif
+}
+
+static void _syspopup_launch(int is_on)
+{
+       syspopup_launch(PACKAGE_SYSPOPUP, NULL);
+}
+
+static void _view_update(Evas_Object *view, int state, int flag_extra_1, int flag_extra_2)
+{
+       Evas_Object *image = NULL;
+       const char *icon_path = NULL;
+
+       quickpanel_setting_icon_state_set(view, state);
+
+       if (state == ICON_VIEW_STATE_ON) {
+#ifdef BUTTON_ICON_HIGHLIGHT
+               icon_path = BUTTON_ICON_HIGHLIGHT;
+#endif
+       } else if (state == ICON_VIEW_STATE_DIM) {
+#ifdef BUTTON_ICON_DIM
+               icon_path = BUTTON_ICON_DIM;
+#endif
+       } else {
+               icon_path = BUTTON_ICON_NORMAL;
+       }
+
+       if (icon_path == NULL) {
+               icon_path = BUTTON_ICON_NORMAL;
+       }
+       image = quickpanel_setting_icon_image_new(view, icon_path);
+       quickpanel_setting_icon_content_set(view, image);
+       quickpanel_setting_icon_text_set(view, BUTTON_LABEL, state);
+}
+
+static void _status_update(QP_Module_Setting *module, int flag_extra_1, int flag_extra_2)
+{
+       int ret = 0;
+       bool status = 0;
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_progress_mode_set(module, FLAG_DISABLE, FLAG_TURN_OFF);
+       quickpanel_setting_module_icon_timer_del(module);
+
+       ret = location_manager_is_enabled_method(LOCATIONS_METHOD_HYBRID, &status);
+       msgif(ret != 0, "fail to get LOCATIONS_METHOD_HYBRID:%d", ret);
+
+       if (status == true) {
+               quickpanel_setting_module_icon_state_set(module, ICON_VIEW_STATE_ON);
+       } else {
+               quickpanel_setting_module_icon_state_set(module, ICON_VIEW_STATE_OFF);
+       }
+
+       quickpanel_setting_module_icon_view_update(module,
+                       quickpanel_setting_module_icon_state_get(module),
+                       FLAG_VALUE_VOID);
+}
+
+static void _mouse_clicked_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
+{
+       int ret = 0;
+       bool enable = 0;
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       if (quickpanel_setting_module_is_icon_clickable(module) == 0) {
+               return;
+       }
+
+       if (quickpanel_setting_module_icon_state_get(module) == ICON_VIEW_STATE_OFF) {
+               _syspopup_launch(quickpanel_setting_module_icon_state_get(module));
+       } else {
+               // Use my location off
+               ret = location_manager_is_enabled_method(LOCATIONS_METHOD_HYBRID, &enable);
+               if (ret == false) {
+                       if (enable == true) {
+                               ret = location_manager_enable_method(LOCATIONS_METHOD_HYBRID, false);
+                               if (ret != 0) {
+                                       ERR("Failed to set LOCATIONS_METHOD_HYBRID[%d]", ret);
+                               }
+                       }
+               } else {
+                       ERR("Failed to get Use my location[%d]", ret);
+               }
+               // GPS off
+               ret = location_manager_is_enabled_method(LOCATIONS_METHOD_GPS, &enable);
+               if (ret == false) {
+                       if (enable == true) {
+                               ret = location_manager_enable_method(LOCATIONS_METHOD_GPS, false);
+                               if (ret != 0) {
+                                       ERR("Failed to set LOCATIONS_METHOD_GPS [%d]", ret);
+                               }
+                       }
+               } else {
+                       ERR("Failed to get GPS[%d]", ret);
+               }
+               // Wireless networks off
+               ret = location_manager_is_enabled_method(LOCATIONS_METHOD_WPS, &enable);
+               if (ret == false) {
+                       if (enable == true) {
+                               ret = location_manager_enable_method(LOCATIONS_METHOD_WPS, false);
+                               if (ret != 0) {
+                                       ERR("Failed to set LOCATIONS_METHOD_WPS [%d]", ret);
+                               }
+                       }
+               } else {
+                       ERR("Failed to get network[%d]", ret);
+               }
+       }
+}
+
+static void _gps_vconf_cb(keynode_t *node, void *data)
+{
+       _status_update(data, FLAG_VALUE_VOID, FLAG_VALUE_VOID);
+}
+
+static int _register_module_event_handler(void *data)
+{
+       int ret = 0;
+
+       ret = vconf_notify_key_changed(VCONFKEY_LOCATION_USE_MY_LOCATION,
+                       _gps_vconf_cb, data);
+       msgif(ret != 0, "failed to notify key(VCONFKEY_LOCATION_USE_MY_LOCATION) : %d", ret);
+
+       return QP_OK;
+}
+
+static int _unregister_module_event_handler(void *data)
+{
+       int ret = 0;
+
+       ret = vconf_ignore_key_changed(VCONFKEY_LOCATION_USE_MY_LOCATION,
+                       _gps_vconf_cb);
+       msgif(ret != 0, "failed to ignore key(VCONFKEY_LOCATION_USE_MY_LOCATION) : %d", ret);
+
+       return QP_OK;
+}
+
+/****************************************************************************
+ *
+ * Quickpanel Item functions
+ *
+ ****************************************************************************/
+static int _init(void *data)
+{
+       int ret = QP_OK;
+
+       ret = _register_module_event_handler(data);
+
+       return ret;
+}
+
+static int _fini(void *data)
+{
+       int ret = QP_OK;
+
+       ret = _unregister_module_event_handler(data);
+
+       return ret;
+}
+
+static void _lang_changed(void *data)
+{
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_icon_view_update_text(module);
+}
+
+static void _refresh(void *data)
+{
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_icon_view_update_text(module);
+}
+
+static void _reset_icon(QP_Module_Setting *module)
+{
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_progress_mode_set(module, FLAG_DISABLE, FLAG_VALUE_VOID);
+       _status_update(module, FLAG_VALUE_VOID, FLAG_VALUE_VOID);
+}
+
+static void _handler_on(void *data)
+{
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_progress_mode_set(module, FLAG_DISABLE, FLAG_TURN_OFF);
+       quickpanel_setting_module_icon_timer_del(module);
+
+       if (quickpanel_setting_module_icon_state_get(module) == ICON_VIEW_STATE_OFF) {
+               quickpanel_setting_module_progress_mode_set(module, FLAG_ENABLE, FLAG_TURN_ON);
+               quickpanel_setting_module_icon_timer_add(module);
+       } else {
+               ERR("the button is already turned on");
+               _reset_icon(module);
+       }
+}
+
+static void _handler_off(void *data)
+{
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_progress_mode_set(module, FLAG_DISABLE, FLAG_TURN_OFF);
+       quickpanel_setting_module_icon_timer_del(module);
+
+       if (quickpanel_setting_module_icon_state_get(module) == ICON_VIEW_STATE_ON) {
+               quickpanel_setting_module_progress_mode_set(module, FLAG_ENABLE, FLAG_TURN_OFF);
+               quickpanel_setting_module_icon_timer_add(module);
+       } else {
+               ERR("the button is already turned off");
+               _reset_icon(module);
+       }
+}
+
+static void _handler_progress_on(void *data)
+{
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_progress_mode_set(module, FLAG_ENABLE, FLAG_VALUE_VOID);
+}
+
+static void _handler_progress_off(void *data)
+{
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       _reset_icon(module);
+}
+
+static int _handler_ipc(const char *command, void *data)
+{
+       int i = 0;
+       retif(data == NULL, EINA_FALSE, "item data is NULL");
+       retif(command == NULL, EINA_FALSE, "command is NULL");
+
+       static Setting_Activity_Handler __table_handler[] = {
+               {
+                       .command = "on",
+                       .handler = _handler_on,
+               },
+               {
+                       .command = "off",
+                       .handler = _handler_off,
+               },
+               {
+                       .command = "progress_on",
+                       .handler = _handler_progress_on,
+               },
+               {
+                       .command = "progress_off",
+                       .handler = _handler_progress_off,
+               },
+               {
+                       .command = NULL,
+                       .handler = NULL,
+               },
+       };
+
+       for (i = 0; __table_handler[i].command; i++) {
+               if (strcasecmp(__table_handler[i].command, command)) {
+                       continue;
+               }
+
+               if (__table_handler[i].handler != NULL) {
+                       DBG("process:%s", command);
+                       __table_handler[i].handler(data);
+               }
+               break;
+       }
+
+       return EINA_TRUE;
+}
+
+QP_Module_Setting gps = {
+       .name                           = "gps",
+       .init                           = _init,
+       .fini                           = _fini,
+       .lang_changed           = _lang_changed,
+       .refresh                        = _refresh,
+       .icon_get                       = _icon_get,
+       .label_get                      = _label_get,
+       .view_update        = _view_update,
+       .status_update          = _status_update,
+       .handler_longpress              = _long_press_cb,
+       .handler_ipc        = _handler_ipc,
+       .handler_press          = _mouse_clicked_cb,
+};
diff --git a/daemon/settings/modules/rotate-lock.c b/daemon/settings/modules/rotate-lock.c
new file mode 100755 (executable)
index 0000000..002d852
--- /dev/null
@@ -0,0 +1,209 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+
+#include <vconf.h>
+#include <system_settings.h>
+#include <bundle_internal.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "common.h"
+#include "quickpanel-ui.h"
+#include "settings.h"
+#include "setting_utils.h"
+#include "setting_module_api.h"
+#include "settings_icon_common.h"
+
+#define BUTTON_LABEL _("IDS_ST_BUTTON2_AUTO_NROTATE")
+#define BUTTON_ICON_NORMAL "quick_icon_auto_rotate.png"
+#define BUTTON_ICON_HIGHLIGHT NULL
+#define BUTTON_ICON_DIM NULL
+#define PACKAGE_SETTING_MENU "setting-display-efl"
+
+static void _mouse_clicked_cb(void *data, Evas_Object *obj, const char *emission, const char *source);
+
+static const char *_label_get(void)
+{
+       return BUTTON_LABEL;
+}
+
+static const char *_icon_get(qp_setting_icon_image_type type)
+{
+       if (type == QP_SETTING_ICON_NORMAL) {
+               return BUTTON_ICON_NORMAL;
+       } else if (type == QP_SETTING_ICON_HIGHLIGHT) {
+               return BUTTON_ICON_HIGHLIGHT;
+       } else if (type == QP_SETTING_ICON_DIM) {
+#ifdef BUTTON_ICON_DIM
+               return BUTTON_ICON_DIM;
+#endif
+       }
+
+       return NULL;
+}
+
+static void _long_press_cb(void *data)
+{
+#ifdef PACKAGE_SETTING_MENU
+       bundle *kb = bundle_create();
+       if (kb != NULL) {
+               bundle_add(kb, "viewtype", "main");
+               quickpanel_setting_icon_handler_longpress(PACKAGE_SETTING_MENU, kb);
+               bundle_free(kb);
+       } else {
+               ERR("failed to create the bunlde");
+       }
+#endif
+}
+
+static void _view_update(Evas_Object *view, int state, int flag_extra_1, int flag_extra_2)
+{
+       Evas_Object *image = NULL;
+       const char *icon_path = NULL;
+
+       quickpanel_setting_icon_state_set(view, state);
+
+       if (state == ICON_VIEW_STATE_ON) {
+#ifdef BUTTON_ICON_HIGHLIGHT
+               icon_path = BUTTON_ICON_HIGHLIGHT;
+#endif
+       } else if (state == ICON_VIEW_STATE_DIM) {
+#ifdef BUTTON_ICON_DIM
+               icon_path = BUTTON_ICON_DIM;
+#endif
+       } else {
+               icon_path = BUTTON_ICON_NORMAL;
+       }
+
+       if (icon_path == NULL) {
+               icon_path = BUTTON_ICON_NORMAL;
+       }
+       image = quickpanel_setting_icon_image_new(view, icon_path);
+       quickpanel_setting_icon_content_set(view, image);
+       quickpanel_setting_icon_text_set(view, BUTTON_LABEL, state);
+}
+
+static void _status_update(QP_Module_Setting *module, int flag_extra_1, int flag_extra_2)
+{
+       int ret = 0;
+       bool status = false;
+       retif(module == NULL, , "Invalid parameter!");
+
+       ret = system_settings_get_value_bool(SYSTEM_SETTINGS_KEY_DISPLAY_SCREEN_ROTATION_AUTO, &status);
+       msgif(ret !=  SYSTEM_SETTINGS_ERROR_NONE , "failed to notify key SYSTEM_SETTINGS_KEY_DISPLAY_SCREEN_ROTATION_AUTO : %d", ret);
+
+       if (status == true) {
+               quickpanel_setting_module_icon_state_set(module, ICON_VIEW_STATE_ON);
+       } else {
+               quickpanel_setting_module_icon_state_set(module, ICON_VIEW_STATE_OFF);
+       }
+
+       quickpanel_setting_module_icon_view_update(module, quickpanel_setting_module_icon_state_get(module),FLAG_VALUE_VOID);
+}
+
+static void _mouse_clicked_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
+{
+       int ret = 0;
+       bool status = false;
+
+       ret = system_settings_get_value_bool(SYSTEM_SETTINGS_KEY_DISPLAY_SCREEN_ROTATION_AUTO, &status);
+       msgif(ret != SYSTEM_SETTINGS_ERROR_NONE, "failed to notify key SYSTEM_SETTINGS_KEY_DISPLAY_SCREEN_ROTATION_AUTO : %d", ret);
+
+       ret = system_settings_set_value_bool(SYSTEM_SETTINGS_KEY_DISPLAY_SCREEN_ROTATION_AUTO, !status );
+       msgif(ret != SYSTEM_SETTINGS_ERROR_NONE, "failed to notify key SYSTEM_SETTINGS_KEY_DISPLAY_SCREEN_ROTATION_AUTO : %d", ret);
+}
+
+static void _autorotation_vconf_cb(system_settings_key_e key, void *data)
+{
+       _status_update(data, FLAG_VALUE_VOID, FLAG_VALUE_VOID);
+}
+
+static int _register_module_event_handler(void *data)
+{
+       int ret = 0;
+
+       ret = system_settings_set_changed_cb(SYSTEM_SETTINGS_KEY_DISPLAY_SCREEN_ROTATION_AUTO, _autorotation_vconf_cb, data);
+       msgif(ret != SYSTEM_SETTINGS_ERROR_NONE, "failed to notify key(SYSTEM_SETTINGS_KEY_DISPLAY_SCREEN_ROTATION_AUTO) : %d", ret);
+
+       return QP_OK;
+}
+
+static int _unregister_module_event_handler(void *data)
+{
+       int ret = 0;
+
+       ret = system_settings_unset_changed_cb(SYSTEM_SETTINGS_KEY_DISPLAY_SCREEN_ROTATION_AUTO);
+       msgif(ret != SYSTEM_SETTINGS_ERROR_NONE, "failed to ignore key(SYSTEM_SETTINGS_KEY_DISPLAY_SCREEN_ROTATION_AUTO) : %d", ret);
+
+       return QP_OK;
+}
+
+/****************************************************************************
+ *
+ * Quickpanel Item functions
+ *
+ ****************************************************************************/
+static int _init(void *data)
+{
+       int ret = QP_OK;
+
+       ret = _register_module_event_handler(data);
+
+       return ret;
+}
+
+static int _fini(void *data)
+{
+       int ret = QP_OK;
+
+       ret = _unregister_module_event_handler(data);
+
+       return ret;
+}
+
+static void _lang_changed(void *data)
+{
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_icon_view_update_text(module);
+}
+
+static void _refresh(void *data)
+{
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_icon_view_update_text(module);
+}
+
+QP_Module_Setting rotate = {
+       .name                           = "rotate",
+       .init                           = _init,
+       .fini                           = _fini,
+       .lang_changed           = _lang_changed,
+       .refresh                        = _refresh,
+       .icon_get                       = _icon_get,
+       .label_get                      = _label_get,
+       .view_update        = _view_update,
+       .status_update          = _status_update,
+       .handler_longpress              = _long_press_cb,
+       .handler_press          = _mouse_clicked_cb,
+};
diff --git a/daemon/settings/modules/sound-profile.c b/daemon/settings/modules/sound-profile.c
new file mode 100755 (executable)
index 0000000..fecff38
--- /dev/null
@@ -0,0 +1,304 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+
+#include <vconf.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <feedback.h>
+#include <sound_manager.h>
+#include <E_DBus.h>
+
+#include "common_uic.h"
+#include "common.h"
+#include "quickpanel-ui.h"
+#include "settings.h"
+#include "setting_utils.h"
+#include "setting_module_api.h"
+#include "settings_icon_common.h"
+
+#define BUTTON_LABEL _("IDS_QP_BUTTON2_SOUND_ABB")
+#define BUTTON_ICON_SND_NORMAL "quick_icon_sn_vf.png"
+#define BUTTON_ICON_SND_HIGHLIGHT "quick_icon_sn_vf.png"
+#define BUTTON_ICON_MUTE_NORMAL "quick_icon_sf_vf.png"
+#define BUTTON_ICON_VIB_HIGHLIGHT "quick_icon_sf_vn.png"
+#define PACKAGE_SETTING_MENU "setting-profile-efl"
+#define SAM_LOG_FEATURE_SOUND "ST0C"
+
+static int g_check_press = 0;
+
+static void _mouse_clicked_cb(void *data, Evas_Object *obj, const char *emission, const char *source);
+
+static const char *_label_get(void)
+{
+       return BUTTON_LABEL;
+}
+
+static const char *_icon_get(qp_setting_icon_image_type type)
+{
+       if (type == QP_SETTING_ICON_NORMAL) {
+               return BUTTON_ICON_SND_NORMAL;
+       } else if (type == QP_SETTING_ICON_HIGHLIGHT) {
+               return BUTTON_ICON_SND_HIGHLIGHT;
+       } else if (type == QP_SETTING_ICON_DIM) {
+#ifdef BUTTON_ICON_DIM
+               return BUTTON_ICON_DIM;
+#endif
+       }
+
+       return NULL;
+}
+
+static void _long_press_cb(void *data)
+{
+#ifdef PACKAGE_SETTING_MENU
+       quickpanel_setting_icon_handler_longpress(PACKAGE_SETTING_MENU, NULL);
+#endif
+}
+
+static void _play_snd_job_cb(void *data)
+{
+       if (feedback_play_type(FEEDBACK_TYPE_SOUND, FEEDBACK_PATTERN_SILENT_OFF) != FEEDBACK_ERROR_NONE) {
+               ERR("failed to play a sound");
+       }
+}
+
+static void _play_vib_job_cb(void *data)
+{
+       if (feedback_play_type(FEEDBACK_TYPE_VIBRATION, FEEDBACK_PATTERN_VIBRATION_ON) != FEEDBACK_ERROR_NONE) {
+               ERR("failed to play a vibration");
+       }
+}
+
+static void _view_update(Evas_Object *view, int state, int flag_extra_1, int flag_extra_2)
+{
+       int icon_state;
+       int ret = -1;
+       int sound_status = 1;
+       int vibration_status = 1;
+       Evas_Object *image = NULL;
+       const char *text = NULL;
+       const char *img_path = NULL;
+
+       retif(view == NULL, , "Invalid parameter!");
+
+       /* Get sound status */
+       ret = vconf_get_bool(VCONFKEY_SETAPPL_SOUND_STATUS_BOOL, &sound_status);
+       /* If fail, set sound on status */
+       if (ret != 0) {
+               ERR("failed get VCONFKEY_SETAPPL_SOUND_STATUS_BOOL:%d", ret);
+               sound_status = 1;
+       }
+
+       /* Get vibration status */
+       ret = vconf_get_bool(VCONFKEY_SETAPPL_VIBRATION_STATUS_BOOL,
+                       &vibration_status);
+       /* If fail, set vibration on status */
+       if (ret != 0) {
+               ERR("failed get VCONFKEY_SETAPPL_VIBRATION_STATUS_BOOL:%d", ret);
+               vibration_status = 1;
+       }
+
+       INFO("sound : %d, vibration : %d", sound_status, vibration_status);
+
+       if (sound_status == 1 && vibration_status == 1) {
+               /* Sound & vibration profile */
+               icon_state = ICON_VIEW_STATE_ON;
+               text = _("IDS_QP_BUTTON2_SOUND_ABB");
+               img_path = BUTTON_ICON_SND_HIGHLIGHT;
+       } else if (sound_status == 0 && vibration_status == 1) {
+               /* Vibration profile */
+               icon_state = ICON_VIEW_STATE_ON;
+               text = _("IDS_QP_BUTTON2_VIBRATE");
+               img_path = BUTTON_ICON_VIB_HIGHLIGHT;
+       } else if (sound_status == 1 && vibration_status == 0) {
+               /*  Sound profile */
+               icon_state = ICON_VIEW_STATE_ON;
+               text = _("IDS_QP_BUTTON2_SOUND_ABB");
+               img_path = BUTTON_ICON_SND_HIGHLIGHT;
+       } else {
+               /*  Mute profile */
+               icon_state = ICON_VIEW_STATE_OFF;
+               text = _("IDS_QP_BUTTON2_MUTE_ABB");
+               img_path = BUTTON_ICON_MUTE_NORMAL;
+       }
+
+       quickpanel_setting_icon_state_set(view, icon_state);
+       quickpanel_setting_icon_text_set(view, text, icon_state);
+       image = quickpanel_setting_icon_image_new(view, img_path);
+       quickpanel_setting_icon_content_set(view, image);
+
+       if (quickpanel_uic_is_opened() && g_check_press) {
+               if (sound_status == 1 && vibration_status == 0) {
+                       ecore_job_add(_play_snd_job_cb, NULL);
+                       g_check_press = 0;
+               } else if (sound_status == 0 && vibration_status == 1) {
+                       ecore_job_add(_play_vib_job_cb, NULL);
+                       g_check_press = 0;
+               }
+       }
+}
+
+static void _status_update(QP_Module_Setting *module, int flag_extra_1, int flag_extra_2)
+{
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_icon_view_update(module,
+                       quickpanel_setting_module_icon_state_get(module),
+                       FLAG_VALUE_VOID);
+}
+
+static void _mouse_clicked_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
+{
+       int ret = 0;
+       int sound_status = 1;
+       int vibration_status = 1;
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       /* Get sound profile */
+       ret = vconf_get_bool(VCONFKEY_SETAPPL_SOUND_STATUS_BOOL,
+                       &sound_status);
+       retif(ret != 0, , "failed to get sound status(%d)", ret);
+
+       ret = vconf_get_bool(VCONFKEY_SETAPPL_VIBRATION_STATUS_BOOL,
+                       &vibration_status);
+       retif(ret != 0, ,"failed to get vibration status(%d)", ret);
+
+       INFO("sound : %d, vibration : %d", sound_status, vibration_status);
+
+       g_check_press = 1;
+
+       if (sound_status == 1 && vibration_status == 1) {
+               ret = vconf_set_bool(VCONFKEY_SETAPPL_SOUND_STATUS_BOOL, 0);
+               msgif(ret != 0, "failed set VCONFKEY_SETAPPL_SOUND_STATUS_BOOL:%d", ret);
+       } else  if (sound_status == 1 && vibration_status == 0) {
+               ret = vconf_set_bool(VCONFKEY_SETAPPL_VIBRATION_STATUS_BOOL, 1);
+               msgif(ret != 0, "failed set VCONFKEY_SETAPPL_VIBRATION_STATUS_BOOL:%d", ret);
+               ret = vconf_set_bool(VCONFKEY_SETAPPL_SOUND_STATUS_BOOL, 0);
+               msgif(ret != 0, "failed set VCONFKEY_SETAPPL_SOUND_STATUS_BOOL:%d", ret);
+       } else if (sound_status == 0 && vibration_status == 1) {
+               ret = vconf_set_bool(VCONFKEY_SETAPPL_VIBRATION_STATUS_BOOL, 0);
+               msgif(ret != 0, "failed set VCONFKEY_SETAPPL_VIBRATION_STATUS_BOOL:%d", ret);
+               /*insert log for mute mode on state */
+               //_log_manager_insert_log(SAM_LOG_FEATURE_SOUND, "MUTE", NULL);
+       } else if (sound_status == 0 && vibration_status == 0) {
+               ret = vconf_set_bool(VCONFKEY_SETAPPL_SOUND_STATUS_BOOL, 1);
+               msgif(ret != 0, "failed set VCONFKEY_SETAPPL_SOUND_STATUS_BOOL:%d", ret);
+       }
+}
+
+static void _soundprofile_vconf_cb(keynode_t *node, void *data)
+{
+       _status_update(data, FLAG_VALUE_VOID, FLAG_VALUE_VOID);
+}
+
+static int _register_module_event_handler(void *data)
+{
+       int ret = 0;
+
+       ret = vconf_notify_key_changed(VCONFKEY_SETAPPL_SOUND_STATUS_BOOL,
+                       _soundprofile_vconf_cb, data);
+       msgif(ret != 0,
+                       "failed to vconf_notify_key_changed [%s] -[%d]",
+                       VCONFKEY_SETAPPL_SOUND_STATUS_BOOL, ret);
+
+       ret = vconf_notify_key_changed(VCONFKEY_SETAPPL_VIBRATION_STATUS_BOOL,
+                       _soundprofile_vconf_cb, data);
+       msgif(ret != 0,
+                       "failed to vconf_notify_key_changed [%s] -[%d]",
+                       VCONFKEY_SETAPPL_SOUND_STATUS_BOOL, ret);
+
+       return QP_OK;
+}
+
+static int _unregister_module_event_handler(void *data)
+{
+       int ret = 0;
+
+       ret = vconf_ignore_key_changed(VCONFKEY_SETAPPL_SOUND_STATUS_BOOL,
+                       _soundprofile_vconf_cb);
+       msgif(ret != 0,
+                       "failed to vconf_ignore_key_changed [%s] -[%d]",
+                       VCONFKEY_SETAPPL_SOUND_STATUS_BOOL, ret);
+
+       ret = vconf_ignore_key_changed(VCONFKEY_SETAPPL_VIBRATION_STATUS_BOOL,
+                       _soundprofile_vconf_cb);
+       msgif(ret != 0,
+                       "failed to vconf_ignore_key_changed [%s] -[%d]",
+                       VCONFKEY_SETAPPL_SOUND_STATUS_BOOL, ret);
+
+       return QP_OK;
+}
+
+/****************************************************************************
+ *
+ * Quickpanel Item functions
+ *
+ ****************************************************************************/
+static int _init(void *data)
+{
+       int ret = QP_OK;
+
+       ret = _register_module_event_handler(data);
+
+       return ret;
+}
+
+static int _fini(void *data)
+{
+       int ret = QP_OK;
+
+       ret = _unregister_module_event_handler(data);
+
+       return ret;
+}
+
+static void _lang_changed(void *data)
+{
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_icon_view_update_text(module);
+       _status_update(module, FLAG_VALUE_VOID, FLAG_VALUE_VOID);
+}
+
+static void _refresh(void *data)
+{
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_icon_view_update_text(module);
+       _status_update(module, FLAG_VALUE_VOID, FLAG_VALUE_VOID);
+}
+
+
+QP_Module_Setting sound = {
+       .name                           = "sound",
+       .init                           = _init,
+       .fini                           = _fini,
+       .lang_changed           = _lang_changed,
+       .refresh                        = _refresh,
+       .icon_get                       = _icon_get,
+       .label_get                      = _label_get,
+       .view_update        = _view_update,
+       .status_update          = _status_update,
+       .handler_longpress              = _long_press_cb,
+       .handler_press          = _mouse_clicked_cb,
+       .is_disable_feedback = 1,
+};
diff --git a/daemon/settings/modules/wifi.c b/daemon/settings/modules/wifi.c
new file mode 100755 (executable)
index 0000000..29faf7f
--- /dev/null
@@ -0,0 +1,575 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+
+#include <app.h>
+#include <tethering.h>
+#include <wifi.h>
+#include <vconf.h>
+
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "common.h"
+#include "quickpanel-ui.h"
+#include "settings.h"
+#include "setting_utils.h"
+#include "setting_module_api.h"
+#include "settings_icon_common.h"
+
+#define E_DATA_POPUP_MODULE_ITEM "mobule_item"
+#define BUTTON_LABEL _("IDS_ST_BUTTON2_WI_FI_ABB")
+#define BUTTON_ICON_NORMAL "quick_icon_wifi.png"
+#define BUTTON_ICON_HIGHLIGHT NULL
+#define BUTTON_ICON_DIM NULL
+#define PACKAGE_SETTING_MENU "wifi-efl-ug-lite"
+#define PACKAGE_SETTING_MENU_PTN "wifi-efl-ug" // for redwood partner
+
+static int _wifi_on(void *data, const char *popup_txt);
+static int _wifi_off(void);
+static int _wifi_is_on(bool *is_on);
+static void _wifi_state_changed_cb(wifi_device_state_e state, void *user_data);
+static void _mouse_clicked_cb(void *data, Evas_Object *obj, const char *emission, const char *source);
+static void _reset_icon(QP_Module_Setting *module);
+
+static const char *_label_get(void)
+{
+       return BUTTON_LABEL;
+}
+
+static const char *_icon_get(qp_setting_icon_image_type type)
+{
+       if (type == QP_SETTING_ICON_NORMAL) {
+               return BUTTON_ICON_NORMAL;
+       } else if (type == QP_SETTING_ICON_HIGHLIGHT) {
+               return BUTTON_ICON_HIGHLIGHT;
+       } else if (type == QP_SETTING_ICON_DIM) {
+#ifdef BUTTON_ICON_DIM
+               return BUTTON_ICON_DIM;
+#endif
+       }
+
+       return NULL;
+}
+
+static void _long_press_cb(void *data)
+{
+#ifdef PACKAGE_SETTING_MENU
+       if (quickpanel_common_ui_is_package_exist(PACKAGE_SETTING_MENU)) {
+               quickpanel_setting_icon_handler_longpress(PACKAGE_SETTING_MENU, NULL);
+       } else {
+               DBG("No package[%s] try[%s]", PACKAGE_SETTING_MENU, PACKAGE_SETTING_MENU_PTN);
+               quickpanel_setting_icon_handler_longpress(PACKAGE_SETTING_MENU_PTN, NULL);
+       }
+#endif
+}
+
+static void _view_update(Evas_Object *view, int state, int flag_extra_1, int flag_extra_2)
+{
+       Evas_Object *image = NULL;
+       const char *icon_path = NULL;
+
+       quickpanel_setting_icon_state_set(view, state);
+
+       if (state == ICON_VIEW_STATE_ON) {
+#ifdef BUTTON_ICON_HIGHLIGHT
+               icon_path = BUTTON_ICON_HIGHLIGHT;
+#endif
+       } else if (state == ICON_VIEW_STATE_DIM) {
+#ifdef BUTTON_ICON_DIM
+               icon_path = BUTTON_ICON_DIM;
+#endif
+       } else {
+               icon_path = BUTTON_ICON_NORMAL;
+       }
+
+       if (icon_path == NULL) {
+               icon_path = BUTTON_ICON_NORMAL;
+       }
+       image = quickpanel_setting_icon_image_new(view, icon_path);
+       quickpanel_setting_icon_content_set(view, image);
+       quickpanel_setting_icon_text_set(view, BUTTON_LABEL, state);
+}
+
+static void _status_update(QP_Module_Setting *module, int wifi_status, int flag_extra_2)
+{
+       ERR("");
+       int ret = -1;
+       bool is_on = 0;
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_icon_timer_del(module);
+
+       if (wifi_status == FLAG_VALUE_VOID) {
+               ret = _wifi_is_on(&is_on);
+       } else {
+               ret = 0;
+               if (wifi_status == WIFI_DEVICE_STATE_ACTIVATED) {
+                       is_on = true;
+               } else {
+                       is_on = false;
+               }
+       }
+
+       if (ret == 0 && is_on == true) {
+               quickpanel_setting_module_icon_state_set(module, ICON_VIEW_STATE_ON);
+       } else {
+               quickpanel_setting_module_icon_state_set(module, ICON_VIEW_STATE_OFF);
+       }
+
+       quickpanel_setting_module_progress_mode_set(module, FLAG_DISABLE, FLAG_TURN_OFF);
+       quickpanel_setting_module_icon_timer_del(module);
+
+       quickpanel_setting_module_icon_view_update(module,
+                       quickpanel_setting_module_icon_state_get(module),
+                       FLAG_VALUE_VOID);
+}
+
+static void _mouse_clicked_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
+{
+       int ret = 0;
+       int is_on = 0;
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       if (quickpanel_setting_module_is_icon_clickable(module) == 0) {
+               return;
+       }
+
+       if (quickpanel_setting_module_icon_state_get(module) == ICON_VIEW_STATE_ON) {
+               is_on = FLAG_TURN_OFF;
+               ret = _wifi_off();
+       } else {
+               is_on = FLAG_TURN_ON;
+               ret = _wifi_on(module,
+                               _("IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"));
+       }
+
+       if (ret != 0) {
+               ERR("wifi op failed:%d", ret);
+               return;
+       }
+
+       if (is_on == 1) {
+               quickpanel_setting_module_progress_mode_set(module, FLAG_ENABLE, FLAG_TURN_ON);
+       } else {
+               quickpanel_setting_module_progress_mode_set(module, FLAG_ENABLE, FLAG_TURN_OFF);
+       }
+       quickpanel_setting_module_icon_timer_add(module);
+}
+
+static int _register_module_event_handler(void *data)
+{
+       int ret = 0;
+
+       ret = wifi_initialize();
+       msgif(ret < 0, "[ERR] wifi_initialize()");
+
+       ret = wifi_set_device_state_changed_cb(_wifi_state_changed_cb, data);
+       if (ret != 0) {
+               ERR("wifi cb register failed:%d", ret);
+       } else {
+               ERR("wifi op register done:%d", ret);
+       }
+
+       return QP_OK;
+}
+
+static int _unregister_module_event_handler(void *data)
+{
+       int ret = 0;
+
+       ret = wifi_unset_device_state_changed_cb();
+       if (ret != 0) {
+               ERR("wifi cb unregister failed:%d", ret);
+       } else {
+               ERR("wifi op unregister done:%d", ret);
+       }
+
+       ret = wifi_deinitialize();
+       msgif(ret != WIFI_ERROR_NONE, "Fail to deactivate Wi-Fi device");
+
+       return QP_OK;
+}
+
+/****************************************************************************
+ *
+ * Quickpanel Item functions
+ *
+ ****************************************************************************/
+
+static int _init(void *data)
+{
+       int ret = QP_OK;
+
+       ret = _register_module_event_handler(data);
+
+       return ret;
+}
+
+static int _fini(void *data)
+{
+       int ret = QP_OK;
+
+       ret = _unregister_module_event_handler(data);
+
+       return ret;
+}
+
+static void _lang_changed(void *data)
+{
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_icon_view_update_text(module);
+}
+
+static void _refresh(void *data)
+{
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_icon_view_update_text(module);
+}
+
+static void _wifi_activated_cb(wifi_error_e result, void *user_data)
+{
+       if (result == WIFI_ERROR_NONE) {
+               /* succeed to turn on Wi-Fi */
+       } else {
+               /* failed to turn on Wi-Fi */
+       }
+}
+
+static void _wifi_deactivated_cb(wifi_error_e result, void* user_data)
+{
+       if (result == WIFI_ERROR_NONE) {
+               /* succeed to turn off Wi-Fi */
+       } else {
+               /* failed to turn off Wi-Fi */
+       }
+}
+
+static void _tethering_disabled_cb(tethering_error_e error, tethering_type_e type, tethering_disabled_cause_e code, void *data)
+{
+       int ret;
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       tethering_h th = (tethering_h)(module->loader->extra_handler_1);
+       retif(th == NULL, , "th is NULL");
+       tethering_destroy(th);
+       module->loader->extra_handler_1 = NULL;
+
+       if (error != TETHERING_ERROR_NONE) {
+               /* failed to disable wifi tethering */
+               return;
+       }
+
+       ret = wifi_activate_with_wifi_picker_tested(_wifi_activated_cb, NULL);
+       if (ret != WIFI_ERROR_NONE) {
+               ERR("Fail to activate Wi-Fi device [%d]\n", ret);
+               return;
+       }
+}
+
+static bool _tethering_disable(tethering_type_e type, void *data)
+{
+       tethering_h th = NULL;
+       tethering_error_e ret = TETHERING_ERROR_NONE;
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+
+       retif(module == NULL, false, "Invalid parameter!");
+
+       /* disable wifi tethering */
+       ret = tethering_create(&th);
+       if (ret != TETHERING_ERROR_NONE) {
+               /* failed to create tethering handle */
+               return false;
+       }
+
+       ret = tethering_set_disabled_cb(th, type,
+                       _tethering_disabled_cb, module);
+       if (ret != TETHERING_ERROR_NONE) {
+               /* failed to set disabled callback */
+               tethering_destroy(th);
+               return false;
+       }
+
+       module->loader->extra_handler_1 = th;
+       quickpanel_setting_module_progress_mode_set(module, FLAG_ENABLE, FLAG_TURN_ON);
+       quickpanel_setting_module_icon_timer_add(module);
+
+       ret = tethering_disable(th, type);
+       if (ret != TETHERING_ERROR_NONE) {
+               ERR("fail to tethering_disable()");
+               return false;
+       }
+
+       return true;
+}
+
+static void _tethering_wifi_reply_cb(app_control_h request, app_control_h reply, app_control_result_e result, void *user_data)
+{
+       QP_Module_Setting *module = (QP_Module_Setting *) user_data;
+       char *resp_type = NULL;
+
+       DBG("Result[%d]", result);
+       if (result == APP_CONTROL_RESULT_SUCCEEDED && reply) {
+               app_control_get_extra_data(reply, "_SYSPOPUP_RESP_", &resp_type);
+               if (resp_type) {
+                       DBG("Response[%s]", resp_type);
+                       if (!strcmp("RESP_TETHERING_TYPE_WIFI_OFF", resp_type)) {
+                               _tethering_disable(TETHERING_TYPE_WIFI, user_data);
+                       }
+
+                       free(resp_type);
+               }
+       }
+
+       _reset_icon(module);
+}
+
+static void _tethering_off_popup(Evas_Object *win, void *data, int type, const char *popup_txt)
+{
+       app_control_h service = NULL;
+       int ret = APP_CONTROL_ERROR_NONE;
+
+       ret = app_control_create(&service);
+       if (ret != APP_CONTROL_ERROR_NONE) {
+               ERR("Failed to create app_control[%d]", ret);
+               return;
+       }
+
+       app_control_add_extra_data(service, "_SYSPOPUP_TITLE_", "mobileap");
+       if (type == TETHERING_TYPE_WIFI) {
+               app_control_add_extra_data(service, "_SYSPOPUP_CONTENT_", "TETHERING_TYPE_WIFI");
+       } else {
+               app_control_add_extra_data(service, "_SYSPOPUP_CONTENT_", "TETHERING_TYPE_WIFI_AP");
+       }
+       app_control_add_extra_data(service, "_SYSPOPUP_TYPE_", "popup_user_resp");
+       app_control_add_extra_data(service, "_AP_NAME_", "none");
+
+       app_control_set_app_id(service, "net.netpopup");
+
+       ret = app_control_send_launch_request(service, _tethering_wifi_reply_cb, data);
+       if (ret != APP_CONTROL_ERROR_NONE) {
+               ERR("Failed to send launch request[%d]", ret);
+       }
+
+       app_control_destroy(service);
+}
+
+static int _wifi_on(void *data, const char *popup_txt)
+{
+       int ret = -1;
+       struct appdata *ad = quickpanel_get_app_data();
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(ad == NULL, ret, "Invalid parameter!");
+       retif(module == NULL, ret, "Invalid parameter!");
+
+       /* Check wifi tethering status */
+       if (tethering_is_enabled(NULL, TETHERING_TYPE_WIFI)) {
+               _tethering_off_popup(ad->win, data, TETHERING_TYPE_WIFI, popup_txt);
+               return -1;
+       }
+
+       ret = wifi_activate_with_wifi_picker_tested(_wifi_activated_cb, NULL);
+       if (ret != WIFI_ERROR_NONE) {
+               ERR("Fail to activate Wi-Fi device [%d]\n", ret);
+               return -1;
+       }
+
+       return 0;
+}
+
+static int _wifi_off(void)
+{
+       int ret;
+
+       ret = wifi_deactivate(_wifi_deactivated_cb, NULL);
+       if (ret != WIFI_ERROR_NONE) {
+               ERR("Fail to activate Wi-Fi device [%d]\n", ret);
+               return -1;
+       }
+
+       return 0;
+}
+
+static int _wifi_is_on(bool *is_on)
+{
+       int ret;
+
+       ret = wifi_is_activated(is_on);
+       if (ret != WIFI_ERROR_NONE) {
+               ERR("Fail to get Wi-Fi device status [%d]\n", ret);
+               return -1;
+       }
+
+       return 0;
+}
+
+/*
+   Set Wi-Fi status changed callback
+   - needs to update your Wi-Fi status.
+ */
+static void _wifi_state_changed_cb(wifi_device_state_e state, void *user_data)
+{
+       ERR("state:%d", state);
+
+       if (state == WIFI_DEVICE_STATE_ACTIVATED) {
+               /* Wi-Fi is activated(On) - change your Wi-Fi status */
+               _status_update(user_data, state, FLAG_VALUE_VOID);
+       } else if (state == WIFI_DEVICE_STATE_DEACTIVATED) {
+               /* Wi-Fi is deactivated(Off) - change your Wi-Fi status */
+               _status_update(user_data, state, FLAG_VALUE_VOID);
+       } else {
+               /* Ignore */
+       }
+}
+
+static void _reset_icon(QP_Module_Setting *module) {
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_progress_mode_set(module, FLAG_DISABLE, FLAG_VALUE_VOID);
+       _status_update(module, FLAG_VALUE_VOID, FLAG_VALUE_VOID);
+}
+
+static void _handler_on(void *data)
+{
+       int ret = 0;
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_progress_mode_set(module, FLAG_DISABLE, FLAG_TURN_OFF);
+       quickpanel_setting_module_icon_timer_del(module);
+
+       if (quickpanel_setting_module_icon_state_get(module) == ICON_VIEW_STATE_OFF) {
+               ret = _wifi_on(module, _("IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"));
+
+               if (ret == 0) {
+                       quickpanel_setting_module_progress_mode_set(module, FLAG_ENABLE, FLAG_TURN_ON);
+                       quickpanel_setting_module_icon_timer_add(module);
+               } else {
+                       ERR("op failed:%d", ret);
+               }
+       } else {
+               ERR("the button is already turned on");
+               _reset_icon(module);
+       }
+}
+
+static void _handler_off(void *data)
+{
+       int ret = 0;
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_progress_mode_set(module, FLAG_DISABLE, FLAG_TURN_OFF);
+       quickpanel_setting_module_icon_timer_del(module);
+
+       if (quickpanel_setting_module_icon_state_get(module) == ICON_VIEW_STATE_ON) {
+               ret = _wifi_off();
+
+               if (ret == 0) {
+                       quickpanel_setting_module_progress_mode_set(module, FLAG_ENABLE, FLAG_TURN_OFF);
+                       quickpanel_setting_module_icon_timer_add(module);
+               } else {
+                       ERR("op failed:%d", ret);
+               }
+       } else {
+               ERR("the button is already turned off");
+               _reset_icon(module);
+       }
+}
+
+static void _handler_progress_on(void *data)
+{
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_module_progress_mode_set(module, FLAG_ENABLE, FLAG_VALUE_VOID);
+}
+
+static void _handler_progress_off(void *data)
+{
+       QP_Module_Setting *module = (QP_Module_Setting *)data;
+       retif(module == NULL, , "Invalid parameter!");
+
+       _reset_icon(module);
+}
+
+static int _handler_ipc(const char *command, void *data)
+{
+       int i = 0;
+       retif(data == NULL, EINA_FALSE, "item data is NULL");
+       retif(command == NULL, EINA_FALSE, "command is NULL");
+
+       static Setting_Activity_Handler __table_handler[] = {
+               {
+                       .command = "on",
+                       .handler = _handler_on,
+               },
+               {
+                       .command = "off",
+                       .handler = _handler_off,
+               },
+               {
+                       .command = "progress_on",
+                       .handler = _handler_progress_on,
+               },
+               {
+                       .command = "progress_off",
+                       .handler = _handler_progress_off,
+               },
+               {
+                       .command = NULL,
+                       .handler = NULL,
+               },
+       };
+
+       for (i = 0; __table_handler[i].command; i++) {
+               if (strcasecmp(__table_handler[i].command, command)) {
+                       continue;
+               }
+
+               if (__table_handler[i].handler != NULL) {
+                       DBG("process:%s", command);
+                       __table_handler[i].handler(data);
+               }
+               break;
+       }
+
+       return EINA_TRUE;
+}
+
+QP_Module_Setting wifi = {
+       .name                           = "wifi",
+       .init                           = _init,
+       .fini                           = _fini,
+       .lang_changed           = _lang_changed,
+       .refresh                        = _refresh,
+       .icon_get                       = _icon_get,
+       .label_get                      = _label_get,
+       .view_update        = _view_update,
+       .status_update          = _status_update,
+       .handler_longpress      = _long_press_cb,
+       .handler_ipc        = _handler_ipc,
+       .handler_press          = _mouse_clicked_cb,
+};
diff --git a/daemon/settings/setting_module_api.c b/daemon/settings/setting_module_api.c
new file mode 100755 (executable)
index 0000000..e4b2722
--- /dev/null
@@ -0,0 +1,295 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "common.h"
+#include "quickpanel_def.h"
+#include "quickpanel-ui.h"
+#include "settings.h"
+#include "setting_utils.h"
+#include "setting_module_api.h"
+#include "settings_icon_common.h"
+
+#ifdef QP_SCREENREADER_ENABLE
+#include "accessibility.h"
+#endif
+
+#define E_DATA_CONTAINER_TYPE "container_type"
+
+static qp_setting_icon_container_type _icon_container_type_get(Evas_Object *view)
+{
+       retif(view == NULL, QP_SETTING_ICON_CONTAINER_NONE, "invalid parameter");
+
+       return (qp_setting_icon_container_type)evas_object_data_get(view, E_DATA_CONTAINER_TYPE);
+}
+
+static void _icon_view_add(QP_Module_Setting *module, Evas_Object *view ,qp_setting_icon_container_type container_type)
+{
+       retif(module == NULL, , "invalid parameter");
+       retif(view == NULL, , "invalid parameter");
+
+       if (eina_list_data_find(module->view_list, view) == NULL) {
+               evas_object_data_set(view, E_DATA_CONTAINER_TYPE, (void *)container_type);
+               module->view_list = eina_list_append(module->view_list, view);
+       }
+}
+
+static void _icon_view_del(QP_Module_Setting *module, Evas_Object *view)
+{
+       retif(module == NULL, , "invalid parameter");
+       retif(view == NULL, , "invalid parameter");
+
+       module->view_list = eina_list_remove(module->view_list, view);
+}
+
+HAPI Evas_Object *quickpanel_setting_module_icon_create(QP_Module_Setting *module, Evas_Object *parent)
+{
+       Evas_Object *view = NULL;
+       retif(module == NULL, NULL, "invalid parameter");
+       retif(parent == NULL, NULL, "invalid parameter");
+
+       view = quickpanel_setting_icon_new(parent);
+       retif(view == NULL, NULL, "failed to create icon");
+
+       if (module->label_get != NULL) {
+               quickpanel_setting_icon_text_set(view, module->label_get(), ICON_VIEW_STATE_OFF);
+       }
+       if (module->handler_press != NULL) {
+               if (module->is_disable_feedback) {
+                       quickpanel_setting_icon_click_cb_without_feedback_add(view, module->handler_press, module);
+               } else {
+                       quickpanel_setting_icon_click_cb_add(view, module->handler_press, module);
+               }
+       }
+       evas_object_data_set(view, E_DATA_MODULE_INFO, module);
+       evas_object_show(view);
+
+       return view;
+}
+
+HAPI QP_Module_Setting *quickpanel_setting_module_get_from_icon(Evas_Object *icon)
+{
+       return evas_object_data_get(icon, E_DATA_MODULE_INFO);
+}
+
+HAPI void quickpanel_setting_module_icon_add(QP_Module_Setting *module, Evas_Object *icon, qp_setting_icon_container_type container_type)
+{
+       _icon_view_add(module, icon, container_type);
+}
+
+HAPI Evas_Object *quickpanel_setting_module_icon_get(QP_Module_Setting *module, qp_setting_icon_container_type container_type)
+{
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *view = NULL;
+       retif(module == NULL, NULL, "invalid parameter");
+
+       if (module->view_update != NULL) {
+               EINA_LIST_FOREACH_SAFE(module->view_list, l, l_next, view) {
+                       if (_icon_container_type_get(view) == container_type) {
+                               return view;
+                       }
+               }
+       }
+
+       return NULL;
+}
+
+HAPI void quickpanel_setting_module_icon_remove(QP_Module_Setting *module, Evas_Object *icon)
+{
+       _icon_view_del(module, icon);
+}
+
+HAPI void quickpanel_setting_module_icon_state_set(QP_Module_Setting *module, int state)
+{
+       retif(module == NULL, , "invalid parameter");
+       retif(module->loader == NULL, , "invalid parameter");
+
+       module->loader->state = state;
+}
+
+HAPI int quickpanel_setting_module_icon_state_get(QP_Module_Setting *module)
+{
+       retif(module == NULL, FLAG_TURN_OFF, "invalid parameter");
+       retif(module->loader == NULL, FLAG_TURN_OFF, "invalid parameter");
+
+       return module->loader->state;
+}
+
+HAPI void quickpanel_setting_module_icon_view_update(QP_Module_Setting *module, int flag_extra_1, int flag_extra_2)
+{
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *view = NULL;
+       retif(module == NULL, , "invalid parameter");
+
+       int status = quickpanel_setting_module_icon_state_get(module);
+
+       if (module->view_update != NULL) {
+               EINA_LIST_FOREACH_SAFE(module->view_list, l, l_next, view) {
+                       module->view_update(view, status, flag_extra_1, flag_extra_2);
+               }
+       }
+}
+
+HAPI void quickpanel_setting_module_icon_view_update_text(QP_Module_Setting *module)
+{
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *view = NULL;
+       retif(module == NULL, , "invalid parameter");
+
+       if (module->view_update != NULL && module->label_get != NULL) {
+               EINA_LIST_FOREACH_SAFE(module->view_list, l, l_next, view) {
+                       quickpanel_setting_icon_text_set(view, module->label_get(), quickpanel_setting_module_icon_state_get(module));
+               }
+       }
+}
+
+HAPI void quickpanel_setting_module_icon_status_update(QP_Module_Setting *module, int flag_extra_1, int flag_extra_2)
+{
+       retif(module == NULL, , "invalid parameter");
+
+       if (module->status_update != NULL) {
+               module->status_update(module, flag_extra_1, flag_extra_2);
+       }
+}
+
+HAPI int quickpanel_setting_module_is_icon_clickable(QP_Module_Setting *module)
+{
+       retif(module == NULL, 0, "invalid parameter");
+       retif(module->loader == NULL, 0, "invalid parameter");
+
+       if (module->loader->timer != NULL) {
+               return 0;
+       }
+       if (module->loader->state_icon == STATE_ICON_BUSY) {
+               return 0;
+       }
+
+       return 1;
+}
+
+static Eina_Bool _timer_expire_cb(void *data)
+{
+       retif(data == NULL, ECORE_CALLBACK_CANCEL, "invalid parameter");
+
+       quickpanel_setting_module_icon_timer_del(data);
+       quickpanel_setting_module_icon_status_update(data, FLAG_VALUE_VOID, FLAG_VALUE_VOID);
+
+       return ECORE_CALLBACK_CANCEL;
+}
+
+HAPI void quickpanel_setting_module_icon_timer_add(QP_Module_Setting *module)
+{
+       retif(module == NULL, , "invalid parameter");
+       retif(module->loader == NULL, , "invalid parameter");
+
+       quickpanel_setting_module_icon_timer_del(module);
+       module->loader->timer = ecore_timer_add(TIMER_COUNT, _timer_expire_cb, module);
+}
+
+HAPI void quickpanel_setting_module_icon_timer_del(QP_Module_Setting *module)
+{
+       retif(module == NULL, , "invalid parameter");
+       retif(module->loader == NULL, , "invalid parameter");
+
+       if (module->loader->timer != NULL) {
+               ecore_timer_del(module->loader->timer);
+               module->loader->timer = NULL;
+       }
+}
+
+#ifdef __PROGRESSBAR_ENABLED__
+static Evas_Object *_progressbar_get(Evas_Object *parent)
+{
+       Evas_Object *content = NULL;
+
+       content = elm_progressbar_add(parent);
+       elm_progressbar_unit_format_set(content, "%0.0f%%");
+       retif(!content, NULL, "fail to elm_progressbar_add");
+
+       elm_object_style_set(content, "quickpanel_style");
+       evas_object_size_hint_weight_set(content,
+                       EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       elm_progressbar_pulse(content, EINA_TRUE);
+       evas_object_show(content);
+
+       return content;
+}
+
+static void _progressbar_set(Evas_Object *view, int is_enable, int is_request_on)
+{
+       Evas_Object *content = NULL;
+       Evas_Object *content_old = NULL;
+       retif(view == NULL, , "invalid parameter");
+
+       if (is_enable == FLAG_ENABLE) {
+               content_old = quickpanel_setting_icon_content_get(view);
+               if (content_old != NULL) {
+                       evas_object_del(content_old);
+                       content_old = NULL;
+               }
+               content = _progressbar_get(view);
+               quickpanel_setting_icon_content_set(view, content);
+
+               quickpanel_setting_icon_state_progress_set(view);
+               quickpanel_setting_icon_state_set(view, ICON_VIEW_STATE_DIM);
+       }
+}
+#endif
+
+HAPI void quickpanel_setting_module_progress_mode_set(QP_Module_Setting *module, int is_enable, int is_request_on)
+{
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *view = NULL;
+       retif(module == NULL, , "invalid parameter");
+       retif(module->loader == NULL, , "invalid parameter");
+
+       EINA_LIST_FOREACH_SAFE(module->view_list, l, l_next, view) {
+#ifdef __PROGRESSBAR_ENABLED__
+               _progressbar_set(view, is_enable, is_request_on);
+#else
+               if (is_enable) {
+                       quickpanel_setting_icon_state_progress_set(view);
+               }
+#endif
+       }
+
+       if (is_enable == FLAG_ENABLE) {
+               module->loader->state_icon = STATE_ICON_BUSY;
+       } else {
+               module->loader->state_icon = STATE_ICON_IDLE;
+       }
+}
+
+HAPI void quickpanel_setting_module_icon_destroy(QP_Module_Setting *module, Evas_Object *icon)
+{
+       retif(module == NULL, , "invalid parameter");
+       retif(icon == NULL, , "invalid parameter");
+
+       _icon_view_del(module, icon);
+       quickpanel_setting_icon_click_cb_del(icon, module->handler_press);
+       evas_object_del(icon);
+       icon = NULL;
+}
diff --git a/daemon/settings/setting_module_api.h b/daemon/settings/setting_module_api.h
new file mode 100755 (executable)
index 0000000..d634d89
--- /dev/null
@@ -0,0 +1,53 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __SETTING_MODULE_API_H__
+#define __SETTING_MODULE_API_H__
+
+#define FLAG_VALUE_VOID 0xDEADDEAD
+
+#define FLAG_ENABLE 1
+#define FLAG_DISABLE 0
+
+#define FLAG_TURN_ON 1
+#define FLAG_TURN_OFF 0
+
+typedef enum _qp_setting_icon_container_type {
+       QP_SETTING_ICON_CONTAINER_NONE = -1,
+       QP_SETTING_ICON_CONTAINER_FEATURED = 0,
+       QP_SETTING_ICON_CONTAINER_ALL_LIST,
+} qp_setting_icon_container_type;
+
+extern Evas_Object *quickpanel_setting_module_icon_create(QP_Module_Setting *module, Evas_Object *parent);
+extern void quickpanel_setting_module_icon_add(QP_Module_Setting *module, Evas_Object *icon, qp_setting_icon_container_type container_type);
+extern void quickpanel_setting_module_icon_remove(QP_Module_Setting *module, Evas_Object *icon);
+extern void quickpanel_setting_module_icon_state_set(QP_Module_Setting *module, int state);
+extern int quickpanel_setting_module_icon_state_get(QP_Module_Setting *module);
+extern Evas_Object *quickpanel_setting_module_icon_get(QP_Module_Setting *module, qp_setting_icon_container_type container_type);
+extern void quickpanel_setting_module_icon_view_update(QP_Module_Setting *module, int flag_extra_1, int flag_extra_2);
+extern void quickpanel_setting_module_icon_view_update_text(QP_Module_Setting *module);
+extern void quickpanel_setting_module_icon_status_update(QP_Module_Setting *module, int flag_extra_1, int flag_extra_2);
+extern int quickpanel_setting_module_is_icon_clickable(QP_Module_Setting *module);
+extern void quickpanel_setting_module_icon_timer_add(QP_Module_Setting *module);
+extern void quickpanel_setting_module_icon_timer_del(QP_Module_Setting *module);
+extern void quickpanel_setting_module_progress_mode_set(QP_Module_Setting *module, int is_enable, int is_request_on);
+extern void quickpanel_setting_module_icon_destroy(QP_Module_Setting *module, Evas_Object *icon);
+
+extern QP_Module_Setting *quickpanel_setting_module_get_from_icon(Evas_Object *icon);
+
+#endif /* __SETTING_MODULE_API_H__ */
diff --git a/daemon/settings/setting_utils.c b/daemon/settings/setting_utils.c
new file mode 100755 (executable)
index 0000000..0f18fe8
--- /dev/null
@@ -0,0 +1,627 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+#include <glib.h>
+
+#include <notification.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "settings.h"
+#include "common.h"
+#include "quickpanel_def.h"
+#include "quickpanel-ui.h"
+#include "setting_utils.h"
+#ifdef QP_SCREENREADER_ENABLE
+#include "accessibility.h"
+#endif
+
+#define DEFAULT_EDJ            EDJDIR"/"PACKAGE".edj"
+#define _EDJ(o) elm_layout_edje_get(o)
+
+#define TEXT_LEN 128
+#define QP_SETTING_INITIAL_PAGE_NUM 0
+#define DIVIDER_MAGIC 0xCAFECAFE
+#define E_DATA_DIVIDER_MAGIC "divider_magic"
+
+static inline void __escaped_text_set(Evas_Object *obj, const char *part, const char *text)
+{
+       char buf[256] = {0,};
+       char *ecaped = NULL;
+
+       if (!obj) {
+               return;
+       }
+
+       if (!part) {
+               return;
+       }
+
+       strncpy(buf, text, sizeof(buf) - 1);
+       quickpanel_common_util_char_trim(buf);
+       ecaped = evas_textblock_text_utf8_to_markup(NULL, buf);
+
+       elm_object_part_text_set(obj, part, ecaped);
+
+       if (ecaped) {
+               free(ecaped);
+       }
+}
+
+HAPI int quickpanel_setting_icon_text_set(Evas_Object *icon, const char *text, int state)
+{
+       retif(icon == NULL, QP_FAIL, "invalid parameter");
+       retif(text == NULL, QP_FAIL, "invalid parameter");
+
+       __escaped_text_set(icon, "icon.text", text);
+
+#ifdef QP_SCREENREADER_ENABLE
+       char buf[256] = {0,};
+       Evas_Object *ao = NULL;
+
+       ao = quickpanel_accessibility_screen_reader_object_get(icon,
+                       SCREEN_READER_OBJ_TYPE_ELM_OBJECT, "focus", icon);
+       if (ao != NULL) {
+               elm_access_info_set(ao, ELM_ACCESS_TYPE, _NOT_LOCALIZED("Button"));
+               strncpy(buf, text, sizeof(buf) - 1);
+               quickpanel_common_util_char_replace(buf, '\n', ' ');
+               elm_access_info_set(ao, ELM_ACCESS_INFO, buf);
+       }
+
+       ao = quickpanel_accessibility_screen_reader_object_get(icon,
+                       SCREEN_READER_OBJ_TYPE_ELM_OBJECT, "focus", icon);
+       if (ao != NULL) {
+               if (state == ICON_VIEW_STATE_ON) {
+                       elm_access_info_set(ao, ELM_ACCESS_STATE, _NOT_LOCALIZED("On"));
+               } else if (state == ICON_VIEW_STATE_DIM) {
+                       elm_access_info_set(ao, ELM_ACCESS_STATE, _NOT_LOCALIZED("Turned off"));
+               } else if (state == ICON_VIEW_STATE_OFF) {
+                       elm_access_info_set(ao, ELM_ACCESS_STATE, _NOT_LOCALIZED("Off"));
+               }
+       }
+#endif
+
+       return QP_OK;
+}
+
+HAPI void quickpanel_setting_icon_access_text_set(Evas_Object *icon, const char *text)
+{
+#ifdef QP_SCREENREADER_ENABLE
+       char buf[256] = {0,};
+       Evas_Object *ao = NULL;
+#endif
+
+       retif(icon == NULL, , "invalid parameter");
+       retif(text == NULL, , "invalid parameter");
+
+#ifdef QP_SCREENREADER_ENABLE
+       ao = quickpanel_accessibility_screen_reader_object_get(icon,
+                       SCREEN_READER_OBJ_TYPE_ELM_OBJECT, "focus", icon);
+       if (ao != NULL) {
+               elm_access_info_set(ao, ELM_ACCESS_TYPE, _NOT_LOCALIZED("Button"));
+               strncpy(buf, text, sizeof(buf) - 1);
+               quickpanel_common_util_char_replace(buf, '\n', ' ');
+               elm_access_info_set(ao, ELM_ACCESS_INFO, buf);
+       }
+#endif
+}
+
+HAPI Evas_Object *quickpanel_setting_icon_content_get(Evas_Object *icon)
+{
+       retif(icon == NULL, NULL, "invalid parameter");
+
+       struct appdata *ad = (struct appdata*)quickpanel_get_app_data();
+       retif(ad == NULL, NULL, "application data is NULL");
+
+       return elm_object_part_content_get(icon, "icon.swallow.wvga");
+}
+
+HAPI int quickpanel_setting_icon_content_set(Evas_Object *icon, Evas_Object *content)
+{
+       retif(icon == NULL, QP_FAIL, "invalid parameter");
+       retif(content == NULL, QP_FAIL, "invalid parameter");
+
+       struct appdata *ad = (struct appdata*)quickpanel_get_app_data();
+       retif(ad == NULL, QP_FAIL, "application data is NULL");
+
+       elm_object_part_content_set(icon, "icon.swallow.wvga", content);
+
+       return QP_OK;
+}
+
+HAPI int quickpanel_setting_icon_state_set(Evas_Object *icon, int state)
+{
+#ifdef QP_SCREENREADER_ENABLE
+       Evas_Object *ao = NULL;
+#endif
+       retif(icon == NULL, -1, "invalid parameter");
+       SERR("icon:%p state:%d", icon, state);
+
+#ifdef QP_SCREENREADER_ENABLE
+       ao = quickpanel_accessibility_screen_reader_object_get(icon,
+                       SCREEN_READER_OBJ_TYPE_ELM_OBJECT, "focus", icon);
+       if (ao != NULL) {
+               if (state == ICON_VIEW_STATE_ON) {
+                       elm_access_info_set(ao, ELM_ACCESS_STATE, _NOT_LOCALIZED("On"));
+               } else if (state == ICON_VIEW_STATE_DIM) {
+                       elm_access_info_set(ao, ELM_ACCESS_STATE, _NOT_LOCALIZED("Turned off"));
+               } else if (state == ICON_VIEW_STATE_OFF) {
+                       elm_access_info_set(ao, ELM_ACCESS_STATE, _NOT_LOCALIZED("Off"));
+               }
+       }
+#endif
+
+       if (state == ICON_VIEW_STATE_ON) {
+               elm_object_signal_emit(icon, "icon.on", "quickpanl.prog");
+       } else if (state == ICON_VIEW_STATE_DIM) {
+               elm_object_signal_emit(icon, "icon.dim", "quickpanl.prog");
+       } else {
+               elm_object_signal_emit(icon, "icon.off", "quickpanl.prog");
+       }
+
+       edje_object_message_signal_process(_EDJ(icon));
+
+       return 0;
+}
+
+HAPI int quickpanel_setting_icon_state_progress_set(Evas_Object *icon)
+{
+       retif(icon == NULL, -1, "invalid parameter");
+
+       elm_object_signal_emit(icon, "icon.progress", "quickpanl.prog");
+       edje_object_message_signal_process(_EDJ(icon));
+
+       return 0;
+}
+
+HAPI Evas_Object *quickpanel_setting_icon_new(Evas_Object *parent)
+{
+       const char *signal = NULL;
+       Evas_Object *icon = NULL;
+       retif(parent == NULL, NULL, "invalid parameter");
+
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, EINA_FALSE, "invalid data.");
+
+       icon = elm_layout_add(parent);
+       retif(!icon, NULL, "fail to add layout");
+
+       elm_layout_file_set(icon, DEFAULT_EDJ, "quickpanel/setting_icon_wvga");
+
+       evas_object_size_hint_weight_set(icon,
+                       EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       elm_object_signal_emit(icon, "icon.off", "quickpanl.prog");
+
+       Evas_Object *focus = quickpanel_accessibility_ui_get_focus_object(icon);
+       elm_object_part_content_set(icon, "focus", focus);
+
+       if (ad->angle == 0 || ad->angle == 180) {
+               signal = "icon.portrait";
+       } else {
+               signal = "icon.landscape";
+       }
+
+       elm_object_signal_emit(icon, signal, "quickpanl.prog");
+       edje_object_message_signal_process(_EDJ(icon));
+
+       return icon;
+}
+
+HAPI Evas_Object *quickpanel_setting_icon_image_new(Evas_Object *parent, const char *img_path)
+{
+       Evas_Object *content = NULL;
+       retif(parent == NULL, NULL, "invalid parameter");
+       retif(img_path == NULL, NULL, "invalid parameter");
+
+       content = elm_image_add(parent);
+       retif(content == NULL, NULL, "failed to create image");
+
+       if (!elm_image_file_set(content, DEFAULT_EDJ, img_path)) {
+               ERR("fail to set file[%s]", img_path);
+               evas_object_del(content);
+               content = NULL;
+               return NULL;
+       }
+
+       return content;
+}
+
+static Evas_Object *quickpanel_setting_container_get(Evas_Object *base)
+{
+       Evas_Object *container = NULL;
+       retif(base == NULL, NULL, "invalid parameter");
+
+       container = elm_object_part_content_get(base, QP_SETTING_BASE_PART);
+
+       return container;
+}
+
+HAPI Evas_Object *quickpanel_setting_scroller_get(Evas_Object *base)
+{
+       Evas_Object *container = NULL;
+       Evas_Object *scroller = NULL;
+       retif(base == NULL, NULL, "invalid parameter");
+
+       struct appdata *ad = (struct appdata*)quickpanel_get_app_data();
+       retif(ad == NULL, NULL, "application data is NULL");
+
+       container = quickpanel_setting_container_get(base);
+
+       scroller = elm_object_part_content_get(container, QP_SETTING_SCROLLER_PART_WVGA);
+
+       retif(scroller == NULL, NULL, "invalid parameter");
+
+       return scroller;
+}
+
+HAPI Evas_Object *quickpanel_setting_box_get_from_scroller(Evas_Object *base)
+{
+       Evas_Object *scroller = NULL;
+       Evas_Object *box = NULL;
+       retif(base == NULL, NULL, "invalid parameter");
+
+       scroller = quickpanel_setting_scroller_get(base);
+       retif(scroller == NULL, NULL, "invalid parameter");
+
+       box = elm_object_content_get(scroller);
+
+       return box;
+}
+
+HAPI Evas_Object *quickpanel_setting_box_get(Evas_Object *base)
+{
+       Evas_Object *container = NULL;
+       Evas_Object *box = NULL;
+       retif(base == NULL, NULL, "invalid parameter");
+
+       container = quickpanel_setting_container_get(base);
+       retif(container == NULL, NULL, "invalid parameter");
+       box = elm_object_part_content_get(container, QP_SETTING_SCROLLER_PART_WVGA);
+
+       return box;
+}
+
+HAPI int quickpanel_setting_container_rotation_set(Evas_Object *base, int angle)
+{
+       Evas_Object *container = NULL;
+       const char *signal = NULL;
+
+       retif(!base, -1, "base is NULL");
+       retif(angle < 0, -1, "angle is %d", angle);
+
+       container = quickpanel_setting_container_get(base);
+       retif(!container, -1, "box is NULL");
+
+       if (angle % 180 == 0) {
+               signal = "portrait";
+       } else {
+               signal = "landscape";
+       }
+
+       elm_object_signal_emit(container, signal, "background");
+       edje_object_message_signal_process(_EDJ(container));
+
+       return 0;
+}
+
+HAPI int quickpanel_setting_icons_rotation_set(Evas_Object *base, int angle)
+{
+       Evas_Object *box = NULL;
+       Evas_Object *icon = NULL;
+       Eina_List *icons = NULL;
+       Eina_List *l = NULL;
+       const char *signal = NULL;
+
+       retif(!base, -1, "base is NULL");
+       retif(angle < 0, -1, "angle is %d", angle);
+
+       box = quickpanel_setting_box_get(base);
+       retif(!box, -1, "box is NULL");
+
+       icons = elm_box_children_get(box);
+       retif(!icons, -1, "icons list is NULL");
+
+       if (angle % 180 == 0) {
+               signal = "icon.portrait";
+       } else {
+               signal = "icon.landscape";
+       }
+
+       EINA_LIST_FOREACH(icons, l, icon) {
+               elm_object_signal_emit(icon, signal, "quickpanl.prog");
+               edje_object_message_signal_process(_EDJ(icon));
+       }
+
+       eina_list_free(icons);
+
+       return 0;
+}
+
+HAPI void quickpanel_setting_icons_emit_sig(Evas_Object *icon, const char *signal)
+{
+       retif(!icon, , "icon is NULL");
+       retif(!signal, , "icon is NULL");
+
+       elm_object_signal_emit(icon, signal, "quickpanl.prog");
+       edje_object_message_signal_process(_EDJ(icon));
+}
+
+HAPI int quickpanel_setting_icons_dragging_set(Evas_Object *icon, int is_on)
+{
+       const char *signal = NULL;
+       retif(!icon, QP_FAIL, "icon is NULL");
+
+       if (is_on == 1) {
+               signal = "dragging.on";
+       } else {
+               signal = "dragging.off";
+       }
+
+       elm_object_signal_emit(icon, signal, "quickpanl.prog");
+       edje_object_message_signal_process(_EDJ(icon));
+
+       return QP_OK;
+}
+
+HAPI int quickpanel_setting_icons_screen_mode_set(Evas_Object *icon, int screen_mode)
+{
+       const char *signal = NULL;
+       retif(!icon, QP_FAIL, "icon is NULL");
+
+       if (screen_mode == 0) {
+               signal = "icon.portrait";
+       } else {
+               signal = "icon.landscape";
+       }
+
+       elm_object_signal_emit(icon, signal, "quickpanl.prog");
+       edje_object_message_signal_process(_EDJ(icon));
+
+       return QP_OK;
+}
+
+HAPI int quickpanel_setting_icon_pack(Evas_Object *box, Evas_Object *icon, int is_attach_divider)
+{
+       retif(box == NULL, QP_FAIL, "box is NULL");
+
+       elm_box_pack_end(box, icon);
+
+       return QP_OK;
+}
+
+HAPI void quickpanel_setting_icon_unpack_all(Evas_Object *box)
+{
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *node = NULL;
+       Eina_List *list = NULL;
+       retif(box == NULL, , "invalid parameter");
+
+       list = elm_box_children_get(box);
+       retif(list == NULL, , "empty list");
+
+       elm_box_unpack_all(box);
+
+       EINA_LIST_FOREACH_SAFE(list, l, l_next, node) {
+               if (node != NULL) {
+                       if (evas_object_data_get(node, E_DATA_DIVIDER_MAGIC) == (void *)DIVIDER_MAGIC) {
+                               evas_object_del(node);
+                               node = NULL;
+                       }
+               }
+       }
+
+       eina_list_free(list);
+}
+
+HAPI int quickpanel_setting_scroll_page_get(void *data)
+{
+       int page_h = 0x99;
+       struct appdata *ad = NULL;
+       retif(data == NULL, QP_FAIL, "Invalid parameter!");
+
+       ad = data;
+       retif(!ad->ly, QP_FAIL, "layout is NULL!");
+
+       Evas_Object *scroller = quickpanel_setting_scroller_get(ad->ly);
+       elm_scroller_current_page_get(scroller, &page_h, NULL);
+
+       return page_h;
+}
+
+HAPI int quickpanel_setting_set_scroll_page_width(void *data)
+{
+       struct appdata *ad = NULL;
+       retif(data == NULL, QP_FAIL, "Invalid parameter!");
+
+       ad = data;
+       retif(!ad->ly, QP_FAIL, "layout is NULL!");
+
+       Evas_Object *scroller = quickpanel_setting_scroller_get(ad->ly);
+
+       int w, h;
+       elm_win_screen_size_get(ad->win, NULL, NULL, &w, &h);
+       elm_scroller_page_size_set(scroller, w / QP_SETTING_NUM_PORTRAIT_ICONS, 0);
+
+       return 0;
+}
+
+HAPI int quickpanel_setting_start(Evas_Object *base)
+{
+       Evas_Object *scroller = NULL;
+       retif(base == NULL, QP_FAIL, "Invalid parameter!");
+
+       scroller = quickpanel_setting_scroller_get(base);
+       retif(scroller == NULL, QP_FAIL, "Invalid parameter!");
+
+       elm_scroller_page_bring_in(scroller, 0, 0);
+
+       return QP_OK;
+}
+
+HAPI int quickpanel_setting_stop(Evas_Object *base, int is_bring_in)
+{
+       int page = QP_SETTING_INITIAL_PAGE_NUM;
+       Evas_Object *scroller = NULL;
+       retif(base == NULL, QP_FAIL, "Invalid parameter!");
+
+       scroller = quickpanel_setting_scroller_get(base);
+       retif(scroller == NULL, QP_FAIL, "Invalid parameter!");
+
+       if (is_bring_in == 1) {
+               elm_scroller_page_bring_in(scroller, page, 0);
+       } else {
+               elm_scroller_page_show(scroller, page, 0);
+       }
+
+       return QP_OK;
+}
+
+HAPI int quickpanel_setting_layout_set(Evas_Object *base, Evas_Object *setting)
+{
+       retif(base == NULL, QP_FAIL, "Invalid parameter!");
+       retif(setting == NULL, QP_FAIL, "Invalid parameter!");
+
+       elm_object_part_content_set(base, QP_SETTING_BASE_PART, setting);
+
+       return 0;
+}
+
+HAPI Evas_Object *quickpanel_setting_layout_get(Evas_Object *base, const char *setting_part)
+{
+       retif(base == NULL, NULL, "Invalid parameter!");
+       retif(setting_part == NULL, NULL, "Invalid parameter!");
+
+       return elm_object_part_content_get(base, setting_part);
+}
+
+HAPI int quickpanel_setting_layout_remove(Evas_Object *base)
+{
+       Evas_Object *container = NULL;
+       Evas_Object *scroller = NULL;
+       Evas_Object *box = NULL;
+       retif(base == NULL, QP_FAIL, "Invalid parameter!");
+
+       container = quickpanel_setting_container_get(base);
+       scroller = quickpanel_setting_scroller_get(base);
+       box = quickpanel_setting_box_get(base);
+
+       if (box) {
+               elm_box_clear(box);
+               evas_object_del(box);
+               box = NULL;
+       }
+       if (scroller) {
+               evas_object_del(scroller);
+               scroller = NULL;
+       }
+       if (container) {
+               evas_object_del(container);
+               container = NULL;
+       }
+
+       return QP_OK;
+}
+
+HAPI void quickpanel_setting_create_confirm_popup(
+               Evas_Object *parent,
+               char *title,
+               char *text,
+               Evas_Smart_Cb func)
+{
+       Evas_Object *popup = elm_popup_add(parent);
+       Evas_Object *btn = NULL;
+
+       if (popup == NULL) {
+               return;
+       }
+
+       evas_object_size_hint_weight_set(popup, EVAS_HINT_EXPAND,
+                       EVAS_HINT_EXPAND);
+
+       if (title) {
+               elm_object_part_text_set(popup, "title,text", title);
+       }
+
+       if (text) {
+               elm_object_text_set(popup, text);
+       }
+
+       btn = elm_button_add(popup);
+       elm_object_style_set(btn, "popup");
+       elm_object_text_set(btn, _("IDS_ST_SK_OK"));
+       elm_object_part_content_set(popup, "button1", btn);
+       evas_object_smart_callback_add(btn, "clicked", func, popup);
+
+       evas_object_show(popup);
+       quickpanel_common_ui_set_current_popup(popup, func);
+}
+
+HAPI void quickpanel_setting_create_2button_confirm_popup(
+               Evas_Object *parent,
+               char *title,
+               char *text,
+               char *btn1_text,
+               Evas_Smart_Cb btn1_func,
+               char *btn2_text,
+               Evas_Smart_Cb btn2_func)
+{
+       Evas_Object *popup = elm_popup_add(parent);
+       Evas_Object *btn = NULL;
+
+       if (popup == NULL) {
+               return;
+       }
+
+       evas_object_size_hint_weight_set(popup, EVAS_HINT_EXPAND,
+                       EVAS_HINT_EXPAND);
+
+       if (title) {
+               elm_object_part_text_set(popup, "title,text", title);
+       }
+
+       if (text) {
+               elm_object_text_set(popup, text);
+       }
+
+       if (btn1_func != NULL && btn1_text != NULL) {
+               btn = elm_button_add(popup);
+               elm_object_style_set(btn, "popup");
+               elm_object_text_set(btn, btn1_text);
+               elm_object_part_content_set(popup, "button1", btn);
+               evas_object_smart_callback_add(btn, "clicked", btn1_func, popup);
+       }
+       if (btn2_func != NULL && btn2_text != NULL) {
+               btn = elm_button_add(popup);
+               elm_object_style_set(btn, "popup");
+               elm_object_text_set(btn, btn2_text);
+               elm_object_part_content_set(popup, "button2", btn);
+               evas_object_smart_callback_add(btn, "clicked", btn2_func, popup);
+       }
+
+       evas_object_show(popup);
+       quickpanel_common_ui_set_current_popup(popup, btn1_func);
+}
+
+HAPI void quickpanel_setting_create_timeout_popup(Evas_Object *parent, char *msg)
+{
+       retif(msg == NULL, , "invalid parameter");
+
+       notification_status_message_post(msg);
+}
diff --git a/daemon/settings/setting_utils.h b/daemon/settings/setting_utils.h
new file mode 100755 (executable)
index 0000000..601d549
--- /dev/null
@@ -0,0 +1,70 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __SETTING_UTILS_H__
+#define __SETTING_UTILS_H__
+
+
+#define TIMER_CONTINUE 1
+#define TIMER_STOP     0
+#define TIMER_COUNT    10
+
+#define QP_SETTING_BASE_PART "qp.base.setting.swallow"
+#define QP_SETTING_SCROLLER_PART_HD "setting.container.swallow.hd"
+#define QP_SETTING_SCROLLER_PART_WVGA "setting.container.swallow.wvga"
+#define QP_SETTING_CONTAINER_ICON_PART "setting.icon.swallow"
+#define QP_SETTING_BRIGHTNESS_PART_HD "brightness.container.swallow.hd"
+#define QP_SETTING_BRIGHTNESS_PART_WVGA "brightness.container.swallow.wvga"
+
+extern int quickpanel_setting_start(Evas_Object *base);
+extern int quickpanel_setting_stop(Evas_Object *base, int is_bring_in);
+
+extern Evas_Object *quickpanel_setting_scroller_get(Evas_Object *base);
+extern int quickpanel_setting_set_scroll_page_width(void *data);
+extern int quickpanel_setting_layout_set(Evas_Object *base, Evas_Object *setting);
+extern Evas_Object *quickpanel_setting_layout_get(Evas_Object *base, const char *setting_part);
+
+extern int quickpanel_setting_layout_remove(Evas_Object *base);
+extern int quickpanel_setting_icon_text_set(Evas_Object *icon, const char *text, int state);
+extern void quickpanel_setting_icon_access_text_set(Evas_Object *icon, const char *text);
+extern int quickpanel_setting_icon_content_set(Evas_Object *icon, Evas_Object *content);
+
+extern Evas_Object *quickpanel_setting_box_get(Evas_Object *base);
+extern Evas_Object *quickpanel_setting_icon_new(Evas_Object *parent);
+extern Evas_Object *quickpanel_setting_icon_image_new(Evas_Object *parent, const char *img_path);
+extern int quickpanel_setting_icon_pack(Evas_Object *box, Evas_Object *icon, int is_attach_divider);
+extern void quickpanel_setting_icon_unpack_all(Evas_Object *box);
+extern int quickpanel_setting_container_rotation_set(Evas_Object *base, int angle);
+extern int quickpanel_setting_icons_rotation_set(Evas_Object *base, int angle);
+extern int quickpanel_setting_icons_dragging_set(Evas_Object *icon, int is_on);
+extern int quickpanel_setting_icons_screen_mode_set(Evas_Object *icon, int screen_mode);
+extern void quickpanel_setting_icons_emit_sig(Evas_Object *icon, const char *signal);
+extern Evas_Object *quickpanel_setting_icon_content_get(Evas_Object *icon);
+extern int quickpanel_setting_icon_content_set(Evas_Object *icon, Evas_Object *content);
+
+extern int quickpanel_setting_icon_state_set(Evas_Object *icon, int is_on);
+extern int quickpanel_setting_icon_state_progress_set(Evas_Object *icon);
+
+// Do not use full window popup in quickpanel
+extern void quickpanel_setting_create_confirm_popup(Evas_Object *parent, char *title, char *text, Evas_Smart_Cb func);
+extern void quickpanel_setting_create_2button_confirm_popup(Evas_Object *parent, char *title, char *text, char *btn1_text, Evas_Smart_Cb btn1_func, char *btn2_text, Evas_Smart_Cb btn2_func);
+extern void quickpanel_setting_create_timeout_popup(Evas_Object *parent, char *msg);
+
+extern int quickpanel_setting_scroll_page_get(void *data);
+
+#endif /* __SETTING_UTILS_H__ */
diff --git a/daemon/settings/settings.c b/daemon/settings/settings.c
new file mode 100755 (executable)
index 0000000..e688dfb
--- /dev/null
@@ -0,0 +1,461 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#include <stdlib.h>
+#include <glib.h>
+#include <Elementary.h>
+
+#include <vconf.h>
+#include <notification.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "common.h"
+#include "quickpanel-ui.h"
+#include "quickpanel_def.h"
+#include "modules.h"
+#include "settings.h"
+#include "setting_utils.h"
+#include "settings_ipc.h"
+#include "pager.h"
+#include "pager_common.h"
+#include "preference.h"
+
+#ifdef QP_SCREENREADER_ENABLE
+#include "accessibility.h"
+#endif
+
+#ifdef QP_EMERGENCY_MODE_ENABLE
+#include "emergency_mode.h"
+#endif
+
+static int quickpanel_settings_init(void *data);
+static int quickpanel_settings_fini(void *data);
+static int quickpanel_settings_suspend(void *data);
+static int quickpanel_settings_resume(void *data);
+static void quickpanel_settings_lang_changed(void *data);
+static void quickpanel_settings_reflesh(void *data);
+static Eina_Bool _module_is_enabled(QP_Module_Setting *module);
+
+extern QP_Module_Setting wifi;
+extern QP_Module_Setting gps;
+extern QP_Module_Setting bluetooth;
+extern QP_Module_Setting sound;
+extern QP_Module_Setting rotate;
+
+QP_Module settings = {
+       .name = "settings",
+       .init = quickpanel_settings_init,
+       .fini = quickpanel_settings_fini,
+       .suspend = quickpanel_settings_suspend,
+       .resume = quickpanel_settings_resume,
+       .lang_changed = quickpanel_settings_lang_changed,
+       .refresh = quickpanel_settings_reflesh,
+};
+
+static struct _info {
+       GHashTable *module_table;
+       QP_Module_Setting *modules[];
+} s_info = {
+       .module_table = NULL,
+       .modules = {
+               &wifi,
+               &gps,
+               &sound,
+               &rotate,
+               &bluetooth,
+               NULL,
+       },
+};
+
+static void _module_init(QP_Module_Setting *module)
+{
+       if (module->init != NULL) {
+               module->loader = (QP_Setting_Loaded_Item *)calloc(1, sizeof(QP_Setting_Loaded_Item));
+               module->init(module);
+               module->is_loaded = EINA_TRUE;
+       }
+}
+
+static void _module_fini(QP_Module_Setting *module)
+{
+       if (module->fini != NULL) {
+               module->fini(module);
+               if (module->loader != NULL) {
+                       free(module->loader);
+                       module->loader = NULL;
+                       module->is_loaded = EINA_FALSE;
+               }
+       }
+}
+
+static int _module_count_get(void)
+{
+       int i, cnt = 0;
+
+       for (i = 0; s_info.modules[i] != NULL; i++) {
+               cnt++;
+       }
+
+       return cnt;
+}
+
+static QP_Module_Setting *_module_get_by_name(const char *name)
+{
+       retif(name == NULL, NULL, "invalid parameter");
+       retif(s_info.module_table == NULL, NULL, "invalid parameter");
+
+       return g_hash_table_lookup(s_info.module_table, name);
+}
+
+static Eina_Bool _module_is_enabled(QP_Module_Setting *module) {
+       retif(module == NULL, EINA_FALSE, "invalid parameter");
+       retif(module->name == NULL, EINA_FALSE, "invalid parameter");
+
+       if (strcmp(module->name, MODULE_BLANK) == 0) {
+               return EINA_FALSE;
+       }
+       if (module->supported_get) {
+               if (module->supported_get() == 0)
+                       return EINA_FALSE;
+       }
+       return EINA_TRUE;
+}
+
+static char *_preference_get(const char *key)
+{
+       char line[PREF_LEN_VALUE_MAX + 1] = {0,};
+
+       if (quickpanel_preference_get(key, line) == QP_OK) {
+               DBG("quicksetting order from file:%s", line);
+               return strdup(line);
+       }
+
+       return NULL;
+}
+
+static int quickpanel_settings_init(void *data)
+{
+       int i;
+       int mod_count = 0;
+       struct appdata *ad = data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+       mod_count = _module_count_get();
+       if (s_info.module_table != NULL) {
+               g_hash_table_remove_all(s_info.module_table);
+               g_hash_table_destroy(s_info.module_table);
+               s_info.module_table = NULL;
+       }
+       s_info.module_table = g_hash_table_new_full(g_str_hash, g_str_equal,
+                       (GDestroyNotify)g_free,
+                       NULL);
+       if (s_info.module_table != NULL) {
+               for (i = 0; i < mod_count; i++) {
+                       if (s_info.modules[i]->supported_get != NULL) {
+                               if (s_info.modules[i]->supported_get() == 0) {
+                                       continue;
+                               }
+                       }
+
+                       if (s_info.modules[i]->init != NULL && s_info.modules[i]->name != NULL) {
+                               ERR("quickbutton %s is initialized", s_info.modules[i]->name);
+                               DBG("quickbutton %s is initialized", s_info.modules[i]->name);
+                               g_hash_table_insert(s_info.module_table,
+                                               g_strdup(s_info.modules[i]->name),
+                                               s_info.modules[i]);
+                               _module_init(s_info.modules[i]);
+                       }
+               }
+       } else {
+               ERR("failed to create module has table");
+               return QP_FAIL;
+       }
+
+       quickpanel_settings_ipc_init(ad);
+
+       return QP_OK;
+}
+
+static int quickpanel_settings_fini(void *data)
+{
+       int i;
+       int ret = 0;
+       struct appdata *ad = data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+       quickpanel_settings_ipc_fini(ad);
+
+       for (i = 0; s_info.modules[i] != NULL; i++) {
+               if (_module_is_enabled(s_info.modules[i]) == EINA_TRUE) {
+                       _module_fini(s_info.modules[i]);
+               }
+       }
+
+       if (s_info.module_table) {
+               g_hash_table_remove_all(s_info.module_table);
+               g_hash_table_destroy(s_info.module_table);
+               s_info.module_table = NULL;
+       }
+
+       return ret;
+}
+
+static int quickpanel_settings_suspend(void *data)
+{
+       int i;
+       int ret = 0;
+       struct appdata *ad = data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+       for (i = 0; s_info.modules[i] != NULL; i++) {
+               if (_module_is_enabled(s_info.modules[i]) == EINA_TRUE) {
+                       if ((s_info.modules[i])->suspend != NULL) {
+                               (s_info.modules[i])->suspend(s_info.modules[i]);
+                       }
+               }
+       }
+
+       return ret;
+}
+
+static int quickpanel_settings_resume(void *data)
+{
+       int i;
+       int ret = 0;
+       struct appdata *ad = data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+       for (i = 0; s_info.modules[i] != NULL; i++) {
+               if (_module_is_enabled(s_info.modules[i]) == EINA_TRUE) {
+                       if ((s_info.modules[i])->resume != NULL) {
+                               (s_info.modules[i])->resume(s_info.modules[i]);
+                       }
+               }
+       }
+
+       return ret;
+}
+
+static void quickpanel_settings_lang_changed(void *data)
+{
+       int i;
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       for (i = 0; s_info.modules[i] != NULL; i++) {
+               if (_module_is_enabled(s_info.modules[i]) == EINA_TRUE) {
+                       if ((s_info.modules[i])->lang_changed != NULL) {
+                               (s_info.modules[i])->lang_changed(s_info.modules[i]);
+                       }
+               }
+       }
+}
+
+static void quickpanel_settings_reflesh(void *data)
+{
+       int i;
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       for (i = 0; s_info.modules[i] != NULL; i++) {
+               if (_module_is_enabled(s_info.modules[i]) == EINA_TRUE) {
+                       if ((s_info.modules[i])->refresh != NULL) {
+                               (s_info.modules[i])->refresh(s_info.modules[i]);
+                       }
+               }
+       }
+}
+
+HAPI int quickpanel_settings_featured_list_validation_check(char *order)
+{
+       int i = 0, is_valid = 0;
+       int order_count = 0;
+       gchar **order_split = NULL;
+       QP_Module_Setting *mod = NULL;
+       retif(order == NULL, is_valid, "Invalid parameter!");
+
+       if (s_info.module_table == NULL) {
+               return is_valid;
+       }
+
+       order_split = g_strsplit(order, ",", 0);
+
+       if (order_split != NULL) {
+               order_count = g_strv_length(order_split);
+
+               if (order_count >= QP_SETTING_NUM_MINIMUM_ICON) {
+                       for (i = 0; i < order_count; i++) {
+                               mod = _module_get_by_name(order_split[i]);
+                               if (mod != NULL) {
+                                       is_valid = 1;
+                               } else {
+                                       is_valid = 0;
+                                       break;
+                               }
+                       }
+               }
+
+               g_strfreev(order_split);
+       }
+
+       return is_valid;
+}
+
+HAPI void quickpanel_settings_featured_list_get(Eina_List **list)
+{
+       int i = 0, seq_count = 0;
+       int num_featured = 0;
+       int seq_added_count = 0;
+       gchar **params = NULL;
+       QP_Module_Setting *module = NULL;
+       retif(list == NULL, , "invalid data.");
+       char *sequence = _preference_get(PREF_QUICKSETTING_ORDER);
+       const char *default_sequence = quickpanel_preference_default_get(PREF_QUICKSETTING_ORDER);
+
+       char *num_featured_str =  _preference_get(PREF_QUICKSETTING_FEATURED_NUM);
+       const char *default_num_featured_str = quickpanel_preference_default_get(PREF_QUICKSETTING_FEATURED_NUM);
+
+       if (sequence != NULL) {
+               params = g_strsplit(sequence, ",", 0);
+               free(sequence);
+       } else {
+               params = g_strsplit(default_sequence, ",", 0);
+       }
+
+       if (num_featured_str != NULL) {
+               num_featured = atoi(num_featured_str);
+               free(num_featured_str);
+       } else {
+               if (default_num_featured_str != NULL) {
+                       num_featured = atoi(default_num_featured_str);
+               } else {
+                       num_featured = QP_SETTING_NUM_TOTAL_ICON;
+               }
+       }
+
+       if (params != NULL) {
+               seq_count = g_strv_length(params);
+
+               for (i = 0; i < seq_count; i++) {
+                       if (seq_added_count >= num_featured){
+                               break;
+                       }
+
+                       module = _module_get_by_name(params[i]);
+                       if (module != NULL) {
+                               if (_module_is_enabled(module) == EINA_TRUE) {
+                                       *list = eina_list_append (*list, module);
+                                       seq_added_count++;
+                               }
+                       }
+               }
+
+               g_strfreev(params);
+       }
+}
+
+HAPI void quickpanel_settings_all_list_get(Eina_List **list)
+{
+       int i = 0, seq_count = 0;
+       gchar **params = NULL;
+       QP_Module_Setting *module = NULL;
+       retif(list == NULL, , "invalid data.");
+       char *sequence = _preference_get(PREF_QUICKSETTING_ORDER);
+       const char *default_sequence = quickpanel_preference_default_get(PREF_QUICKSETTING_ORDER);
+
+       if (sequence != NULL) {
+               params = g_strsplit(sequence, ",", 0);
+               free(sequence);
+       } else if (default_sequence != NULL){
+               params = g_strsplit(default_sequence, ",", 0);
+       }
+
+       if (params != NULL) {
+               seq_count = g_strv_length(params);
+
+               for (i = 0; i < seq_count; i++) {
+                       module = _module_get_by_name(params[i]);
+                       if (module != NULL) {
+                               if (_module_is_enabled(module) == EINA_TRUE) {
+                                       *list = eina_list_append (*list, module);
+                               }
+                       }
+               }
+
+               g_strfreev(params);
+       }
+}
+
+HAPI void quickpanel_setting_save_list_to_file(Eina_List *list, int num_featured)
+{
+       Eina_List *l;
+       Eina_List *l_next;
+       QP_Module_Setting *module = NULL;
+       char buf[32] = {0,};
+       retif(list == NULL, , "invalid parameter");
+
+       int is_first = 1;
+
+       char *base = NULL;
+       char *temp = NULL;
+
+       EINA_LIST_FOREACH_SAFE(list, l, l_next, module) {
+               if (module == NULL){
+                       continue;
+               }
+               if (module->name == NULL) {
+                       continue;
+               }
+               if (_module_is_enabled(module) == EINA_FALSE) {
+                       continue;
+               }
+
+               if (is_first == 1) {
+                       base = g_strdup(module->name);
+                       is_first = 0;
+               } else {
+                       temp = g_strconcat(base, ",", module->name, NULL);
+                       if (base != NULL) g_free(base);
+                       base = temp;
+                       temp = NULL;
+               }
+       }
+
+       if (base != NULL) {
+               if (quickpanel_preference_set(PREF_QUICKSETTING_ORDER, base) == QP_FAIL) {
+                       ERR("failed to write quicksetting order");
+               }
+               g_free(base);
+               snprintf(buf, sizeof(buf) - 1, "%d", num_featured);
+               if (quickpanel_preference_set(PREF_QUICKSETTING_FEATURED_NUM, buf) == QP_FAIL) {
+                       ERR("failed to write quicksetting featured num");
+               }
+       }
+}
+
+HAPI QP_Module_Setting *quickpanel_settings_module_get_by_name(const char *name)
+{
+       return _module_get_by_name(name);
+}
+
+HAPI int quickpanel_settings_module_count_get(void)
+{
+       return _module_count_get();
+}
diff --git a/daemon/settings/settings.h b/daemon/settings/settings.h
new file mode 100755 (executable)
index 0000000..98b0dbd
--- /dev/null
@@ -0,0 +1,108 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#ifndef __SETTING_H__
+#define __SETTING_H__
+
+#define MODULE_BLANK "blank"
+#define FILE_QP_BUTTON_ORDER_INI DATADIR_RW"/qp_setting_order.ini"
+#define E_DATA_MODULE_INFO "module_info"
+
+#define ICON_VIEW_STATE_OFF 0
+#define ICON_VIEW_STATE_ON 1
+#define ICON_VIEW_STATE_DIM 2
+
+#define STATE_ICON_NOT_LOADED 0
+#define STATE_ICON_IDLE 1
+#define STATE_ICON_BUSY 2
+
+#define QS_DBUS_SIG_ACTIVITY "ACTIVITY"
+#define QS_DBUS_SIG_EDITING "EDITING"
+
+typedef enum _qp_setting_icon_state_type {
+       QP_SETTING_ICON_STATE_NOT_LOADED,
+       QP_SETTING_ICON_STATE_IDLE,
+       QP_SETTING_ICON_STATE_BUSY,
+} qp_setting_icon_state_type;
+
+typedef enum _qp_setting_icon_image_type {
+       QP_SETTING_ICON_NORMAL,
+       QP_SETTING_ICON_HIGHLIGHT,
+       QP_SETTING_ICON_DIM,
+} qp_setting_icon_image_type;
+
+typedef  struct _Setting_Activity_Handler {
+       char *command;
+       void (*handler)(void *data);
+} Setting_Activity_Handler;
+
+typedef struct _QP_Module_Setting QP_Module_Setting;
+typedef struct _QP_Setting_Loaded_Item QP_Setting_Loaded_Item;
+
+struct _QP_Module_Setting {
+       char *name;
+       int is_disable_feedback;
+
+       /* func */
+       int (*init) (void *);
+       int (*fini) (void *);
+       int (*suspend) (void *);
+       int (*resume) (void *);
+       int (*hib_enter) (void *);
+       int (*hib_leave) (void *);
+       void (*lang_changed) (void *);
+       void (*refresh) (void *);
+       void (*qp_opened) (void *);
+       void (*qp_closed) (void *);
+
+       const char *(*label_get) (void);
+       const char *(*icon_get) (qp_setting_icon_image_type type);
+       int (*supported_get) (void);
+       void (*view_update)(Evas_Object *, int, int, int);
+       void (*status_update)(QP_Module_Setting *, int, int);
+
+       int (*handler_ipc)(const char *, void *);
+       Edje_Signal_Cb handler_press;
+       void (*handler_longpress) (void *);
+
+       /* do not modify this area */
+       /* internal data */
+       Eina_Bool is_loaded;
+       QP_Setting_Loaded_Item *loader;
+       Eina_List *view_list;
+};
+
+struct _QP_Setting_Loaded_Item {
+       QP_Module_Setting *module;
+       void *app_data;
+       int state_icon;
+
+       Evas_Object *view;
+       Ecore_Timer *timer;
+       int state;
+       void *extra_handler_1;
+};
+
+extern void quickpanel_setting_save_list_to_file(Eina_List *list, int num_featured);
+extern int quickpanel_settings_featured_list_validation_check(char *order);
+extern void quickpanel_settings_featured_list_get(Eina_List **list);
+extern void quickpanel_settings_all_list_get(Eina_List **list);
+
+extern QP_Module_Setting *quickpanel_settings_module_get_by_name(const char *name);
+extern int quickpanel_settings_module_count_get(void);
+
+#endif
diff --git a/daemon/settings/settings_gridbox.c b/daemon/settings/settings_gridbox.c
new file mode 100755 (executable)
index 0000000..fde946c
--- /dev/null
@@ -0,0 +1,495 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "quickpanel-ui.h"
+#include "common.h"
+#include "list_util.h"
+#include "quickpanel_def.h"
+#include "settings_gridbox.h"
+#include "pager.h"
+
+#define E_DATA_LAYOUT_PORTRAIT "layout_portrait"
+#define E_DATA_LAYOUT_LANDSCAPE "layout_landscape"
+#define E_DATA_ITEM_TYPE "item_type"
+#define E_DATA_POS_INFO "pos_info"
+#define DIVIDER_TOUCH_W 20
+
+typedef struct _info_layout {
+       int n_per_rows;
+       int padding_top;
+       int padding_left;
+       int padding_right;
+       int padding_bottom;
+       int padding_between_h;
+       int padding_between_v;
+       int child_w;
+       int child_h;
+       double scale;
+       int limit_w;
+} info_layout;
+
+typedef struct _info_position {
+       int index;
+       int offset_x;
+       int offset_y;
+       int width;
+       int height;
+} info_position;
+
+static Eina_List *_position_info_add(Eina_List *list, int is_icon, int index, int offset_x, int offset_y, int width, int height)
+{
+       info_position *pos_info = (info_position *) calloc(1, sizeof(info_position));
+       retif(pos_info == NULL, NULL, "failed to allocate memory");
+
+       pos_info->index = index;
+
+       if (is_icon == 1) {
+               if (offset_x <= 0) {
+                       pos_info->offset_x = offset_x;
+                       pos_info->width = width - DIVIDER_TOUCH_W;
+               } else {
+                       pos_info->offset_x = offset_x + DIVIDER_TOUCH_W;
+                       pos_info->width = width - DIVIDER_TOUCH_W - DIVIDER_TOUCH_W;
+               }
+       } else {
+               if (offset_x <= 0) {
+                       pos_info->offset_x = offset_x;
+                       pos_info->width = width - DIVIDER_TOUCH_W;
+               } else {
+                       pos_info->offset_x = offset_x - DIVIDER_TOUCH_W;
+                       pos_info->width = width + DIVIDER_TOUCH_W + DIVIDER_TOUCH_W;
+               }
+       }
+
+       pos_info->offset_y = offset_y;
+       pos_info->height = height;
+
+       return eina_list_append(list, pos_info);
+}
+
+static void _position_info_clear(Eina_List *list)
+{
+       info_position *pos_info = NULL;
+
+       EINA_LIST_FREE(list, pos_info) {
+               if (pos_info != NULL) {
+                       free(pos_info);
+                       pos_info = NULL;
+               }
+       }
+}
+
+static Eina_List *_position_info_get(Evas_Object *gridbox)
+{
+       return evas_object_data_get(gridbox, E_DATA_POS_INFO);
+}
+
+static void _position_info_set(Evas_Object *gridbox, Eina_List *list)
+{
+       evas_object_data_set(gridbox, E_DATA_POS_INFO, list);
+}
+
+static info_layout *_get_layout(Evas_Object *gridbox)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+       info_layout *info_layout = NULL;
+
+       retif(ad == NULL, NULL, "invalid data.");
+       retif(gridbox == NULL, NULL, "invalid parameter");
+
+       if (ad->angle == 270 || ad->angle == 90) {
+               info_layout = evas_object_data_get(gridbox, E_DATA_LAYOUT_LANDSCAPE);
+       } else {
+               info_layout = evas_object_data_get(gridbox, E_DATA_LAYOUT_PORTRAIT);
+       }
+
+       return info_layout;
+}
+
+static int _item_is_icon(Evas_Object *icon)
+{
+       const char *item_type = NULL;
+       retif(icon == NULL, 1, "invalid parameter");
+
+       item_type = evas_object_data_get(icon, E_DATA_ITEM_TYPE);
+       retif(item_type == NULL, 1, "invalid parameter");
+
+       if (strcmp(item_type, SETTINGS_GRIDBOX_ITEM_ICON) == 0) {
+               return 1;
+       }
+
+       return 0;
+}
+
+static void _item_pos_get(int order, int *x, int *y, void *data)
+{
+       info_layout *info_layout = data;
+       retif(info_layout == NULL, , "invalid parameter");
+
+       int n_per_row = info_layout->n_per_rows;
+
+       int row = (order - 1) / n_per_row;
+       int column = (order - 1) - (row * n_per_row);
+
+       int row_x = info_layout->padding_left
+               + ((info_layout->child_w + info_layout->padding_between_h) * column);
+
+       int row_y = info_layout->padding_top
+               + ((info_layout->child_h + info_layout->padding_between_v) * row);
+
+       if (x != NULL) {
+               *x = row_x;
+       }
+
+       if (y != NULL) {
+               *y = row_y;
+       }
+}
+
+static inline void _item_move_and_resize(Evas_Object *item, int x, int y, int w, int h)
+{
+       evas_object_move(item, x, y);
+       evas_object_size_hint_min_set(item, w, h);
+       evas_object_resize(item, w, h);
+}
+
+static void _layout_cb(Evas_Object *o, Evas_Object_Box_Data *priv, void *data)
+{
+       int n_children;
+       int x, y;
+       int off_x = 0, off_y = 0;
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object_Box_Option *opt;
+       int child_w;
+       int space_w = 0;
+       int num_padding_between = 0;
+
+       retif(o == NULL, , "invalid parameter");
+       retif(priv == NULL, , "invalid parameter");
+       retif(data == NULL, , "invalid parameter");
+
+       info_layout *info_layout = _get_layout(data);
+       Eina_List *list_pos_info = _position_info_get(data);
+
+       n_children = eina_list_count(priv->children);
+       DBG("layout function:%d", n_children);
+       if (!n_children) {
+               evas_object_size_hint_min_set(o, ELM_SCALE_SIZE(-1), ELM_SCALE_SIZE(0));
+               return;
+       }
+
+       //box geometry
+       evas_object_geometry_get(o, &x, &y, NULL, NULL);
+
+       num_padding_between = info_layout->n_per_rows >> 1;
+       num_padding_between += (info_layout->n_per_rows > 1 && (info_layout->n_per_rows % 2) > 0) ? 1 : 0;
+
+       space_w = (info_layout->padding_left * 2) + (info_layout->padding_between_h * num_padding_between);
+       child_w = (info_layout->limit_w - space_w) / info_layout->n_per_rows;
+
+       info_layout->child_w = child_w;
+
+       if (list_pos_info != NULL) {
+               _position_info_clear(list_pos_info);
+               _position_info_set(data, NULL);
+               list_pos_info = NULL;
+       }
+
+       int order_obj = 0;
+       int order_children = 1;
+       int order_divider = 1;
+       Evas_Object *btn_previous = NULL;
+
+       EINA_LIST_FOREACH_SAFE(priv->children, l, l_next, opt) {
+               if (_item_is_icon(opt->obj)) {
+                       _item_pos_get(order_children, &off_x, &off_y, info_layout);
+                       _item_move_and_resize(opt->obj, x + off_x, y + off_y,
+                                       info_layout->child_w, info_layout->child_h);
+                       order_children++;
+                       list_pos_info =
+                               _position_info_add(list_pos_info, 1, order_obj, off_x, off_y, info_layout->child_w, info_layout->child_h);
+                       if (btn_previous != NULL && opt->obj != NULL) {
+                               elm_object_focus_next_object_set(opt->obj, btn_previous, ELM_FOCUS_LEFT);
+                               elm_object_focus_next_object_set(btn_previous, opt->obj, ELM_FOCUS_RIGHT);
+                       }
+                       btn_previous = opt->obj;
+               } else {
+                       _item_pos_get(order_children - 1, &off_x, &off_y, info_layout);
+                       _item_move_and_resize(opt->obj, x + off_x + info_layout->child_w, y + off_y,
+                                       info_layout->padding_between_h, info_layout->child_h);
+                       if ((order_divider % info_layout->n_per_rows) == 0) {
+                               evas_object_hide(opt->obj);
+                       } else {
+                               evas_object_show(opt->obj);
+                       }
+                       order_divider++;
+                       list_pos_info =
+                               _position_info_add(list_pos_info, 0, order_obj, off_x + info_layout->child_w, off_y,
+                                               info_layout->padding_between_h, info_layout->child_h);
+               }
+               order_obj++;
+       }
+
+       _position_info_set(data, list_pos_info);
+}
+
+static void _deleted_cb(void *data, Evas *e, Evas_Object *obj, void *event_info)
+{
+       DBG("deleted_cb");
+       Eina_List *list = NULL;
+       Evas_Object *gridbox = obj;
+       retif(gridbox == NULL, , "invalid parameter");
+
+       info_layout *info_layout_portrait = evas_object_data_get(gridbox,
+                       E_DATA_LAYOUT_PORTRAIT);
+       info_layout *info_layout_landscape = evas_object_data_get(gridbox,
+                       E_DATA_LAYOUT_LANDSCAPE);
+
+       list = _position_info_get(gridbox);
+       _position_info_clear(list);
+       _position_info_set(gridbox, NULL);
+
+       quickpanel_settings_gridbox_item_remove_all(gridbox);
+       evas_object_data_del(gridbox, E_DATA_LAYOUT_PORTRAIT);
+       evas_object_data_del(gridbox, E_DATA_LAYOUT_LANDSCAPE);
+
+       if (info_layout_portrait != NULL) {
+               free(info_layout_portrait);
+       }
+       if (info_layout_landscape != NULL) {
+               free(info_layout_landscape);
+       }
+}
+
+HAPI Evas_Object *quickpanel_settings_gridbox_create(Evas_Object *parent, void *data)
+{
+       retif(parent == NULL, NULL, "invalid parameter");
+       retif(data == NULL, NULL, "invalid parameter");
+       struct appdata *ad = data;
+       Evas_Object *gridbox = NULL;
+
+       info_layout *info_layout_portrait = NULL;
+       info_layout *info_layout_landscape = NULL;
+
+       info_layout_portrait = (info_layout *) calloc(1,
+                       sizeof(info_layout));
+       retif(info_layout_portrait == NULL, NULL, "memory allocation failed");
+       info_layout_portrait->padding_between_h = 2 * ad->scale;
+       info_layout_portrait->padding_between_v = 1 * ad->scale;
+       info_layout_portrait->padding_top = 0;
+       info_layout_portrait->padding_left = 1;
+       info_layout_portrait->padding_bottom = 0;
+       info_layout_portrait->n_per_rows = 8;
+       info_layout_portrait->child_w = 0;
+
+       info_layout_portrait->child_h = QP_SETTING_ICON_MIN_WH_WVGA * ad->scale;
+
+       info_layout_portrait->limit_w = ad->win_width;
+       info_layout_portrait->scale = ad->scale;
+
+       info_layout_landscape = (info_layout *) calloc(1, sizeof(info_layout));
+       if (info_layout_landscape == NULL) {
+               free(info_layout_portrait);
+               ERR("memory allocation failed");
+               return NULL;
+       }
+       info_layout_landscape->padding_between_h = 2 * ad->scale;
+       info_layout_landscape->padding_between_v = 1 * ad->scale;
+       info_layout_landscape->padding_top = 0;
+       info_layout_landscape->padding_left = 1;
+       info_layout_landscape->padding_bottom = 0;
+       info_layout_landscape->n_per_rows = 10;
+       info_layout_landscape->child_w = 0;
+
+       info_layout_landscape->child_h = QP_SETTING_ICON_MIN_WH_WVGA * ad->scale;
+
+       info_layout_landscape->limit_w = ad->win_height;
+       info_layout_landscape->scale = ad->scale;
+
+       gridbox = elm_box_add(parent);
+       evas_object_size_hint_weight_set(gridbox, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       evas_object_size_hint_fill_set(gridbox, EVAS_HINT_FILL, EVAS_HINT_FILL);
+       elm_box_horizontal_set(gridbox, EINA_TRUE);
+
+       elm_box_layout_set(gridbox, _layout_cb, gridbox, NULL);
+
+       evas_object_data_set(gridbox, E_DATA_LAYOUT_PORTRAIT, info_layout_portrait);
+       evas_object_data_set(gridbox, E_DATA_LAYOUT_LANDSCAPE, info_layout_landscape);
+       evas_object_event_callback_add(gridbox, EVAS_CALLBACK_DEL, _deleted_cb, NULL);
+
+       evas_object_show(gridbox);
+
+       return gridbox;
+}
+
+HAPI void quickpanel_settings_gridbox_remove(Evas_Object *gridbox)
+{
+       retif(gridbox == NULL, , "invalid parameter");
+
+       quickpanel_settings_gridbox_item_remove_all(gridbox);
+       evas_object_del(gridbox);
+       gridbox = NULL;
+}
+
+HAPI void quickpanel_settings_gridbox_item_add(Evas_Object *gridbox, Evas_Object *item, const char *item_type, int is_prepend)
+{
+       evas_object_data_set(item, E_DATA_ITEM_TYPE, item_type);
+
+       if (is_prepend == SETTINGS_GRIDBOX_PREPEND) {
+               elm_box_pack_start(gridbox, item);
+       } else {
+               elm_box_pack_end(gridbox, item);
+       }
+}
+
+HAPI void quickpanel_settings_gridbox_item_remove(Evas_Object *gridbox, Evas_Object *item)
+{
+       retif(gridbox == NULL, , "invalid parameter");
+       retif(item == NULL, , "invalid parameter");
+
+       elm_box_unpack(gridbox, item);
+       evas_object_del(item);
+       item = NULL;
+}
+
+HAPI void quickpanel_settings_gridbox_item_remove_all(Evas_Object *gridbox)
+{
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *obj = NULL;
+       Eina_List *item_list = NULL;
+
+       retif(gridbox == NULL, , "invalid parameter");
+
+       item_list = elm_box_children_get(gridbox);
+       retif(item_list == NULL, , "invalid parameter");
+
+       EINA_LIST_FOREACH_SAFE(item_list, l, l_next, obj) {
+               if (obj != NULL) {
+                       quickpanel_settings_gridbox_item_remove(gridbox, obj);
+               }
+       }
+
+       eina_list_free(item_list);
+}
+
+HAPI void quickpanel_settings_gridbox_rotation(Evas_Object *gridbox, int angle)
+{
+       const char *signal = NULL;
+
+       retif(gridbox == NULL, , "invalid parameter");
+
+       info_layout *info_layout_portrait = evas_object_data_get(gridbox,
+                       E_DATA_LAYOUT_PORTRAIT);
+       info_layout *info_layout_landscape = evas_object_data_get(gridbox,
+                       E_DATA_LAYOUT_LANDSCAPE);
+
+       retif(info_layout_portrait == NULL || info_layout_landscape == NULL, ,
+                       "gridbox is crashed");
+
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *obj;
+       Eina_List *item_list = elm_box_children_get(gridbox);
+       retif(item_list == NULL, , "invalid parameter");
+
+       if (angle == 270 || angle == 90) {
+               signal = "icon.landscape";
+       } else {
+               signal = "icon.portrait";
+       }
+
+       EINA_LIST_FOREACH_SAFE(item_list, l, l_next, obj) {
+               if (obj != NULL) {
+                       elm_object_signal_emit(obj, signal, "quickpanl.prog");
+                       edje_object_message_signal_process(_EDJ(obj));
+               }
+       }
+}
+
+HAPI int quickpanel_settings_gridbox_item_count_get(Evas_Object *gridbox)
+{
+       int item_count = 0;
+       Eina_List *items = NULL;
+       retif(gridbox == NULL, 0, "invalid parameter");
+
+       if ((items = elm_box_children_get(gridbox)) != NULL) {
+               item_count = eina_list_count(items);
+               eina_list_free(items);
+               return item_count;
+       } else {
+               return 0;
+       }
+}
+
+HAPI int quickpanel_settings_gridbox_item_index_get(Evas_Object *gridbox, int touch_x, int touch_y)
+{
+       Eina_List *l;
+       Eina_List *l_next;
+       Eina_List *list_pos_info = NULL;
+       info_position *pos_info = NULL;
+       int x = 0, y = 0, w = 0, h = 0;
+
+       evas_object_geometry_get(gridbox, &x, &y, &w, &h);
+       list_pos_info = _position_info_get(gridbox);
+
+       if (touch_x >= x && touch_x <= x + w && touch_y >= y && touch_y <= y + h) {
+               touch_x = touch_x - x;
+               touch_y = touch_y - y;
+               EINA_LIST_FOREACH_SAFE(list_pos_info, l, l_next, pos_info) {
+                       if (pos_info != NULL) {
+                               if (touch_x >= pos_info->offset_x && touch_x <= pos_info->offset_x + pos_info->width
+                                               && touch_y >= pos_info->offset_y && touch_y <= pos_info->offset_y + pos_info->height) {
+                                       return pos_info->index;
+                               }
+                       }
+               }
+       }
+       return -1;
+}
+
+HAPI void quickpanel_settings_gridbox_unpack_all(Evas_Object *gridbox)
+{
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *node = NULL;
+       Eina_List *list = NULL;
+       retif(gridbox == NULL, , "invalid parameter");
+
+       list = elm_box_children_get(gridbox);
+       retif(list == NULL, , "empty list");
+
+       elm_box_unpack_all(gridbox);
+
+       EINA_LIST_FOREACH_SAFE(list, l, l_next, node) {
+               if (node != NULL) {
+                       if (_item_is_icon(node) == 0) {
+                               evas_object_del(node);
+                               node = NULL;
+                       }
+               }
+       }
+
+       eina_list_free(list);
+}
diff --git a/daemon/settings/settings_gridbox.h b/daemon/settings/settings_gridbox.h
new file mode 100755 (executable)
index 0000000..eaad6a8
--- /dev/null
@@ -0,0 +1,37 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __QUICKPANEL_SETTINGS_GRIDBOX_H__
+#define __QUICKPANEL_SETTINGS_GRIDBOX_H__
+
+#define SETTINGS_GRIDBOX_PREPEND 1
+#define SETTINGS_GRIDBOX_APPEND 0
+#define SETTINGS_GRIDBOX_ITEM_ICON "item_icon"
+#define SETTINGS_GRIDBOX_ITEM_DIVIDER "item_divider"
+
+extern Evas_Object *quickpanel_settings_gridbox_create(Evas_Object *parent, void *data);
+extern void quickpanel_settings_gridbox_remove(Evas_Object *gridbox);
+extern void quickpanel_settings_gridbox_item_add(Evas_Object *gridbox, Evas_Object *item, const char *item_type, int is_prepend);
+extern void quickpanel_settings_gridbox_item_remove(Evas_Object *gridbox, Evas_Object *item);
+extern void quickpanel_settings_gridbox_item_remove_all(Evas_Object *gridbox);
+extern void quickpanel_settings_gridbox_rotation(Evas_Object *gridbox, int angle);
+extern int quickpanel_settings_gridbox_item_count_get(Evas_Object *gridbox);
+extern int quickpanel_settings_gridbox_item_index_get(Evas_Object *gridbox, int touch_x, int touch_y);
+extern void quickpanel_settings_gridbox_unpack_all(Evas_Object *gridbox);
+
+#endif
diff --git a/daemon/settings/settings_icon_common.c b/daemon/settings/settings_icon_common.c
new file mode 100755 (executable)
index 0000000..ede02ab
--- /dev/null
@@ -0,0 +1,239 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <sound_manager.h>
+#include <E_DBus.h>
+
+#include "media.h"
+#include "quickpanel-ui.h"
+#include "quickpanel_def.h"
+#include "common_uic.h"
+#include "common.h"
+#include "modules.h"
+#include "settings.h"
+#include "setting_utils.h"
+#include "setting_module_api.h"
+#include "accessibility.h"
+#include "pager.h"
+#include "pager_common.h"
+
+#define E_DATA_ICON_CLICKED_CB "clicked_cb"
+#define E_DATA_ICON_ORIGINAL_OBJ "original_obj"
+
+#define TAP_AND_DELAY_LONG 1.000
+
+static struct _info {
+       int down_x;
+       Eina_Bool is_longpressed;
+       Ecore_Timer *timer_longpress;
+} s_info = {
+       .down_x = 0,
+       .is_longpressed = EINA_FALSE,
+       .timer_longpress = NULL,
+};
+
+static Eina_Bool _icon_handler_longpress(void *data)
+{
+       DBG("");
+       Evas_Object *obj = data;
+       QP_Module_Setting *module = NULL;
+       retif(obj == NULL, ECORE_CALLBACK_CANCEL, "invalid argument");
+
+       struct appdata *ad = (struct appdata*)quickpanel_get_app_data();
+       retif(ad == NULL, ECORE_CALLBACK_CANCEL, "application data is NULL");
+
+       quickpanel_media_play_feedback();
+
+       ecore_timer_del(s_info.timer_longpress);
+       s_info.timer_longpress = NULL;
+       s_info.is_longpressed = EINA_TRUE;
+
+       module = evas_object_data_get(obj, E_DATA_MODULE_INFO);
+       if (module != NULL) {
+               if (module->handler_longpress != NULL) {
+                       if (module->name) {
+                               DBG("launch setting menu of %s", module->name);
+                       }
+                       module->handler_longpress(obj);
+
+                       elm_object_signal_emit(obj, "mouse,up,1", "background.super");
+               }
+       }
+
+       return ECORE_CALLBACK_CANCEL;
+}
+
+static void _icon_mouse_up_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
+{
+       retif(obj == NULL, , "invalid argument");
+
+       if (s_info.timer_longpress != NULL) {
+               ecore_timer_del(s_info.timer_longpress);
+               s_info.timer_longpress = NULL;
+               s_info.is_longpressed = EINA_FALSE;
+       }
+}
+
+static void _icon_mouse_down_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
+{
+       retif(obj == NULL, , "invalid argument");
+
+       if (s_info.timer_longpress != NULL) {
+               ecore_timer_del(s_info.timer_longpress);
+               s_info.timer_longpress = NULL;
+       }
+
+       quickpanel_page_get_touched_pos(&(s_info.down_x), NULL);
+
+       s_info.is_longpressed = EINA_FALSE;
+       s_info.timer_longpress = ecore_timer_add(TAP_AND_DELAY_LONG,_icon_handler_longpress, obj);
+}
+
+#ifdef QP_SCREENREADER_ENABLE
+static void _icon_focus_clicked_cb(void *data, Evas_Object *obj, void *event_info)
+{
+       Evas_Object *icon = NULL;
+       Edje_Signal_Cb func = NULL;
+       retif(obj == NULL, , "invalid argument");
+
+       struct appdata *ad = (struct appdata*)quickpanel_get_app_data();
+       retif(ad == NULL, , "application data is NULL");
+
+       if (s_info.timer_longpress != NULL) {
+               ecore_timer_del(s_info.timer_longpress);
+               s_info.timer_longpress = NULL;
+       }
+
+       if (s_info.is_longpressed != EINA_TRUE) {
+               quickpanel_media_play_feedback();
+       }
+
+       icon = evas_object_data_get(obj, E_DATA_ICON_ORIGINAL_OBJ);
+       if (icon != NULL) {
+               func = evas_object_data_get(icon, E_DATA_ICON_CLICKED_CB);
+
+               if (func != NULL && s_info.is_longpressed != EINA_TRUE) {
+                       func(data, icon,  "mouse,clicked,1", "background.super");
+               }
+       }
+}
+
+static void _icon_focus_clicked_cb_without_feedback(void *data, Evas_Object *obj, void *event_info)
+{
+       Evas_Object *icon = NULL;
+       Edje_Signal_Cb func = NULL;
+       retif(obj == NULL, , "invalid argument");
+
+       struct appdata *ad = (struct appdata*)quickpanel_get_app_data();
+       retif(ad == NULL, , "application data is NULL");
+
+       if (s_info.timer_longpress != NULL) {
+               ecore_timer_del(s_info.timer_longpress);
+               s_info.timer_longpress = NULL;
+       }
+
+       icon = evas_object_data_get(obj, E_DATA_ICON_ORIGINAL_OBJ);
+       if (icon != NULL) {
+               func = evas_object_data_get(icon, E_DATA_ICON_CLICKED_CB);
+
+               if (func != NULL && s_info.is_longpressed != EINA_TRUE) {
+                       func(data, icon,  "mouse,clicked,1", "background.super");
+               }
+       }
+}
+
+HAPI int quickpanel_setting_icon_click_cb_add(Evas_Object *icon, Edje_Signal_Cb func, void *data)
+{
+       retif(icon == NULL, QP_FAIL, "invalid parameter");
+       retif(func == NULL, QP_FAIL, "invalid parameter");
+
+       struct appdata *ad = (struct appdata*)quickpanel_get_app_data();
+       retif(ad == NULL, QP_FAIL, "application data is NULL");
+
+       elm_object_signal_callback_add(icon, "mouse,up,1", "background.super", _icon_mouse_up_cb, data);
+       elm_object_signal_callback_add(icon, "mouse,down,1", "background.super", _icon_mouse_down_cb, data);
+
+       evas_object_data_set(icon, E_DATA_ICON_CLICKED_CB, func);
+
+#ifdef QP_SCREENREADER_ENABLE
+       Evas_Object *ao = NULL;
+       ao = quickpanel_accessibility_screen_reader_object_get(icon,
+                       SCREEN_READER_OBJ_TYPE_ELM_OBJECT, "focus", icon);
+       if (ao != NULL) {
+               evas_object_smart_callback_add(ao, "clicked",
+                               _icon_focus_clicked_cb, data);
+               evas_object_data_set(ao, E_DATA_ICON_ORIGINAL_OBJ, icon);
+       }
+#endif
+
+       return 0;
+}
+
+HAPI int quickpanel_setting_icon_click_cb_without_feedback_add(Evas_Object *icon, Edje_Signal_Cb func, void *data)
+{
+       retif(icon == NULL, QP_FAIL, "invalid parameter");
+       retif(func == NULL, QP_FAIL, "invalid parameter");
+
+       struct appdata *ad = (struct appdata*)quickpanel_get_app_data();
+       retif(ad == NULL, QP_FAIL, "application data is NULL");
+
+       elm_object_signal_callback_add(icon, "mouse,up,1", "background.super", _icon_mouse_up_cb, data);
+       elm_object_signal_callback_add(icon, "mouse,down,1", "background.super", _icon_mouse_down_cb, data);
+
+       evas_object_data_set(icon, E_DATA_ICON_CLICKED_CB, func);
+
+#ifdef QP_SCREENREADER_ENABLE
+       Evas_Object *ao = NULL;
+       ao = quickpanel_accessibility_screen_reader_object_get(icon,
+                       SCREEN_READER_OBJ_TYPE_ELM_OBJECT, "focus", icon);
+       if (ao != NULL) {
+               evas_object_smart_callback_add(ao, "clicked",
+                               _icon_focus_clicked_cb_without_feedback, data);
+               evas_object_data_set(ao, E_DATA_ICON_ORIGINAL_OBJ, icon);
+       }
+#endif
+
+       return 0;
+}
+
+HAPI int quickpanel_setting_icon_click_cb_del(Evas_Object *icon, Edje_Signal_Cb func)
+{
+       retif(icon == NULL, QP_FAIL, "invalid parameter");
+       retif(func == NULL, QP_FAIL, "invalid parameter");
+
+       struct appdata *ad = (struct appdata*)quickpanel_get_app_data();
+       retif(ad == NULL, QP_FAIL, "application data is NULL");
+
+       elm_object_signal_callback_del(icon, "mouse,clicked,1", "background.super", func);
+
+       return QP_OK;
+}
+
+HAPI void quickpanel_setting_icon_handler_longpress(const char *pkgname, void *data)
+{
+       int ret;
+
+       ret = quickpanel_uic_launch_ug_by_appcontrol(pkgname, data);
+       quickpanel_uic_launch_app_inform_result(pkgname, ret);
+       quickpanel_uic_close_quickpanel(true, 1);
+}
+#endif
+
diff --git a/daemon/settings/settings_icon_common.h b/daemon/settings/settings_icon_common.h
new file mode 100755 (executable)
index 0000000..7b16e93
--- /dev/null
@@ -0,0 +1,27 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __SETTING_ICON_COMMON_H__
+#define __SETTING_ICON_COMMON_H__
+
+extern int quickpanel_setting_icon_click_cb_add(Evas_Object *icon, Edje_Signal_Cb func, void *data);
+extern int quickpanel_setting_icon_click_cb_without_feedback_add(Evas_Object *icon, Edje_Signal_Cb func, void *data);
+extern int quickpanel_setting_icon_click_cb_del(Evas_Object *icon, Edje_Signal_Cb func);
+extern void quickpanel_setting_icon_handler_longpress(const char *pkgname, void *data);
+
+#endif /* __SETTING_ICON_COMMON_H__ */
diff --git a/daemon/settings/settings_ipc.c b/daemon/settings/settings_ipc.c
new file mode 100755 (executable)
index 0000000..552f120
--- /dev/null
@@ -0,0 +1,207 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+#include <E_DBus.h>
+#include <glib.h>
+
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "quickpanel-ui.h"
+#include "quickpanel_def.h"
+#include "common.h"
+#include "modules.h"
+#include "settings.h"
+#include "setting_utils.h"
+#include "settings_view_all.h"
+#include "settings_view_featured.h"
+
+static struct _info {
+       E_DBus_Signal_Handler *hdl_activity;
+       E_DBus_Signal_Handler *hdl_editing;
+} s_info = {
+       .hdl_activity = NULL,
+       .hdl_editing = NULL,
+};
+
+static void _handler_activity(void *data, DBusMessage *msg)
+{
+       int ret = 0;
+       DBusError err;
+       char *module = NULL;
+       char *command = NULL;
+       QP_Module_Setting *mod = NULL;
+       retif(data == NULL || msg == NULL, , "Invalid parameter!");
+
+       dbus_error_init(&err);
+       ret = dbus_message_get_args(msg, &err,
+                       DBUS_TYPE_STRING, &module,
+                       DBUS_TYPE_STRING, &command,
+                       DBUS_TYPE_INVALID);
+       retif(ret == 0, , "dbus_message_get_args error");
+       retif(module == NULL, , "Failed to get module");
+       retif(command == NULL, , "Failed to get command");
+
+       if (dbus_error_is_set(&err)) {
+               ERR("Dbus err: %s", err.message);
+               dbus_error_free(&err);
+               return;
+       }
+
+       mod = quickpanel_settings_module_get_by_name(module);
+       if (mod != NULL) {
+               DBG("module:%s, command:%s", module, command);
+               if (mod->handler_ipc != NULL) {
+                       if (mod->is_loaded == EINA_TRUE && mod->loader != NULL) {
+                               mod->handler_ipc(command, mod);
+                       } else {
+                               ERR("module:%s isn't loaded");
+                       }
+               } else {
+                       ERR("module:%s don't have IPC handler");
+               }
+       } else {
+               ERR("failed to lookup module:%s", module);
+       }
+}
+
+static void _handler_editing(void *data, DBusMessage *msg)
+{
+       int i = 0;
+       int ret = 0, is_error = 0;
+       DBusError err;
+       char *key = NULL;
+       char *order = NULL;
+       int num_featured = 0;
+       int order_count = 0;
+       gchar **order_split = NULL;
+       Eina_List *list_active = NULL;
+       QP_Module_Setting *mod = NULL;
+       retif(data == NULL || msg == NULL, , "Invalid parameter!");
+
+       dbus_error_init(&err);
+       ret = dbus_message_get_args(msg, &err,
+                       DBUS_TYPE_STRING, &key,
+                       DBUS_TYPE_STRING, &order,
+                       DBUS_TYPE_INT32, &num_featured,
+                       DBUS_TYPE_INVALID);
+       retif(ret == 0, , "dbus_message_get_args error");
+       retif(key == NULL, , "Failed to get key");
+       retif(order == NULL, , "Failed to get value");
+
+       if (dbus_error_is_set(&err)) {
+               ERR("dbus err: %s", err.message);
+               dbus_error_free(&err);
+               return;
+       }
+
+       if (strcmp(key, "quicksetting_order") == 0) {
+               DBG("order:%s %d", order, num_featured);
+               if (quickpanel_settings_featured_list_validation_check(order) == 1) {
+                       order_split = g_strsplit(order, ",", 0);
+                       if (order_split != NULL) {
+                               order_count = g_strv_length(order_split);
+                               DBG("count of quicksettings:%d", order_count);
+
+                               for (i = 0; i < order_count; i++) {
+                                       mod = quickpanel_settings_module_get_by_name(order_split[i]);
+                                       if (mod != NULL && mod->init != NULL) {
+                                               list_active = eina_list_append (list_active, mod);
+                                       } else {
+                                               ERR("failed to get quicksetting:%s", order_split[i]);
+                                               is_error = 1;
+                                       }
+                               }
+
+                               if (is_error == 0) {
+                                       if (list_active != NULL) {
+                                               quickpanel_setting_view_featured_reload(list_active, num_featured);
+                                               quickpanel_setting_view_all_reload(list_active);
+                                               quickpanel_setting_save_list_to_file(list_active, num_featured);
+                                               eina_list_free(list_active);
+                                       }
+                               }
+                               g_strfreev(order_split);
+                       }
+               } else {
+                       ERR("setting order validation check failed, igonore this signal");
+               }
+       }
+}
+
+static void _settings_ipc_init(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+       retif(ad->dbus_connection == NULL, , "Invalid parameter!");
+
+       s_info.hdl_activity =
+               e_dbus_signal_handler_add(ad->dbus_connection, NULL,
+                               QP_DBUS_PATH,
+                               QP_DBUS_NAME,
+                               QS_DBUS_SIG_ACTIVITY,
+                               _handler_activity, ad);
+       msgif(s_info.hdl_activity == NULL, "fail to add size signal");
+
+       s_info.hdl_editing =
+               e_dbus_signal_handler_add(ad->dbus_connection, NULL,
+                               QP_DBUS_PATH,
+                               QP_DBUS_NAME,
+                               QS_DBUS_SIG_EDITING,
+                               _handler_editing, ad);
+       msgif(s_info.hdl_editing == NULL, "fail to add size signal");
+}
+
+static void _settings_ipc_fini(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+       retif(ad->dbus_connection == NULL, , "Invalid parameter!");
+
+       if (s_info.hdl_activity != NULL) {
+               e_dbus_signal_handler_del(ad->dbus_connection,
+                               s_info.hdl_activity);
+               s_info.hdl_activity = NULL;
+       }
+
+       if (s_info.hdl_editing != NULL) {
+               e_dbus_signal_handler_del(ad->dbus_connection,
+                               s_info.hdl_editing);
+               s_info.hdl_editing = NULL;
+       }
+}
+
+/*****************************************************************************
+ *
+ * Util functions
+ *
+ *****************************************************************************/
+HAPI int quickpanel_settings_ipc_init(void *data)
+{
+       _settings_ipc_init(data);
+
+       return QP_OK;
+}
+
+HAPI int quickpanel_settings_ipc_fini(void *data)
+{
+       _settings_ipc_fini(data);
+
+       return QP_OK;
+}
diff --git a/daemon/settings/settings_ipc.h b/daemon/settings/settings_ipc.h
new file mode 100755 (executable)
index 0000000..d958345
--- /dev/null
@@ -0,0 +1,25 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __SETTING_IPC_H__
+#define __SETTING_IPC_H__
+
+extern int quickpanel_settings_ipc_init(void *data);
+extern int quickpanel_settings_ipc_fini(void *data);
+
+#endif /* __SETTING_IPC_H__ */
diff --git a/daemon/settings/settings_view_all.c b/daemon/settings/settings_view_all.c
new file mode 100755 (executable)
index 0000000..f1e4c00
--- /dev/null
@@ -0,0 +1,294 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+#include <glib.h>
+
+#include <notification.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "common.h"
+#include "common_uic.h"
+#include "quickpanel-ui.h"
+#include "quickpanel_def.h"
+#include "modules.h"
+#include "preference.h"
+#include "settings.h"
+#include "setting_utils.h"
+#include "settings_gridbox.h"
+#include "setting_module_api.h"
+#include "settings_view_all.h"
+#include "pager.h"
+#include "pager_common.h"
+#include "page_setting_all.h"
+#include "accessibility.h"
+
+#ifdef QP_EMERGENCY_MODE_ENABLE
+#include "emergency_mode.h"
+#endif
+
+static int _init(void *data);
+static int _fini(void *data);
+static int _resume(void *data);
+static void _opened(void *data);
+static void _closed(void *data);
+static void _refresh(void *data);
+static void _view_icons_add(void);
+static void _view_icons_del(void);
+
+QP_Module settings_view_all = {
+       .name = "settings_view_all",
+       .init = _init,
+       .fini = _fini,
+       .resume = _resume,
+       .qp_opened = _opened,
+       .qp_closed = _closed,
+       .refresh = _refresh,
+       .lang_changed = NULL,
+};
+
+static int _icons_rotation_set(int angle)
+{
+       Evas_Object *icon = NULL;
+       Eina_List *icons = NULL;
+       Evas_Object *section = NULL;
+       Eina_List *l = NULL;
+       const char *signal = NULL;
+
+       retif(angle < 0, -1, "angle is %d", angle);
+
+       section = quickpanel_page_setting_all_view_get("ACTIVE.BUTTONS");
+       retif(!section, -1, "box is NULL");
+
+       icons = elm_box_children_get(section);
+       retif(!icons, -1, "icons list is NULL");
+
+       if (angle % 180 == 0) {
+               signal = "icon.portrait";
+       } else {
+               signal = "icon.landscape";
+       }
+
+       EINA_LIST_FOREACH(icons, l, icon) {
+               elm_object_signal_emit(icon, signal, "quickpanl.prog");
+               edje_object_message_signal_process(_EDJ(icon));
+       }
+
+       eina_list_free(icons);
+
+       return 0;
+}
+
+static Evas_Object *_icon_create(QP_Module_Setting *module, Evas_Object *parent) {
+       retif(module == NULL, NULL, "Invalid parameter!");
+       retif(parent == NULL, NULL, "Invalid parameter!");
+
+       return quickpanel_setting_module_icon_create(module, parent);
+}
+
+static Evas_Object *_divider_create(Evas_Object *parent) {
+       Evas_Object *divider = NULL;
+       retif(parent == NULL, NULL, "invalid parameter");
+
+       struct appdata *ad = (struct appdata*)quickpanel_get_app_data();
+       retif(ad == NULL, NULL, "application data is NULL");
+
+       divider = quickpanel_uic_load_edj(parent, DEFAULT_EDJ, "quickpanel/setting_icon_divider", 0);
+
+       retif(divider == NULL, NULL, "failed to load divider");
+
+       return divider;
+}
+
+static void _icon_pack(Evas_Object *gridbox, Evas_Object *icon, int need_divider)
+{
+       Evas_Object *divider = NULL;
+       retif(gridbox == NULL, , "Invalid parameter!");
+       retif(icon == NULL, , "Invalid parameter!");
+
+       quickpanel_settings_gridbox_item_add(gridbox, icon, SETTINGS_GRIDBOX_ITEM_ICON, SETTINGS_GRIDBOX_APPEND);
+
+       if (need_divider == 1) {
+               divider = _divider_create(gridbox);
+               if (divider != NULL) {
+                       quickpanel_settings_gridbox_item_add(gridbox, divider,
+                                       SETTINGS_GRIDBOX_ITEM_DIVIDER, SETTINGS_GRIDBOX_APPEND);
+               }
+       }
+}
+
+static void _view_icons_add(void)
+{
+       int index = 0, total = 0;
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *gridbox = NULL;
+       Evas_Object *icon = NULL;
+       QP_Module_Setting *module = NULL;
+       Eina_List *list_all_icon = NULL;
+       Evas_Object *layout = quickpanel_page_setting_all_view_get("LAYOUT");
+       retif(layout == NULL, , "Invalid parameter!");
+
+       quickpanel_settings_all_list_get(&list_all_icon);
+       retif(list_all_icon == NULL, , "Invalid parameter!");
+
+       gridbox = quickpanel_page_setting_all_view_get("ACTIVE.BUTTONS");
+       if (gridbox == NULL) {
+               gridbox = quickpanel_settings_gridbox_create(layout, quickpanel_get_app_data());
+               quickpanel_page_setting_all_view_set("ACTIVE.BUTTONS", gridbox);
+       }
+
+       total = eina_list_count(list_all_icon);
+       DBG("total:%d", total);
+       EINA_LIST_FOREACH_SAFE(list_all_icon, l, l_next, module) {
+               icon = _icon_create(module, gridbox);
+               if (icon != NULL) {
+                       _icon_pack(gridbox, icon, (index != total - 1) ? 1 : 0);
+                       quickpanel_setting_module_icon_add(module, icon, QP_SETTING_ICON_CONTAINER_ALL_LIST);
+                       quickpanel_setting_module_icon_status_update(module, FLAG_VALUE_VOID, FLAG_VALUE_VOID);
+               }
+               DBG("all list:%s", module->name);
+               index++;
+       }
+
+       eina_list_free(list_all_icon);
+}
+
+static void _view_icons_del(void)
+{
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *icon = NULL;
+       QP_Module_Setting *module = NULL;
+       Eina_List *list_icons = NULL;
+       Evas_Object *box = quickpanel_page_setting_all_view_get("ACTIVE.BUTTONS");
+       retif(box == NULL, , "Invalid parameter!");
+
+       list_icons = elm_box_children_get(box);
+
+       EINA_LIST_FOREACH_SAFE(list_icons, l, l_next, icon) {
+               module = quickpanel_setting_module_get_from_icon(icon);
+               quickpanel_setting_module_icon_remove(module, icon);
+               elm_box_unpack(box, icon);
+               if (icon != NULL) {
+                       evas_object_del(icon);
+                       icon = NULL;
+               }
+       }
+
+       eina_list_free(list_icons);
+}
+
+static int _view_create(void *data)
+{
+       _view_icons_add();
+
+       return QP_OK;
+}
+
+static int _view_destroy(void *data)
+{
+       _view_icons_del();
+
+       return QP_OK;
+}
+
+/*****************************************************************************
+ *
+ * Util functions
+ *
+ *****************************************************************************/
+static int _init(void *data)
+{
+       struct appdata *ad = (struct appdata *)data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+       _view_create(data);
+
+       return QP_OK;
+}
+
+static int _fini(void *data)
+{
+       struct appdata *ad = (struct appdata *)data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+       _view_destroy(ad);
+
+       return QP_OK;
+}
+
+static int _resume(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+       return QP_OK;
+}
+
+static void _opened(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+}
+
+static void _closed(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+}
+
+static void _refresh(void *data) {
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       _icons_rotation_set(ad->angle);
+}
+
+HAPI void quickpanel_setting_view_all_reload(Eina_List *list_all_module)
+{
+       int index = 0, total = 0;
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *gridbox = NULL;
+       Evas_Object *icon = NULL;
+       QP_Module_Setting *module = NULL;
+       retif(list_all_module == NULL, , "Invalid parameter!");
+
+       gridbox = quickpanel_page_setting_all_view_get("ACTIVE.BUTTONS");
+       retif(gridbox == NULL, , "Invalid parameter!");
+
+       quickpanel_settings_gridbox_unpack_all(gridbox);
+
+       total = eina_list_count(list_all_module);
+       DBG("total:%d", total);
+       EINA_LIST_FOREACH_SAFE(list_all_module, l, l_next, module) {
+               if ((icon = quickpanel_setting_module_icon_get(module,
+                                               QP_SETTING_ICON_CONTAINER_ALL_LIST)) == NULL) {
+                       icon = _icon_create(module, gridbox);
+               }
+               if (icon != NULL) {
+                       _icon_pack(gridbox, icon, (index != total - 1) ? 1 : 0);
+                       quickpanel_setting_module_icon_add(module, icon, QP_SETTING_ICON_CONTAINER_ALL_LIST);
+                       quickpanel_setting_module_icon_status_update(module, FLAG_VALUE_VOID, FLAG_VALUE_VOID);
+               }
+               DBG("all list:%s", module->name);
+               index++;
+       }
+}
diff --git a/daemon/settings/settings_view_all.h b/daemon/settings/settings_view_all.h
new file mode 100755 (executable)
index 0000000..62d7272
--- /dev/null
@@ -0,0 +1,25 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __SETTING_VIEW_ALL_H__
+#define __SETTING_VIEW_ALL_H__
+
+extern void qp_setting_view_all_reload(Eina_List *list_all_module);
+extern void quickpanel_setting_view_all_reload(Eina_List *list_all_module);
+
+#endif /* __SETTING_VIEW_ALL_H__ */
diff --git a/daemon/settings/settings_view_featured.c b/daemon/settings/settings_view_featured.c
new file mode 100755 (executable)
index 0000000..03f0732
--- /dev/null
@@ -0,0 +1,348 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+#include <glib.h>
+
+#include <notification.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "common.h"
+#include "common_uic.h"
+#include "quickpanel-ui.h"
+#include "quickpanel_def.h"
+#include "modules.h"
+#include "preference.h"
+#include "settings.h"
+#include "setting_utils.h"
+#include "settings_gridbox.h"
+#include "setting_module_api.h"
+#include "settings_view_featured.h"
+#include "pager.h"
+#include "pager_common.h"
+#include "accessibility.h"
+
+#ifdef QP_EMERGENCY_MODE_ENABLE
+#include "emergency_mode.h"
+#endif
+
+static int _init(void *data);
+static void _init_job_cb(void *data);
+static int _fini(void *data);
+static int _resume(void *data);
+static void _opened(void *data);
+static void _closed(void *data);
+static void _refresh(void *data);
+static void _lang_changed(void *data);
+
+QP_Module settings_view_featured = {
+       .name = "settings_view_featured",
+       .init = _init,
+       .init_job_cb = _init_job_cb,
+       .fini = _fini,
+       .resume = _resume,
+       .qp_opened = _opened,
+       .qp_closed = _closed,
+       .refresh = _refresh,
+       .lang_changed = _lang_changed,
+};
+
+static void _view_layout_create(void *data)
+{
+       Evas_Object *box = NULL;
+       Evas_Object *container = NULL;
+       struct appdata *ad = data;
+       retif(!ad->ly, , "layout is NULL!");
+
+       container = quickpanel_uic_load_edj(ad->ly, DEFAULT_EDJ, "quickpanel/setting_container_wvga", 0);
+
+       retif(container == NULL, , "failed to load container");
+
+       box = elm_box_add(container);
+       if (!box) {
+               if (container != NULL) {
+                       evas_object_del(container);
+                       container = NULL;
+               }
+               return;
+       }
+
+       elm_object_style_set(box, "effect");
+
+       evas_object_size_hint_weight_set(box, 0.0 , EVAS_HINT_EXPAND);
+       evas_object_size_hint_fill_set(box, EVAS_HINT_FILL, EVAS_HINT_FILL);
+       elm_box_horizontal_set(box, EINA_TRUE);
+       evas_object_show(box);
+
+       elm_object_part_content_set(container, QP_SETTING_SCROLLER_PART_WVGA, box);
+
+       quickpanel_setting_layout_set(ad->ly, container);
+}
+
+static void _view_icons_add(void *data)
+{
+       int index = 0, total = 0;
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *icon = NULL;
+       QP_Module_Setting *module = NULL;
+       Eina_List *list_featured_icon = NULL;
+       struct appdata *ad = (struct appdata *)data;
+       Evas_Object *box = quickpanel_setting_box_get(ad->ly);
+       retif(box == NULL, , "Invalid parameter!");
+
+       quickpanel_settings_featured_list_get(&list_featured_icon);
+       retif(list_featured_icon == NULL, , "Invalid parameter!");
+
+       total = eina_list_count(list_featured_icon);
+       EINA_LIST_FOREACH_SAFE(list_featured_icon, l, l_next, module) {
+               icon = quickpanel_setting_module_icon_create(module, box);
+               quickpanel_setting_module_icon_add(module, icon, QP_SETTING_ICON_CONTAINER_FEATURED);
+               quickpanel_setting_icon_pack(box, icon, (index == total - 1) ? 0 : 1);
+               quickpanel_setting_module_icon_status_update(module, FLAG_VALUE_VOID, FLAG_VALUE_VOID);
+               index++;
+       }
+
+       eina_list_free(list_featured_icon);
+}
+
+static void _view_icons_del(void *data)
+{
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *icon = NULL;
+       QP_Module_Setting *module = NULL;
+       Eina_List *list_featured_icon = NULL;
+       struct appdata *ad = (struct appdata *)data;
+       retif(ad == NULL, , "Invalid parameter!");
+       Evas_Object *box = quickpanel_setting_box_get(ad->ly);
+       retif(box == NULL, , "Invalid parameter!");
+       list_featured_icon = elm_box_children_get(box);
+
+       EINA_LIST_FOREACH_SAFE(list_featured_icon, l, l_next, icon) {
+               module = quickpanel_setting_module_get_from_icon(icon);
+               quickpanel_setting_module_icon_remove(module, icon);
+               elm_box_unpack(box, icon);
+               if (icon != NULL) {
+                       evas_object_del(icon);
+                       icon = NULL;
+               }
+       }
+
+       eina_list_free(list_featured_icon);
+}
+
+/*****************************************************************************
+ *
+ * Util functions
+ *
+ *****************************************************************************/
+static int _init(void *data)
+{
+       struct appdata *ad = (struct appdata *)data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+#ifdef QP_EMERGENCY_MODE_ENABLE
+       if (quickpanel_emergency_mode_is_on()) {
+               elm_object_signal_emit(ad->ly, "quickpanel.setting.hide", "quickpanel.prog");
+               return QP_OK;
+       }
+#endif
+
+       _view_layout_create(data);
+       _view_icons_add(data);
+
+       elm_object_signal_emit(ad->ly, "quickpanel.setting.show", "quickpanel.prog");
+
+       return QP_OK;
+}
+
+static void _init_job_cb(void *data)
+{
+       struct appdata *ad = data;
+       Evas_Object *scroller = NULL;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_set_scroll_page_width(ad);
+       quickpanel_setting_stop(ad->ly, 0);
+       scroller = quickpanel_setting_scroller_get(ad->ly);
+       evas_object_show(scroller);
+}
+
+static int _fini(void *data)
+{
+       struct appdata *ad = (struct appdata *)data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+       _view_icons_del(ad);
+       quickpanel_setting_layout_remove(ad->ly);
+       elm_object_signal_emit(ad->ly, "quickpanel.setting.hide", "quickpanel.prog");
+
+       return QP_OK;
+}
+
+static int _resume(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+       return QP_OK;
+}
+
+static void _opened(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_view_featured_initial_focus_set();
+}
+
+static void _closed(void *data)
+{
+       struct appdata *ad = data;
+       Evas_Object *focused_obj = NULL;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_stop(ad->ly, 0);
+
+       if (ad->win != NULL) {
+               focused_obj = elm_object_focused_object_get(ad->win);
+               if (focused_obj != NULL) {
+                       elm_object_focus_set(focused_obj, EINA_FALSE);
+               }
+       }
+}
+
+static void _refresh(void *data) {
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       quickpanel_setting_container_rotation_set(ad->ly, ad->angle);
+       quickpanel_setting_icons_rotation_set(ad->ly, ad->angle);
+       if (ad->is_opened == 0) {
+               quickpanel_setting_stop(ad->ly, 1);
+       }
+}
+
+static void _lang_changed(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       if (ad->is_opened == 0) {
+               quickpanel_setting_stop(ad->ly, 0);
+       }
+}
+
+HAPI Eina_Bool quickpanel_settings_is_in_left_edge(void)
+{
+       if (quickpanel_setting_scroll_page_get(quickpanel_get_app_data()) == 0) {
+               return EINA_TRUE;
+       }
+
+       return EINA_FALSE;
+}
+
+HAPI void quickpanel_setting_view_featured_reload(Eina_List *list_all_module, int num_featured)
+{
+       int index = 0, total = 0;
+       Eina_List *l;
+       Eina_List *l_next;
+       Evas_Object *box = NULL;
+       Evas_Object *icon = NULL;
+       QP_Module_Setting *module = NULL;
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(list_all_module == NULL, , "Invalid parameter!");
+
+       box = quickpanel_setting_box_get(ad->ly);
+       retif(box == NULL, , "invalid parameter");
+
+       quickpanel_setting_icon_unpack_all(box);
+
+       total = eina_list_count(list_all_module);
+       DBG("total:%d", total);
+       EINA_LIST_FOREACH_SAFE(list_all_module, l, l_next, module) {
+               if (index < num_featured) {
+                       if ((icon = quickpanel_setting_module_icon_get(module,
+                                                       QP_SETTING_ICON_CONTAINER_FEATURED)) == NULL) {
+                               icon = quickpanel_setting_module_icon_create(module, box);
+                       }
+                       if (icon != NULL) {
+                               quickpanel_setting_module_icon_add(module, icon, QP_SETTING_ICON_CONTAINER_FEATURED);
+                               quickpanel_setting_icon_pack(box, icon, (index == num_featured - 1) ? 0 : 1);
+                               quickpanel_setting_module_icon_status_update(module, FLAG_VALUE_VOID, FLAG_VALUE_VOID);
+                       }
+                       DBG("all list:%s", module->name);
+               } else {
+                       if ((icon = quickpanel_setting_module_icon_get(module,
+                                                       QP_SETTING_ICON_CONTAINER_FEATURED)) != NULL) {
+                               quickpanel_setting_module_icon_remove(module, icon);
+                               evas_object_del(icon);
+                               icon = NULL;
+                       }
+               }
+
+               index++;
+       }
+}
+
+HAPI void quickpanel_setting_view_featured_initial_focus_set(void)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "Invalid parameter!");
+
+       Evas_Object *obj_first = NULL;
+       Eina_List *list_featured_icon = NULL;
+       Evas_Object *box = quickpanel_setting_box_get(ad->ly);
+       retif(box == NULL, , "Invalid parameter!");
+
+#ifdef QP_EMERGENCY_MODE_ENABLE
+       if (quickpanel_emergency_mode_is_on()) {
+               return;
+       }
+#endif
+
+       if (quickpanel_uic_opened_reason_get() == OPENED_BY_CMD_SHOW_SETTINGS) {
+               return;
+       }
+
+       list_featured_icon = elm_box_children_get(box);
+       if (list_featured_icon != NULL) {
+               obj_first = eina_list_nth(list_featured_icon, 0);
+               if (obj_first != NULL) {
+                       elm_object_focus_set(obj_first, EINA_FALSE);
+                       elm_object_focus_set(obj_first, EINA_TRUE);
+               }
+               eina_list_free(list_featured_icon);
+       }
+}
+
+HAPI void quickpanel_setting_view_featured_brightness_init(Evas_Object *brightness_view)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "Invalid parameter!");
+
+       Evas_Object *container = NULL;
+
+       container = quickpanel_setting_layout_get(ad->ly, QP_SETTING_BASE_PART);
+
+       retif(container == NULL, ,"Failed to get container");
+
+       elm_object_part_content_set(container, QP_SETTING_BRIGHTNESS_PART_WVGA, brightness_view);
+}
diff --git a/daemon/settings/settings_view_featured.h b/daemon/settings/settings_view_featured.h
new file mode 100755 (executable)
index 0000000..b68cd18
--- /dev/null
@@ -0,0 +1,27 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __SETTING_VIEW_FEATURED_H__
+#define __SETTING_VIEW_FEATURED_H__
+
+extern Eina_Bool quickpanel_settings_is_in_left_edge(void);
+extern void quickpanel_setting_view_featured_reload(Eina_List *list_all_module, int num_featured);
+extern void quickpanel_setting_view_featured_initial_focus_set(void);
+extern void quickpanel_setting_view_featured_brightness_init(Evas_Object *brightness_view);
+
+#endif /* __SETTING_VIEW_FEATURED_H__ */
diff --git a/daemon/sim_controller.c b/daemon/sim_controller.c
new file mode 100755 (executable)
index 0000000..9f43f6a
--- /dev/null
@@ -0,0 +1,640 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#include <Elementary.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <E_DBus.h>
+
+#include <tapi_common.h>
+#include <ITapiSim.h>
+#include <TelCall.h>
+#include <ITapiCall.h>
+#include <TelNetwork.h>
+
+#include <dlog.h>
+#include <vconf.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "setting_utils.h"
+
+#include "list_util.h"
+#include "quickpanel-ui.h"
+#include "common.h"
+
+#include "handler_controller.h"
+
+#define TAPI_HANDLE_MAX  2
+
+static struct
+{
+       TapiHandle *handle[TAPI_HANDLE_MAX+1];
+       Eina_Bool sim_card_ready[2];
+
+       Evas_Object *layout;
+
+       int call_state; // 0:none, 1:call
+}
+sim_state_info =
+{
+       .handle[0] = NULL,
+       .handle[1] = NULL,
+       .handle[2] = NULL,
+       .sim_card_ready[0] = EINA_FALSE,
+       .sim_card_ready[1] = EINA_FALSE,
+       .layout = NULL,
+       .call_state = 0,
+};
+
+static void register_sim_callbacks();
+static void unregister_sim_callbacks();
+
+static char *get_sim_plmn(TapiHandle *handle)
+{
+       int ret;
+       char *network_name = NULL;
+
+       /* Reading Network (PLMN) name - ‘string’ type Property */
+       ret = tel_get_property_string(handle,
+                       TAPI_PROP_NETWORK_NETWORK_NAME, &network_name);
+       if(ret == TAPI_API_SUCCESS)
+       {
+               /* ‘network_name’ contains valid Network name based on Display condition */
+               return network_name;
+       }
+       else
+       {
+               ERR("Sim = %p PLMN = ERROR[%d]", handle, ret);
+               /* get property failed */
+       }
+
+       return NULL;
+}
+
+static char *get_sim_spn(TapiHandle *handle)
+{
+       int ret;
+       char *spn_name = NULL;
+
+
+       /* Reading SPN name - ‘string’ type Property */
+       ret = tel_get_property_string(handle,
+                       TAPI_PROP_NETWORK_SPN_NAME, &spn_name);
+       if(ret == TAPI_API_SUCCESS)
+       {
+               /* ‘spn_name’ contains valid Service provider name */
+               return spn_name;
+       }
+       else
+       {
+               ERR("Sim = %p SPN = ERROR[%d]", handle, ret);
+               /* get property failed */
+               return NULL;
+       }
+}
+
+static char *get_plmn_spn_network(int handle_num, TapiHandle *handle)
+{
+       int ret = TAPI_API_SUCCESS;
+       int service_type = TAPI_NETWORK_SERVICE_TYPE_UNKNOWN;
+       int name_option = TAPI_NETWORK_DISP_INVALID;
+       char *plmn = NULL;
+       char *spn = NULL;
+       char buf[1024] = { 0, };
+
+       // get service type
+       ret = tel_get_property_int(handle, TAPI_PROP_NETWORK_SERVICE_TYPE, &service_type);
+       if (ret != TAPI_API_SUCCESS) {
+               ERR("Failed to get service type[%d]", ret);
+       }
+
+       if (service_type >= TAPI_NETWORK_SERVICE_TYPE_2G) {
+               // get network name option
+               ret = tel_get_property_int(handle, TAPI_PROP_NETWORK_NAME_OPTION, &name_option);
+               if (ret != TAPI_API_SUCCESS) {
+                       ERR("Failed to get name option[%d]", ret);
+               }
+
+               switch (name_option) {
+               case TAPI_NETWORK_DISP_SPN:
+                       spn = get_sim_spn(handle);
+                       if (spn != NULL && spn[0] != 0) {
+                               INFO("PLMN/SPN - Sim %p using SPN: %s", handle, spn);
+                               snprintf(buf, sizeof(buf), "%s", spn);
+                       }
+                       break;
+               case TAPI_NETWORK_DISP_PLMN:
+                       plmn = get_sim_plmn(handle);
+                       if (plmn != NULL && plmn[0] != 0) {
+                               INFO("PLMN/SPN - Sim %p using PLMN: %s", handle, plmn);
+                               snprintf(buf, sizeof(buf), "%s", plmn);
+                       }
+                       break;
+               case TAPI_NETWORK_DISP_SPN_PLMN:
+                       spn = get_sim_spn(handle);
+                       plmn = get_sim_plmn(handle);
+                       if (spn != NULL && spn[0] != 0 && plmn != NULL && plmn[0] != 0) {
+                               INFO("PLMN/SPN - Sim %p using SPN: %s, PLMN: %s", handle, spn, plmn);
+                               snprintf(buf, sizeof(buf), "%s - %s", plmn, spn);
+                       } else if (spn != NULL && spn[0] != 0) {
+                               INFO("PLMN/SPN - Sim %p using SPN: %s", handle, spn);
+                               snprintf(buf, sizeof(buf), "%s", spn);
+                       } else if (plmn != NULL && plmn[0] != 0) {
+                               INFO("PLMN/SPN - Sim %p using PLMN: %s", handle, plmn);
+                               snprintf(buf, sizeof(buf), "%s", plmn);
+                       }
+                       break;
+               default:
+                       ERR("Invalid name option[%d]", name_option);
+                       plmn = get_sim_plmn(handle);
+                       if (plmn != NULL && plmn[0] != 0) {
+                               INFO("PLMN/SPN - Sim %p using PLMN: %s", handle, plmn);
+                               snprintf(buf, sizeof(buf), "%s", plmn);
+                       }
+                       break;
+               }
+       } else {
+               switch (service_type) {
+               case TAPI_NETWORK_SERVICE_TYPE_NO_SERVICE:
+                       snprintf(buf, sizeof(buf), "%s", _("IDS_IDLE_BODY_NO_SERVICE"));
+                       break;
+               case TAPI_NETWORK_SERVICE_TYPE_EMERGENCY:
+                       snprintf(buf, sizeof(buf), "%s", _("IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"));
+                       break;
+               case TAPI_NETWORK_SERVICE_TYPE_SEARCH:
+                       snprintf(buf, sizeof(buf), "%s", _("IDS_COM_BODY_SEARCHING"));
+                       break;
+               default:
+                       ERR("invalid service type[%d]", service_type);
+                       plmn = get_sim_plmn(handle);
+                       if (plmn != NULL && plmn[0] != 0) {
+                               INFO("PLMN/SPN - Sim %p using PLMN: %s", handle, plmn);
+                               snprintf(buf, sizeof(buf), "%s", plmn);
+                       }
+                       break;
+               }
+       }
+
+       DBG("handle[%d][%p] service_type[%d], name_option[%d] >> [%s]", handle_num, handle, service_type, name_option, buf);
+
+       if (strlen(buf) == 0) {
+               ERR("Empty string");
+               snprintf(buf, sizeof(buf), "%s", _("IDS_IDLE_BODY_NO_SERVICE"));
+       } else if (strncasecmp(buf, "No Service", strlen("No Service")) == 0) {
+               ERR("USING SPECIAL NETWORK NAME:  %s in handle: %d", _("IDS_IDLE_BODY_NO_SERVICE"), handle_num);
+               return strdup(_("IDS_IDLE_BODY_NO_SERVICE"));
+       } else if (strncasecmp(buf, "EMERGENCY", strlen("EMERGENCY")) == 0) {
+               ERR("USING SPECIAL NETWORK NAME:  %s in handle: %d", _("IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"), handle_num);
+               return strdup(_("IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"));
+       } else if (strncasecmp(buf, "Searching", strlen("Searching")) == 0) {
+               ERR("USING SPECIAL NETWORK NAME:  %s in handle: %d", _("IDS_COM_BODY_SEARCHING"), handle_num);
+               return strdup(_("IDS_COM_BODY_SEARCHING"));
+       } else if (strncasecmp(buf, "SIM Error", strlen("SIM Error")) == 0) {
+               ERR("USING SPECIAL NETWORK NAME:  %s in handle: %d", _("IDS_IDLE_BODY_INVALID_SIM_CARD"), handle_num);
+               return strdup(_("IDS_IDLE_BODY_INVALID_SIM_CARD"));
+       } else if (strncasecmp(buf, "NO SIM", strlen("NO SIM")) == 0) {
+               ERR("USING SPECIAL NETWORK NAME:  %s in handle: %d", _("IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"), handle_num);
+               return strdup(_("IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"));
+       }
+
+       return strdup(buf);
+}
+
+// --------------------------------------------------------------------------------------------
+static void print_sim_status(TelSimCardStatus_t sim_status, int card_changed)
+{
+       switch(sim_status) {
+       case TAPI_SIM_STATUS_CARD_ERROR:
+               INFO("Sim card status: TAPI_SIM_STATUS_CARD_ERROR");
+               break;
+
+       case TAPI_SIM_STATUS_CARD_NOT_PRESENT:
+               INFO("Sim card status: TAPI_SIM_STATUS_CARD_NOT_PRESENT");
+               break;
+
+       case TAPI_SIM_STATUS_SIM_INITIALIZING:
+               INFO("Sim card status: TAPI_SIM_STATUS_SIM_INITIALIZING");
+               break;
+
+       case TAPI_SIM_STATUS_SIM_INIT_COMPLETED:
+               INFO("Sim card status: TAPI_SIM_STATUS_SIM_INIT_COMPLETED");
+               break;
+
+       case TAPI_SIM_STATUS_SIM_PIN_REQUIRED:
+               INFO("Sim card status: TAPI_SIM_STATUS_SIM_PIN_REQUIRED");
+               break;
+
+       case TAPI_SIM_STATUS_SIM_PUK_REQUIRED:
+               INFO("Sim card status: TAPI_SIM_STATUS_SIM_PUK_REQUIRED");
+               break;
+
+       case TAPI_SIM_STATUS_CARD_BLOCKED:
+               INFO("Sim card status: TAPI_SIM_STATUS_CARD_BLOCKED");
+               break;
+
+       case TAPI_SIM_STATUS_SIM_NCK_REQUIRED:
+               INFO("Sim card status: TAPI_SIM_STATUS_SIM_NCK_REQUIRED");
+               break;
+
+       case TAPI_SIM_STATUS_SIM_NSCK_REQUIRED:
+               INFO("Sim card status: TAPI_SIM_STATUS_SIM_NSCK_REQUIRED");
+               break;
+
+       case TAPI_SIM_STATUS_SIM_SPCK_REQUIRED:
+               INFO("Sim card status: TAPI_SIM_STATUS_SIM_SPCK_REQUIRED");
+               break;
+
+       case TAPI_SIM_STATUS_SIM_CCK_REQUIRED:
+               INFO("Sim card status: TAPI_SIM_STATUS_SIM_CCK_REQUIRED");
+               break;
+
+       case TAPI_SIM_STATUS_CARD_REMOVED:
+               INFO("Sim card status: TAPI_SIM_STATUS_CARD_REMOVED");
+               break;
+
+       case TAPI_SIM_STATUS_SIM_LOCK_REQUIRED:
+               INFO("Sim card status: TAPI_SIM_STATUS_SIM_LOCK_REQUIRED");
+               break;
+
+       case TAPI_SIM_STATUS_CARD_CRASHED:
+               INFO("Sim card status: TAPI_SIM_STATUS_CARD_CRASHED");
+               break;
+
+       case TAPI_SIM_STATUS_CARD_POWEROFF:
+               INFO("Sim card status: TAPI_SIM_STATUS_CARD_POWEROFF");
+               break;
+
+       case TAPI_SIM_STATUS_UNKNOWN:
+               INFO("Sim card status: TAPI_SIM_STATUS_UNKNOWN");
+               break;
+       }
+
+       INFO("Sim_card_changed: %d", card_changed);
+}
+
+static void get_sim_status()
+{
+       int i;
+       int ret;
+       TelSimCardStatus_t sim_status;
+       int card_changed;
+
+       for (i = 0; i < TAPI_HANDLE_MAX + 1; ++i) {
+               if (sim_state_info.handle[i]) {
+                       ret = tel_get_sim_init_info (sim_state_info.handle[i], &sim_status, &card_changed);
+                       if(ret == 0) {
+                               print_sim_status(sim_status, card_changed);
+
+                               if(sim_status == TAPI_SIM_STATUS_SIM_INIT_COMPLETED || sim_status == TAPI_SIM_STATUS_SIM_PIN_REQUIRED) {
+                                       if (i < TAPI_HANDLE_MAX) {
+                                               sim_state_info.sim_card_ready[i] = EINA_TRUE;
+                                       }
+                               } else {
+                                       ERR("SIM[%d] is not completed initialization [%d]", i, sim_status);
+                               }
+                       } else {
+                               ERR("Could not get sim[%d] status[%d]", i, ret);
+                       } // if ret == 0
+               } // if sim_state_info
+       } // for
+}
+
+static void sim_handler_text_set(Eina_Bool flight_mode)
+{
+       if (flight_mode) {
+               // if flight mode, No service
+               quickpanel_handler_text_set(_("IDS_IDLE_BODY_NO_SERVICE"));
+       } else if (sim_state_info.sim_card_ready[0] && sim_state_info.sim_card_ready[1]) {
+               quickpanel_handler_text_set(NULL);
+       } else if(sim_state_info.sim_card_ready[0]) {
+               char *plmn_spn1 = get_plmn_spn_network(0, sim_state_info.handle[0]);
+               quickpanel_handler_text_set(plmn_spn1);
+               if (plmn_spn1) {
+                       free(plmn_spn1);
+               }
+       } else if(sim_state_info.sim_card_ready[1]) {
+               char *plmn_spn1 = get_plmn_spn_network(1, sim_state_info.handle[1]);
+               quickpanel_handler_text_set(plmn_spn1);
+               if (plmn_spn1) {
+                       free(plmn_spn1);
+               }
+       } else {
+               quickpanel_handler_text_set(_("IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"));
+       }
+}
+
+static void init_view()
+{
+       struct appdata *ad = NULL;
+
+       ad = quickpanel_get_app_data();
+       if (ad == NULL) {
+               ERR("invalid data");
+               return;
+       }
+
+       int flight_mode_state = EINA_FALSE;
+       int ret = vconf_get_bool(VCONFKEY_TELEPHONY_FLIGHT_MODE, &flight_mode_state);
+       if(ret != 0) {
+               ERR("Could not get 'VCONFKEY_TELEPHONY_FLIGHT_MODE' value");
+       }
+
+       sim_handler_text_set(flight_mode_state);
+}
+
+/* Initialize TAPI */
+static void _init_tel()
+{
+       char **cp_list = NULL;
+       unsigned int modem_num = 0;
+
+       /* Get CP name list – cp_list */
+       cp_list = tel_get_cp_name_list();
+
+       if(cp_list == NULL) {
+               ERR("Could not get the cp_name_list");
+               return;
+       }
+
+       while (cp_list[modem_num]) {
+               /* Initialize TAPI handle */
+               sim_state_info.handle[modem_num] = tel_init(cp_list[modem_num]);
+
+               if (cp_list[modem_num]) {
+                       ERR("sim_state_info.handle[%d] = %s; ptr = %p", modem_num, cp_list[modem_num], sim_state_info.handle[modem_num]);
+               }
+
+               /* Move to next CP Name in cp_list */
+               modem_num++;
+       }
+
+       sim_state_info.handle[modem_num] = NULL;
+
+       /* free cp_list */
+       free(cp_list);
+}
+
+/* De-initialize TAPI */
+static void _deinit_tel()
+{
+       int i = 0;
+       while (sim_state_info.handle[i]) {
+               /* De-initialize TAPI handle */
+               tel_deinit(sim_state_info.handle[i]);
+               sim_state_info.handle[i] = NULL;
+
+               /* Move to next handle */
+               i++;
+       }
+}
+
+/* Telephony state change callback */
+void tel_ready_cb(keynode_t *key, void *data)
+{
+       Eina_Bool status = EINA_FALSE;
+
+       status = vconf_keynode_get_bool(key);
+
+       if (status == TRUE) {   /* Telephony State - READY */
+               DBG("tel status[%d]", status);
+               _init_tel();
+               register_sim_callbacks();
+               get_sim_status();
+
+               init_view();
+       } else {   /* Telephony State – NOT READY */
+               /* De-initialization is optional here (ONLY if required) */
+               ERR("tel status[%d]", status);
+               _deinit_tel();
+               sim_state_info.sim_card_ready[0] = EINA_FALSE;
+               sim_state_info.sim_card_ready[1] = EINA_FALSE;
+
+               unregister_sim_callbacks();
+       }
+}
+
+static void tel_flight_mode_cb(keynode_t *key, void *data)
+{
+       Eina_Bool flight_mode_state = EINA_FALSE;
+
+       flight_mode_state = vconf_keynode_get_bool(key);
+       sim_handler_text_set(flight_mode_state);
+}
+
+// --------------------------------------------------------------------------------------------
+static void on_sim_card_status_changed(TapiHandle *handle, const char *noti_id, void *data, void *user_data)
+{
+       int handle_num;
+       int *sim_status = data;
+
+       /**
+        * @note
+        * Casting the pointer to "long" first for 64 bits architecture.
+        * And then convert it to "int"
+        */
+       handle_num = (int)((long)user_data);
+
+       ERR("SIM[%p][%d] status[%d], [%d][%d]", handle, handle_num, *sim_status, sim_state_info.sim_card_ready[0], sim_state_info.sim_card_ready[1]);
+
+       if(*sim_status == TAPI_SIM_STATUS_SIM_INIT_COMPLETED || *sim_status == TAPI_SIM_STATUS_SIM_PIN_REQUIRED) {
+               sim_state_info.sim_card_ready[handle_num] = EINA_TRUE;
+       } else {
+               sim_state_info.sim_card_ready[handle_num] = EINA_FALSE;
+       }
+
+       init_view();
+}
+
+static void on_plmn_spn_changed(TapiHandle *handle, const char *noti_id,
+               void *data, void *user_data)
+{
+       if (!handle) {
+               ERR("handle == NULL");
+               return;
+       }
+
+       int flight_mode_state = EINA_FALSE;
+       int ret = vconf_get_bool(VCONFKEY_TELEPHONY_FLIGHT_MODE, &flight_mode_state);
+       if (ret != 0) {
+               ERR("Could not get the 'VCONFKEY_TELEPHONY_FLIGHT_MODE' value");
+       }
+       sim_handler_text_set(flight_mode_state);
+}
+
+static void register_sim_callbacks()
+{
+       long i;
+       int ret;
+
+       for (i = 0; i < TAPI_HANDLE_MAX; ++i) {
+               if (sim_state_info.handle[i]) {
+                       ret = tel_register_noti_event(sim_state_info.handle[i], TAPI_NOTI_SIM_STATUS, on_sim_card_status_changed, (void *)i);
+                       if (ret != TAPI_API_SUCCESS) {
+                               ERR("Failed to register 'on_sim_card_status_changed' callback to handle[%d][%d]", i, ret);
+                       } else {
+                               ERR("SIM card status changed event registered");
+                       }
+
+                       ret = tel_register_noti_event(sim_state_info.handle[i], TAPI_PROP_NETWORK_SPN_NAME, on_plmn_spn_changed, (void *)i);
+                       if (ret != TAPI_API_SUCCESS) {
+                               ERR("Failed to register 'on_plmn_spn_changed' callback to handle[%d][%d]", i, ret);
+                       }
+
+                       ret = tel_register_noti_event(sim_state_info.handle[i], TAPI_PROP_NETWORK_NETWORK_NAME, on_plmn_spn_changed, (void *)i);
+                       if (ret != TAPI_API_SUCCESS) {
+                               ERR("Failed to register 'on_plmn_spn_changed' callback to handle: %i", i);
+                       }
+
+                       ret = tel_register_noti_event(sim_state_info.handle[i], TAPI_PROP_NETWORK_SERVICE_TYPE, on_plmn_spn_changed, (void *)i);
+                       if (ret != TAPI_API_SUCCESS) {
+                               ERR("Failed to register network service type[%d][%d]", ret, i);
+                       }
+
+                       ret = tel_register_noti_event(sim_state_info.handle[i], TAPI_PROP_NETWORK_NAME_OPTION, on_plmn_spn_changed, (void *)i);
+                       if (ret != TAPI_API_SUCCESS) {
+                               ERR("Failed to register network name option[%d][%d]", ret, i);
+                       }
+               } else {
+                       ERR("No handle [%d]", i);
+               }
+       }
+}
+
+static void unregister_sim_callbacks()
+{
+       int i;
+       int ret;
+       for(i = 0; i < TAPI_HANDLE_MAX; ++i) {
+               if(sim_state_info.handle[i]) {
+                       ret = tel_deregister_noti_event(sim_state_info.handle[i], TAPI_NOTI_SIM_STATUS);
+                       if (ret != TAPI_API_SUCCESS) {
+                               ERR("Failed to dereregister TAPI_NOTI_SIM_STATUS callback from handle: %i", i);
+                       } else {
+                               DBG("SIM status changed event deregistered");
+                       }
+
+                       ret = tel_deregister_noti_event(sim_state_info.handle[i], TAPI_PROP_NETWORK_NETWORK_NAME);
+                       if (ret != TAPI_API_SUCCESS) {
+                               ERR("Failed to dereregister TAPI_PROP_NETWORK_PLMN callback from handle: %i", i);
+                       }
+
+                       ret = tel_deregister_noti_event(sim_state_info.handle[i], TAPI_PROP_NETWORK_SPN_NAME);
+                       if (ret != TAPI_API_SUCCESS) {
+                               ERR("Failed to dereregister TAPI_PROP_NETWORK_SPN_NAME callback from handle: %i", i);
+                       }
+
+                       ret = tel_deregister_noti_event(sim_state_info.handle[i], TAPI_PROP_NETWORK_SERVICE_TYPE);
+                       if (ret != TAPI_API_SUCCESS) {
+                               ERR("Failed to deregister network service type[%d][%d]", ret, i);
+                       }
+
+                       ret = tel_deregister_noti_event(sim_state_info.handle[i], TAPI_PROP_NETWORK_NAME_OPTION);
+                       if (ret != TAPI_API_SUCCESS) {
+                               ERR("Failed to deregister network name option[%d][%d]", ret, i);
+                       }
+
+                       if(i == 0) {
+                               ret = tel_deregister_noti_event(sim_state_info.handle[i], TAPI_NOTI_CALL_PREFERRED_VOICE_SUBSCRIPTION);
+                               if (ret != TAPI_API_SUCCESS) {
+                                       ERR("Failed to dereregister  callback to handle: %d", i);
+                               }
+                       }
+               }
+       } // for
+}
+
+void sim_controller_init(Evas_Object *master_layout)
+{
+       int state = EINA_FALSE;
+       int ret;
+       /* Check if Telephony state - READY */
+       ret = vconf_get_bool(VCONFKEY_TELEPHONY_READY, &state);
+
+       DBG("VCONFKEY_TELEPHONY_READY == %d", state);
+
+       if (ret != -1 && state == TRUE) {
+               /* Telephony State - READY */
+               /* Initialize TAPI handles */
+
+               _init_tel();
+               register_sim_callbacks();
+               get_sim_status();
+
+               init_view();
+       } else {        /* Telephony State – NOT READY, register for change in state */
+               DBG("Telephony state: [NOT Ready]");
+       }
+
+       /* Register for Telephony state change */
+       ret = vconf_notify_key_changed(VCONFKEY_TELEPHONY_READY, tel_ready_cb, master_layout);
+       if(ret != 0) {
+               ERR("Failed to register VCONFKEY_TELEPHONY_READY key changed callback");
+       }
+
+       ret = vconf_notify_key_changed(VCONFKEY_TELEPHONY_FLIGHT_MODE, tel_flight_mode_cb, master_layout);
+       if(ret != 0) {
+               ERR("Failed to register VCONFKEY_TELEPHONY_FLIGHT_MODE key changed callback");
+       }
+}
+
+void sim_controller_resume()
+{
+       int state = FALSE;
+       int ret = 0;
+       int i = 0;
+       TelSimCardStatus_t sim_status;
+       int card_changed;
+
+       ret = vconf_get_bool(VCONFKEY_TELEPHONY_READY, &state);
+       if (ret != 0 || state == FALSE) {
+               ERR("Failed to get telephony state[%d][%d]", state, ret);
+               return;
+       }
+
+       for (i = 0; i < TAPI_HANDLE_MAX; ++i) {
+               if (sim_state_info.handle[i]) {
+                       ret = tel_get_sim_init_info(sim_state_info.handle[i], &sim_status, &card_changed);
+                       DBG("SIM[%d] info[%d][%d][%d]", i, ret, sim_status, card_changed);
+                       if (sim_status == TAPI_SIM_STATUS_SIM_INIT_COMPLETED || sim_status == TAPI_SIM_STATUS_SIM_PIN_REQUIRED) {
+                               if (sim_state_info.sim_card_ready[i] != EINA_TRUE) {
+                                       ERR("SIM[%d] is init completed but local value is not ture", i);
+                               }
+                       }
+               } else {
+                       ERR("No handle[%d]", i);
+               }
+       }
+}
+
+void sim_controller_on_language_change()
+{
+       on_plmn_spn_changed(sim_state_info.handle[0], "SELF", NULL, (void*) 0);
+       on_plmn_spn_changed(sim_state_info.handle[1], "SELF", NULL, (void*) 1);
+
+       if (sim_state_info.handle[0] == NULL && sim_state_info.handle[1] == NULL) {
+               int flight_mode = EINA_FALSE;
+               int ret = vconf_get_bool(VCONFKEY_TELEPHONY_FLIGHT_MODE, &flight_mode);
+               if (ret != 0) {
+                       ERR("Failed to get flight mode[%d]", ret);
+               }
+
+               sim_handler_text_set(flight_mode);
+       }
+}
diff --git a/daemon/sim_controller.h b/daemon/sim_controller.h
new file mode 100755 (executable)
index 0000000..54940de
--- /dev/null
@@ -0,0 +1,27 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __SIM_CONTROL_H__
+#define __SIM_CONTROL_H__
+
+
+extern void sim_controller_init(Evas_Object *master_layout);
+extern void sim_controller_resume();
+extern void sim_controller_on_language_change();
+
+#endif //  __SIM_CONTROL_H__
diff --git a/daemon/vi/vi_manager.c b/daemon/vi/vi_manager.c
new file mode 100755 (executable)
index 0000000..9635c0f
--- /dev/null
@@ -0,0 +1,465 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include <Elementary.h>
+
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "quickpanel-ui.h"
+#include "common_uic.h"
+#include "common.h"
+#include "list_util.h"
+#include "vi_manager.h"
+#include "pager.h"
+
+static int _init(void *data);
+static int _fini(void *data);
+static int _resume(void *data);
+static void _qp_opened(void *data);
+
+QP_Module vi_manager = {
+       .name = "vi_manager",
+       .init = _init,
+       .fini = _fini,
+       .resume = _resume,
+       .qp_opened = _qp_opened,
+       .lang_changed = NULL,
+       .refresh = NULL
+};
+
+static struct info {
+       Eina_List *vi_list;
+       Eina_List *vi_user_event_list;
+       QP_VI *current;
+       qp_vim_state_type state;
+} s_info = {
+       .vi_list = NULL,
+       .vi_user_event_list = NULL,
+       .current = NULL,
+       .state = VIM_STATE_NOT_READY,
+};
+
+static QP_VI *_vi_list_get_first(void);
+static QP_VI *_vi_user_event_list_get_first(void);
+static void _vi_list_del(QP_VI *vi);
+
+static inline void _vim_set_state(qp_vim_state_type state)
+{
+       s_info.state = state;
+}
+
+static inline qp_vim_state_type _vim_get_state(void)
+{
+       return s_info.state;
+}
+
+static void _vi_freeze_start(void)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "invalid parameter");
+       retif(ad->list == NULL, , "invalid parameter");
+
+       if (!evas_object_freeze_events_get(ad->scroller)) {
+               INFO("VIM freezing");
+               evas_object_freeze_events_set(ad->scroller, EINA_TRUE);
+       }
+}
+
+static void _vi_freeze_stop(void)
+{
+       struct appdata *ad = quickpanel_get_app_data();
+       retif(ad == NULL, , "invalid parameter");
+       retif(ad->list == NULL, , "invalid parameter");
+
+       if (evas_object_freeze_events_get(ad->scroller)) {
+               INFO("VIM unfreezing");
+               evas_object_freeze_events_set(ad->scroller, EINA_FALSE);
+       }
+}
+
+static void _vi_restart_job_cb(void *data)
+{
+       QP_VI *next_vi = NULL;
+       QP_VI *user_vi = NULL;
+
+       next_vi = _vi_list_get_first();
+
+       if (next_vi != NULL && next_vi->disable_interrupt_userevent == 0) {
+               while ((user_vi = _vi_user_event_list_get_first()) != NULL) {
+                       if (user_vi->interrupt_cb != NULL) {
+                               user_vi->interrupt_cb(user_vi);
+                               user_vi->state = VI_STATE_INTERRUPTED;
+                       }
+                       quickpanel_vi_user_event_del(user_vi);
+               }
+       }
+
+       if (_vim_get_state() == VIM_STATE_READY) {
+               next_vi = _vi_list_get_first();
+
+               if (next_vi) {
+                       if (next_vi->job_cb != NULL) {
+                               _vim_set_state(VIM_STATE_WORKING);
+                               next_vi->state = VI_STATE_RUNNING;
+                               next_vi->job_cb(next_vi);
+                       }
+               }
+       } else if (_vim_get_state() == VIM_STATE_SUSPENDED
+                       || _vim_get_state() == VIM_STATE_NOT_READY){
+               while ((next_vi = _vi_list_get_first()) != NULL) {
+                       quickpanel_vi_done(next_vi);
+               }
+       }
+}
+
+static void _vi_list_add(QP_VI *new_vi)
+{
+       retif(new_vi == NULL, ,"invalid parameter");
+
+       s_info.vi_list = eina_list_append(s_info.vi_list, new_vi);
+}
+
+static int _vi_list_count(void)
+{
+       retif(s_info.vi_list == NULL, 0, "list null");
+
+       return eina_list_count(s_info.vi_list);
+}
+
+static void _vi_list_del(QP_VI *vi)
+{
+       retif(vi == NULL, ,"invalid parameter");
+
+       s_info.vi_list = eina_list_remove(s_info.vi_list, vi);
+}
+
+static int _vi_list_is_data_valid(void *node)
+{
+       if (eina_list_data_find(s_info.vi_list, node) != NULL) {
+               return 1;
+       }
+
+       return 0;
+}
+
+static QP_VI *_vi_list_get_first(void)
+{
+       QP_VI *vi = eina_list_nth(s_info.vi_list, 0);
+
+       return vi;
+}
+
+static QP_VI *_vi_user_event_list_get_first(void)
+{
+       QP_VI *vi = eina_list_nth(s_info.vi_user_event_list, 0);
+
+       return vi;
+}
+
+HAPI QP_VI *quickpanel_vi_new(void)
+{
+       QP_VI *vi = (QP_VI *)calloc(1, sizeof(QP_VI));
+
+       retif(vi == NULL, NULL, "failed to memory allocation");
+
+       return vi;
+}
+
+HAPI QP_VI *quickpanel_vi_new_with_data(qp_vi_op_type op_type, qp_item_type_e item_type, void *container, void *target, vi_cb init_cb, vi_cb job_cb, vi_cb done_cb, vi_cb interrupt_cb, void *extra_data_1, void *extra_data_2, int extra_flag_1, int extra_flag_2)
+{
+       QP_VI *vi = (QP_VI *)calloc(1, sizeof(QP_VI));
+
+       retif(vi == NULL, NULL, "failed to memory allocation");
+
+       DBG("");
+
+       vi->state = VI_STATE_NOT_READY;
+       vi->op_type = op_type;
+       vi->item_type = item_type;
+       vi->container = container;
+       vi->target = target;
+       vi->init_cb = init_cb;
+       vi->job_cb = job_cb;
+       vi->done_cb = done_cb;
+       vi->interrupt_cb = interrupt_cb;
+       vi->extra_data_1 = extra_data_1;
+       vi->extra_data_2 = extra_data_2;
+       vi->extra_flag_1 = extra_flag_1;
+       vi->extra_flag_2 = extra_flag_2;
+
+       return vi;
+}
+
+HAPI void quickpanel_vi_start(QP_VI *vi)
+{
+       retif(vi == NULL, , "vi is NULL");
+
+       /*
+        * workaround - turn off mapbuf
+        * if mapbuf is enabled, geometry information from object become invalid
+        */
+       quickpanel_pager_mapbuf_set(0);
+
+       if (vi->init_cb != NULL) {
+               vi->init_cb(vi);
+       }
+
+       vi->state = VI_STATE_READY;
+
+       if (vi->disable_freezing == 0) {
+               _vi_freeze_start();
+       }
+       _vi_list_add(vi);
+       if (vi->target != NULL) {
+               evas_object_ref(vi->target);
+               if (vi->op_type == VI_OP_DELETE) {
+                       evas_object_freeze_events_set(vi->target, EINA_TRUE);
+               }
+       }
+       if (_vim_get_state() == VIM_STATE_NOT_READY) {
+               _vi_restart_job_cb(NULL);
+       } else {
+               ecore_job_add(_vi_restart_job_cb, NULL);
+       }
+}
+
+HAPI void quickpanel_vi_interrupt(QP_VI *vi)
+{
+       retif(vi == NULL, , "vi is NULL");
+
+       if (!_vi_list_is_data_valid(vi)) {
+               return;
+       }
+
+       _vi_list_del(vi);
+
+       if (vi->interrupt_cb != NULL) {
+               vi->interrupt_cb(vi);
+               vi->state = VI_STATE_INTERRUPTED;
+       }
+
+       if (s_info.current == vi) {
+               s_info.current = NULL;
+       }
+       if (_vim_get_state() == VIM_STATE_WORKING) {
+               if (!quickpanel_uic_is_opened()) {
+                       _vim_set_state(VIM_STATE_SUSPENDED);
+               } else {
+                       _vim_set_state(VIM_STATE_READY);
+               }
+       }
+
+       evas_object_unref(vi->target);
+       free(vi);
+
+       if (_vi_list_count() <= 0) {
+               _vi_freeze_stop();
+       }
+
+       ecore_job_add(_vi_restart_job_cb, NULL);
+}
+
+HAPI void quickpanel_vi_done(QP_VI *vi)
+{
+       retif(vi == NULL, , "vi is NULL");
+
+       if (!_vi_list_is_data_valid(vi)) {
+               return;
+       }
+
+       _vi_list_del(vi);
+
+       if (vi->done_cb != NULL) {
+               vi->done_cb(vi);
+               vi->state = VI_STATE_DONE;
+       }
+
+       if (s_info.current == vi) {
+               s_info.current = NULL;
+       }
+       if (_vim_get_state() == VIM_STATE_WORKING) {
+               if (!quickpanel_uic_is_opened()) {
+                       _vim_set_state(VIM_STATE_SUSPENDED);
+               } else {
+                       _vim_set_state(VIM_STATE_READY);
+               }
+       }
+
+       evas_object_unref(vi->target);
+       free(vi);
+
+       if (_vi_list_count() <= 0) {
+               _vi_freeze_stop();
+       }
+
+       ecore_job_add(_vi_restart_job_cb, NULL);
+}
+
+HAPI void quickpanel_vi_done_cb_for_transit(void *data, Elm_Transit *transit)
+{
+       retif(data == NULL, , "data is NULL");
+
+       quickpanel_vi_done(data);
+}
+
+HAPI void quickpanel_vim_set_state_ready(void)
+{
+       if (!quickpanel_uic_is_opened()) {
+               _vim_set_state(VIM_STATE_SUSPENDED);
+       } else {
+               _vim_set_state(VIM_STATE_READY);
+       }
+}
+
+HAPI void quickpanel_vim_set_state_suspend(void)
+{
+       _vim_set_state(VIM_STATE_SUSPENDED);
+}
+
+#define VIM_DURATION_INSERT 0.17
+#define VIM_DURATION_UPDATE 0.17
+#define VIM_DURATION_DELETE 0.17
+#define VIM_DURATION_REORDER 0.25
+#define VIM_THROTTLE_THRESHOLD 5
+
+HAPI double quickpanel_vim_get_duration(qp_vi_op_type op_type)
+{
+       int count = 0;
+       double duration = 0.0;
+
+       switch (op_type) {
+       case VI_OP_INSERT:
+               duration =  VIM_DURATION_INSERT;
+               break;
+       case VI_OP_UPDATE:
+               duration =  VIM_DURATION_UPDATE;
+               break;
+       case VI_OP_DELETE:
+               duration =  VIM_DURATION_DELETE;
+               break;
+       case VI_OP_REORDER:
+               duration =  VIM_DURATION_REORDER;
+               break;
+       default :
+               duration = VIM_DURATION_INSERT;
+               break;
+       }
+
+       if ((count = _vi_list_count()) > VIM_THROTTLE_THRESHOLD) {
+               duration = duration * (1.0 / (double)count);
+       }
+
+       return duration;
+}
+
+HAPI Elm_Transit_Tween_Mode quickpanel_vim_get_tweenmode(qp_vi_op_type op_type)
+{
+       Elm_Transit_Tween_Mode mode = ELM_TRANSIT_TWEEN_MODE_LINEAR;
+
+       switch (op_type) {
+               case VI_OP_INSERT:
+                       mode =  ELM_TRANSIT_TWEEN_MODE_DECELERATE;
+                       break;
+               case VI_OP_UPDATE:
+                       mode =  ELM_TRANSIT_TWEEN_MODE_DECELERATE;
+                       break;
+               case VI_OP_DELETE:
+                       mode =  ELM_TRANSIT_TWEEN_MODE_ACCELERATE;
+                       break;
+               case VI_OP_REORDER:
+                       mode =  ELM_TRANSIT_TWEEN_MODE_SINUSOIDAL;
+                       break;
+               default :
+                       mode = ELM_TRANSIT_TWEEN_MODE_LINEAR;
+                       break;
+       }
+
+       return mode;
+}
+
+/*****************************************************************************
+ *
+ * Util functions
+ *
+ *****************************************************************************/
+static int _init(void *data)
+{
+       struct appdata *ad = (struct appdata *)data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+       _vim_set_state(VIM_STATE_NOT_READY);
+
+       return QP_OK;
+}
+
+static int _fini(void *data)
+{
+       struct appdata *ad = (struct appdata *)data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+       _vim_set_state(VIM_STATE_NOT_READY);
+
+       return QP_OK;
+}
+
+static int _resume(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, QP_FAIL, "Invalid parameter!");
+
+       if (_vim_get_state() == VIM_STATE_SUSPENDED) {
+               _vim_set_state(VIM_STATE_READY);
+       }
+
+       return QP_OK;
+}
+
+static void _qp_opened(void *data)
+{
+       struct appdata *ad = data;
+       retif(ad == NULL, , "Invalid parameter!");
+
+       if (_vim_get_state() == VIM_STATE_SUSPENDED) {
+               _vim_set_state(VIM_STATE_READY);
+       }
+}
+
+HAPI void quickpanel_vi_user_event_add(QP_VI *new_vi)
+{
+       retif(new_vi == NULL, ,"invalid parameter");
+
+       s_info.vi_user_event_list = eina_list_append(s_info.vi_user_event_list, new_vi);
+}
+
+HAPI void quickpanel_vi_user_event_del(QP_VI *vi)
+{
+       retif(vi == NULL, ,"invalid parameter");
+
+       if (eina_list_data_find(s_info.vi_user_event_list, vi) != NULL) {
+               s_info.vi_user_event_list = eina_list_remove(s_info.vi_user_event_list, vi);
+               free(vi);
+       }
+}
+
+HAPI void quickpanel_vi_object_event_freeze_set(Evas_Object *obj, Eina_Bool freeze)
+{
+       retif(obj == NULL, ,"invalid parameter");
+
+       evas_object_freeze_events_set(obj, freeze);
+}
diff --git a/daemon/vi/vi_manager.h b/daemon/vi/vi_manager.h
new file mode 100755 (executable)
index 0000000..ace6afd
--- /dev/null
@@ -0,0 +1,89 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __QUICKPANEL_VI_MANAGER_H__
+#define __QUICKPANEL_VI_MANAGER_H__
+
+
+typedef Eina_Bool (*vi_cb)(void *data);
+
+typedef enum _qp_vim_state_type {
+       VIM_STATE_NOT_READY = 0,
+       VIM_STATE_READY,
+       VIM_STATE_WORKING,
+       VIM_STATE_SUSPENDED,
+} qp_vim_state_type;
+
+typedef enum _qp_vi_state_type {
+       VI_STATE_NOT_READY = 0,
+       VI_STATE_READY = 1,
+       VI_STATE_RUNNING,
+       VI_STATE_DONE,
+       VI_STATE_INTERRUPTED,
+} qp_vi_state_type;
+
+typedef enum _qp_vi_op_type {
+       VI_OP_NONE = -1,
+       VI_OP_INSERT = 0,
+       VI_OP_UPDATE,
+       VI_OP_DELETE,
+       VI_OP_DELETE_ALL,
+       VI_OP_REORDER,
+       VI_OP_ROTATION,
+       VI_OP_RESIZE,
+} qp_vi_op_type;
+
+typedef struct _QP_VI {
+       qp_vi_state_type state;
+       qp_vi_op_type op_type;
+       qp_item_type_e item_type;
+       void *container;
+       void *target;
+       vi_cb init_cb;
+       vi_cb job_cb;
+       vi_cb done_cb;
+       vi_cb interrupt_cb;
+       int disable_interrupt_userevent;
+       int disable_freezing;
+       void *extra_data_1;
+       void *extra_data_2;
+       int extra_flag_1;
+       int extra_flag_2;
+} QP_VI;
+
+typedef  struct _qp_vi_op_table {
+       qp_vi_op_type op_type;
+       void (*handler)(void *data);
+} qp_vi_op_table;
+
+extern QP_VI *quickpanel_vi_new(void);
+extern QP_VI *quickpanel_vi_new_with_data(qp_vi_op_type op_type, qp_item_type_e item_type, void *container, void *target, vi_cb init_cb, vi_cb job_cb, vi_cb done_cb, vi_cb interrupt_cb, void *extra_data_1, void *extra_data_2, int extra_flag_1, int extra_flag_2);
+extern void quickpanel_vi_start(QP_VI *vi);
+extern void quickpanel_vi_interrupt(QP_VI *vi);
+extern void quickpanel_vi_done(QP_VI *vi);
+extern void quickpanel_vim_set_state_ready(void);
+extern void quickpanel_vim_set_state_suspend(void);
+extern double quickpanel_vim_get_duration(qp_vi_op_type op_type);
+extern void quickpanel_vi_done_cb_for_transit(void *data, Elm_Transit *transit);
+extern Elm_Transit_Tween_Mode quickpanel_vim_get_tweenmode(qp_vi_op_type op_type);
+
+extern void quickpanel_vi_user_event_add(QP_VI *vi);
+extern void quickpanel_vi_user_event_del(QP_VI *vi);
+extern void quickpanel_vi_object_event_freeze_set(Evas_Object *obj, Eina_Bool freeze);
+
+#endif
diff --git a/daemon/voice_control.c b/daemon/voice_control.c
new file mode 100755 (executable)
index 0000000..56f95c4
--- /dev/null
@@ -0,0 +1,213 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#include <Elementary.h>
+
+#include <voice_control_setting.h>
+#include <app_control_internal.h>
+#include <tzsh.h>
+#include <tzsh_quickpanel_service.h>
+#include <E_DBus.h>
+
+#include "common.h"
+#include "common_uic.h"
+#include "voice_control.h"
+#include "quickpanel-ui.h"
+#include "list_util.h"
+
+
+static int _init(void *data);
+static int _fini(void *data);
+Evas_Object* _voice_control_view_create(void *data);
+static void _voice_control_register_event(void *data);
+static bool _check_voice_control_enabled(void);
+
+QP_Module voice_control = {
+       .name = "voice_control",
+       .init = _init,
+       .fini = _fini,
+       .suspend = NULL,
+       .resume = NULL,
+       .hib_enter = NULL,
+       .hib_leave = NULL,
+       .lang_changed = NULL,
+       .refresh = NULL,
+       .get_height = NULL,
+       .qp_opened = NULL,
+       .qp_closed = NULL,
+};
+
+static Evas_Object *g_layout = NULL;
+
+static void _voice_control_view_destroy(void *data)
+{
+       DBG("_voice_control_view_destroy");
+       struct appdata *ad = data;
+
+       if (ad == NULL)
+       {
+               ERR("invalid data");
+               return;
+       }
+
+       if (g_layout == NULL)
+       {
+               ERR("g_layout is not exist");
+               return;
+       }
+
+       quickpanel_list_util_item_unpack_by_object(ad->list, g_layout, 0, 0);
+       quickpanel_list_util_item_del_tag(g_layout);
+       elm_object_signal_emit(ad->ly, "voice_icon.hide", "quickpanel.prog");
+
+       if (g_layout != NULL) {
+               evas_object_del(g_layout);
+               g_layout = NULL;
+       }
+}
+
+static int _init(void *data)
+{
+       struct appdata *ad = (struct appdata *)data;
+
+       if (0 != vc_setting_initialize()) {
+               ERR("Fail to init");
+               return QP_FAIL;
+       }
+
+       _voice_control_register_event(data);
+
+       if (_check_voice_control_enabled()) { //when module restart
+               _voice_control_view_create(ad);
+       }
+
+       return QP_OK;
+}
+
+static int _fini(void *data)
+{
+       struct appdata *ad = (struct appdata *)data;
+
+       if (0 != vc_setting_deinitialize()) {
+               ERR("Fail to vc_setting_deinitialize");
+       }
+
+       _voice_control_view_destroy(ad);
+
+       return QP_OK;
+}
+
+static void _vc_enabled_changed_cb(bool enabled, void* user_data)
+{
+       DBG("_vc_enabled_changed_cb");
+       struct appdata *ad = user_data;
+
+       if( !enabled ) { //deactivated voice controller
+               _voice_control_view_destroy(ad);
+       } else {
+               _voice_control_view_create(ad);
+       }
+}
+
+static void _voice_control_register_event(void *data)
+{
+       DBG("_voice_control_register_event");
+       if (0 != vc_setting_set_enabled_changed_cb(_vc_enabled_changed_cb, data)) {
+               ERR("Fail to set enabled cb");
+               return;
+       }
+}
+
+static bool _check_voice_control_enabled(void)
+{
+       bool enabled = false;
+
+       if (0 != vc_setting_get_enabled(&enabled)) {
+               ERR("Fail to get enabled");
+       }
+       DBG("_check_voice_control_enabled enabled %d",enabled);
+
+       return enabled;
+}
+
+static void _button_clicked_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
+{
+       DBG("_button_clicked_cb");
+       int ret = 0;
+       quickpanel_uic_launch_ug_by_appcontrol(VOICE_CONTOL_REF_APP, NULL);
+       quickpanel_uic_launch_app_inform_result(VOICE_CONTOL_REF_APP, ret);
+       quickpanel_uic_close_quickpanel(true, 1);
+
+}
+
+Evas_Object* _voice_control_view_create(void *data)
+{
+       DBG("_voice_control_view_create");
+       struct appdata *ad = data;
+       Evas_Object *layout = NULL;
+       Eina_Bool ret = EINA_FALSE;
+
+       if (!_check_voice_control_enabled()) {
+               ERR("voice control is not enabled.");
+               return layout;
+       }
+       if (ad->win == NULL)
+       {
+               ERR("invalid parent");
+               return layout;
+       }
+
+       if (g_layout)
+       {
+               ERR("voice control view is already created.");
+               return g_layout;
+       }
+
+       layout = elm_layout_add(ad->win);
+       if (layout == NULL)
+       {
+               ERR("Failed to create voice control layout");
+               return layout;
+       }
+
+       g_layout = layout;
+
+       ret = elm_layout_file_set(layout, VOICE_CONTOL_EDJ, "quickpanel/voice_control/default");
+       if (ret == EINA_FALSE)
+       {
+               ERR("Failed to set layout file[%d]", ret);
+               evas_object_del(layout);
+               return NULL;
+       }
+
+       evas_object_size_hint_weight_set(layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+       evas_object_size_hint_align_set(layout, EVAS_HINT_FILL, EVAS_HINT_FILL);
+       evas_object_show(layout);
+
+       elm_object_signal_callback_add(layout, "button_clicked" , "", _button_clicked_cb, ad);
+       elm_object_signal_emit(ad->ly, "voice_icon.show", "quickpanel.prog");
+
+       // attach to list
+       qp_item_data *qid = quickpanel_list_util_item_new(QP_ITEM_TYPE_VOICE_CONTOL, layout);
+       quickpanel_list_util_item_set_tag(layout, qid);
+       quickpanel_list_util_sort_insert(ad->list, layout);
+       quickpanel_uic_initial_resize(layout, QP_VOICE_CONTOL_HEIGHT);
+
+       return layout;
+}
+
diff --git a/daemon/voice_control.h b/daemon/voice_control.h
new file mode 100755 (executable)
index 0000000..d1ef423
--- /dev/null
@@ -0,0 +1,31 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef VOICE_CONTROL_VIEW_H_
+#define VOICE_CONTROL_VIEW_H_
+
+
+#define EDJE_DIR "/usr/apps/org.tizen.quickpanel/res/edje/"
+#define VOICE_CONTOL_EDJ       EDJE_DIR"/quickpanel_voice_control.edj"
+
+#define QP_VOICE_CONTOL_HEIGHT 80
+#define VOICE_CONTOL_REF_APP "org.tizen.voice-control-panel"
+
+
+#endif /* VOICE_CONTROL_VIEW_H_ */
+
diff --git a/data/CMakeLists.txt b/data/CMakeLists.txt
new file mode 100755 (executable)
index 0000000..6e3471d
--- /dev/null
@@ -0,0 +1,50 @@
+INSTALL(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/icons DESTINATION ${RESDIR} FILES_MATCHING PATTERN "*.png")
+#CONFIGURE_FILE(${PROJECT_NAME}.desktop.in ${CMAKE_CURRENT_BINARY_DIR}/org.tizen.${PROJECT_NAME}.desktop)
+#INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/org.tizen.${PROJECT_NAME}.desktop DESTINATION ${DESKTOPDIR})
+CONFIGURE_FILE(${PROJECT_NAME}.xml.in ${CMAKE_CURRENT_BINARY_DIR}/org.tizen.${PROJECT_NAME}.xml)
+INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/org.tizen.${PROJECT_NAME}.xml DESTINATION ${MANIFESTXMLDIR})
+CONFIGURE_FILE(${PROJECT_NAME}.sh.in ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME})
+INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME} DESTINATION /etc/init.d/)
+
+MESSAGE("EDJE_CC CUSTOM FLAG : ${EDJEFLAGS}")
+
+ADD_CUSTOM_TARGET(quickpanel.edj
+               COMMAND edje_cc -id ${CMAKE_CURRENT_SOURCE_DIR}/images_icon  -id ${CMAKE_CURRENT_SOURCE_DIR}/images "${EDJEFLAGS}"
+               ${CMAKE_CURRENT_SOURCE_DIR}/quickpanel.edc
+               ${CMAKE_CURRENT_BINARY_DIR}/quickpanel.edj
+               DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/quickpanel.edc
+)
+ADD_DEPENDENCIES(${PROJECT_NAME} quickpanel.edj)
+
+ADD_CUSTOM_TARGET(quickpanel_activenoti.edj
+                COMMAND edje_cc -id ${CMAKE_CURRENT_SOURCE_DIR}/images_icon  -id ${CMAKE_CURRENT_SOURCE_DIR}/images "${EDJEFLAGS}"
+                ${CMAKE_CURRENT_SOURCE_DIR}/quickpanel_activenoti.edc
+                ${CMAKE_CURRENT_BINARY_DIR}/quickpanel_activenoti.edj
+                DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/quickpanel_activenoti.edc
+)
+ADD_DEPENDENCIES(${PROJECT_NAME} quickpanel_activenoti.edj)
+
+ADD_CUSTOM_TARGET(quickpanel_voice_control.edj
+                COMMAND edje_cc -id ${CMAKE_CURRENT_SOURCE_DIR}/images_icon  -id ${CMAKE_CURRENT_SOURCE_DIR}/images "${EDJEFLAGS}"
+                ${CMAKE_CURRENT_SOURCE_DIR}/quickpanel_voice_control.edc
+                ${CMAKE_CURRENT_BINARY_DIR}/quickpanel_voice_control.edj
+                DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/quickpanel_voice_control.edc
+)
+ADD_DEPENDENCIES(${PROJECT_NAME} quickpanel_voice_control.edj)
+
+
+
+ADD_CUSTOM_TARGET(quickpanel_theme.edj
+               COMMAND edje_cc -id ${CMAKE_CURRENT_SOURCE_DIR}/images_icon -id ${CMAKE_CURRENT_SOURCE_DIR}/images "${EDJEFLAGS}"
+               ${CMAKE_CURRENT_SOURCE_DIR}/quickpanel_theme.edc
+               ${CMAKE_CURRENT_BINARY_DIR}/quickpanel_theme.edj
+               DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/quickpanel_theme.edc
+)
+ADD_DEPENDENCIES(${PROJECT_NAME} quickpanel_theme.edj)
+
+INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/quickpanel.edj DESTINATION ${EDJDIR})
+INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/quickpanel_activenoti.edj DESTINATION ${EDJDIR})
+INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/quickpanel_voice_control.edj DESTINATION ${EDJDIR})
+INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/quickpanel_theme.edj DESTINATION ${EDJDIR})
+INSTALL(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/icons DESTINATION ${RESDIR} FILES_MATCHING PATTERN "*.png")
+
diff --git a/data/color_classes.edc b/data/color_classes.edc
new file mode 100755 (executable)
index 0000000..537d513
--- /dev/null
@@ -0,0 +1,407 @@
+/*
+* Samsung API
+* Copyright (c) 2009-2015 Samsung Electronics Co., Ltd.
+*
+* Licensed under the Apache License, Version 2.0 (the License);
+* you may not use this file except in compliance with the License.
+* You may obtain a copy of the License at
+*
+* http://www.apache.org/license/
+*
+* Unless required by applicable law or agreed to in writing, software
+* distributed under the License is distributed on an AS IS BASIS,
+* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+* See the License for the specific language governing permissions and
+* limitations under the License.
+*/
+
+color_classes {
+       color_class {
+               name: "AO007L1";
+               color: 18 75 107 255;
+       }
+       color_class {
+               name: "AO007L2";
+               color: 255 255 255 51;
+       }
+       color_class {
+               name: "AO021P";
+               color: 20 107 147 76;
+       }
+       color_class {
+               name: "AO025";
+               color: 255 255 255 255;
+       }
+       color_class {
+               name: "AO027";
+               color: 255 255 255 76;
+       }
+       color_class {
+               name: "AO033";
+               color: 0 0 0 12;
+       }
+       color_class {
+               name: "AO001L1";
+               color: 18 75 107 255;
+       }
+       color_class {
+               name: "AO001L1D";
+               color: 18 75 107 127;
+       }
+       color_class {
+               name: "AO001L1P";
+               color: 15 60 89 255;
+       }
+       color_class {
+               name: "AO002";
+               color: 159 239 0 255;
+       }
+       color_class {
+               name: "AO003";
+               color: 255 255 255 127;
+       }
+       color_class {
+               name: "AO003D";
+               color: 255 255 255 76;
+       }
+       color_class {
+               name: "AO003E1";
+               color: 255 255 255 165;
+       }
+       color_class {
+               name: "AO004";
+               color: 255 255 255 255;
+       }
+       color_class {
+               name: "AO004D";
+               color: 88 144 170 255;
+       }
+       color_class {
+               name: "AO005L2";
+               color: 255 255 255 255;
+       }
+       color_class {
+               name: "AO005L1";
+               color: 16 81 112 255;
+       }
+       color_class {
+               name: "AO005L1D";
+               color: 178 178 178 76;
+       }
+       color_class {
+               name: "AO005L3";
+               color: 255 255 255 255;
+       }
+       color_class {
+               name: "AO005L4";
+               color: 255 255 255 51;
+       }
+       color_class {
+               name: "AO008";
+               color: 255 255 255 255;
+       }
+       color_class {
+               name: "AO010";
+               color: 224 33 33 255;
+       }
+       color_class {
+               name: "AO031";
+               color: 20 107 147 255;
+       }
+       color_class {
+               name: "AO032";
+               color: 255 255 255 255;
+       }
+       color_class {
+               name: "AO011L1";
+               color: 20 107 147 153;
+       }
+       color_class {
+               name: "AO011L1P";
+               color: 66 162 206 255;
+       }
+       color_class {
+               name: "AO011L1D";
+               color: 20 107 147 153;
+       }
+       color_class {
+               name: "AO011L1E01";
+               color: 20 107 147 255;
+       }
+       color_class {
+               name: "AO011i";
+               color: 255 255 255 255;
+       }
+       color_class {
+               name: "AO011iD";
+               color: 255 255 255 127;
+       }
+       color_class {
+               name: "AO011L3";
+               color: 48 48 48 255;
+       }
+       color_class {
+               name: "AO011L3P";
+               color: 20 107 147 255;
+       }
+       color_class {
+               name: "AO011L3D";
+               color: 48 48 48 76;
+       }
+       color_class {
+               name: "AO0111i";
+               color: 224 33 33 255;
+       }
+       color_class {
+               name: "AO0111";
+               color: 20 107 147 153;
+       }
+       color_class {
+               name: "AO012L1";
+               color: 82 196 11 255;
+       }
+       color_class {
+               name: "AO012L1P";
+               color: 66 158 9 255;
+       }
+       color_class {
+               name: "AO012L1D";
+               color: 106 196 51 255;
+       }
+       color_class {
+               name: "AO013L1";
+               color: 249 56 22 255;
+       }
+       color_class {
+               name: "AO013L1P";
+               color: 211 47 19 255;
+       }
+       color_class {
+               name: "AO013L1D";
+               color: 249 56 22 58;
+       }
+       color_class {
+               name: "AO014L1";
+               color: 20 107 147 255;
+       }
+       color_class {
+               name: "AO014L1P";
+               color: 11 61 84 255;
+       }
+       color_class {
+               name: "AO014L1D";
+               color: 50 116 147 255;
+       }
+       color_class {
+               name: "AO014";
+               color: 255 255 255 255;
+       }
+       color_class {
+               name: "AO014P";
+               color: 255 255 255 255;
+       }
+       color_class {
+               name: "AO014D";
+               color: 255 255 255 102;
+       }
+       color_class {
+               name: "AO015";
+               color: 159 239 0 255;
+       }
+       color_class {
+               name: "AO015P";
+               color: 159 239 0 255;
+       }
+       color_class {
+               name: "AO015D";
+               color: 159 239 0 102;
+       }
+       color_class {
+               name: "AO016";
+               color: 255 255 255 255;
+       }
+       color_class {
+               name: "AO016P";
+               color: 255 255 255 255;
+       }
+       color_class {
+               name: "AO016D";
+               color: 255 255 255 102;
+       }
+       color_class {
+               name: "AO019";
+               color: 66 162 206 255;
+       }
+       color_class {
+               name: "AO020";
+               color: 170 172 175 255;
+       }
+       color_class {
+               name: "AO029";
+               color: 24 126 173 204;
+       }
+       color_class {
+               name: "AO029P";
+               color: 20 107 147 255;
+       }
+       color_class {
+               name: "AO029D";
+               color: 0 0 0 76;
+       }
+       color_class {
+               name: "AO030E1";
+               color: 0 126 181 255;
+       }
+       color_class {
+               name: "AO030E2";
+               color: 148 39 170 255;
+       }
+       color_class {
+               name: "AO030E3";
+               color: 58 66 71 255;
+       }
+       color_class {
+               name: "AO030E4";
+               color: 247 187 7 255;
+       }
+       color_class {
+               name: "AO030E5";
+               color: 242 98 2 255;
+       }
+       color_class {
+               name: "AO030E6";
+               color: 26 49 124 255;
+       }
+       color_class {
+               name: "AO030E7";
+               color: 0 150 100 255;
+       }
+       color_class {
+               name: "AO030E8";
+               color: 232 69 156 255;
+       }
+       color_class {
+               name: "AO030E9";
+               color: 83 175 26 255;
+       }
+       color_class {
+               name: "AO030D";
+               color: 0 0 0 76;
+       }
+       color_class {
+               name: "AO010S";
+               color: 20 107 147 255;
+       }
+       color_class {
+               name: "ATO008";
+               color: 255 255 255 255;
+       }
+       color_class {
+               name: "ATO0081";
+               color: 255 255 255 255;
+       }
+       color_class {
+               name: "ATO009";
+               color: 255 255 255 255;
+       }
+       color_class {
+               name: "ATO016";
+               color: 255 255 255 255;
+       }
+       color_class {
+               name: "ATO019";
+               color: 255 255 255 255;
+       }
+       color_class {
+               name: "ATO017";
+               color: 255 255 255 255;
+       }
+       color_class {
+               name: "ATO006P";
+               color: 20 107 147 255;
+       }
+       color_class {
+               name: "ATO006D";
+               color: 20 107 147 127;
+       }
+       color_class {
+               name: "ATO005";
+               color: 0 0 0 255;
+       }
+       color_class {
+               name: "ATO006";
+               color: 76 76 76 255;
+       }
+       color_class {
+               name: "ATO007E1";
+               color: 0 126 181 255;
+       }
+       color_class {
+               name: "ATO007E2";
+               color: 148 39 170 255;
+       }
+       color_class {
+               name: "ATO007E3";
+               color: 58 66 71 255;
+       }
+       color_class {
+               name: "ATO007E4";
+               color: 247 187 7 255;
+       }
+       color_class {
+               name: "ATO007E5";
+               color: 242 98 2 255;
+       }
+       color_class {
+               name: "ATO007E6";
+               color: 26 49 124 255;
+       }
+       color_class {
+               name: "ATO007E7";
+               color: 0 150 100 255;
+       }
+       color_class {
+               name: "ATO007E8";
+               color: 232 69 156 255;
+       }
+       color_class {
+               name: "ATO007E9";
+               color: 83 175 26 255;
+       }
+       color_class {
+               name: "ATO007D";
+               color: 76 76 76 255;
+       }
+       color_class {
+               name: "AO008_STATUS";
+               color: 18 75 107 255;
+       }
+       color_class {
+               name: "A03O003L1";
+               color:  61 185 204 255;
+       }
+       color_class {
+               name: "ATO012";
+               color: 128 128 128 255;
+       }
+       color_class {
+               name: "F043P";
+               color: 31 92 102 255;
+       }
+       color_class {
+               name: "T023";
+               color: 72 72 72 255;
+       }
+       color_class {
+               name: "B011";
+               color: 20 107 147 127;
+       }
+       color_class {
+               name: "B0517";
+               color: 147 147 147 255;
+       }
+       color_class {
+               name: "W0661";
+               color: 155 216 226 255;
+       }
+}
diff --git a/data/images/00_check_bg.png b/data/images/00_check_bg.png
new file mode 100755 (executable)
index 0000000..4105992
Binary files /dev/null and b/data/images/00_check_bg.png differ
diff --git a/data/images/00_check_bg_dim.png b/data/images/00_check_bg_dim.png
new file mode 100755 (executable)
index 0000000..4105992
Binary files /dev/null and b/data/images/00_check_bg_dim.png differ
diff --git a/data/images/00_check_bg_press.png b/data/images/00_check_bg_press.png
new file mode 100755 (executable)
index 0000000..365a256
Binary files /dev/null and b/data/images/00_check_bg_press.png differ
diff --git a/data/images/00_check_checking.png b/data/images/00_check_checking.png
new file mode 100755 (executable)
index 0000000..45fbafe
Binary files /dev/null and b/data/images/00_check_checking.png differ
diff --git a/data/images/00_check_checking_dim.png b/data/images/00_check_checking_dim.png
new file mode 100755 (executable)
index 0000000..45fbafe
Binary files /dev/null and b/data/images/00_check_checking_dim.png differ
diff --git a/data/images/00_divider_line.png b/data/images/00_divider_line.png
new file mode 100755 (executable)
index 0000000..fa2f19e
Binary files /dev/null and b/data/images/00_divider_line.png differ
diff --git a/data/images/00_progress_bar.png b/data/images/00_progress_bar.png
new file mode 100755 (executable)
index 0000000..1675b22
Binary files /dev/null and b/data/images/00_progress_bar.png differ
diff --git a/data/images/00_progress_bg.png b/data/images/00_progress_bg.png
new file mode 100755 (executable)
index 0000000..452e1d7
Binary files /dev/null and b/data/images/00_progress_bg.png differ
diff --git a/data/images/00_slider_handle.png b/data/images/00_slider_handle.png
new file mode 100755 (executable)
index 0000000..829373d
Binary files /dev/null and b/data/images/00_slider_handle.png differ
diff --git a/data/images/00_slider_handle_dim.png b/data/images/00_slider_handle_dim.png
new file mode 100755 (executable)
index 0000000..746f632
Binary files /dev/null and b/data/images/00_slider_handle_dim.png differ
diff --git a/data/images/00_slider_handle_press.png b/data/images/00_slider_handle_press.png
new file mode 100755 (executable)
index 0000000..8475715
Binary files /dev/null and b/data/images/00_slider_handle_press.png differ
diff --git a/data/images/B31_help_tap_1_default.png b/data/images/B31_help_tap_1_default.png
new file mode 100644 (file)
index 0000000..02a5914
Binary files /dev/null and b/data/images/B31_help_tap_1_default.png differ
diff --git a/data/images/B32_help_start_right_01.png b/data/images/B32_help_start_right_01.png
new file mode 100644 (file)
index 0000000..595a9ec
Binary files /dev/null and b/data/images/B32_help_start_right_01.png differ
diff --git a/data/images/B32_help_start_right_02.png b/data/images/B32_help_start_right_02.png
new file mode 100644 (file)
index 0000000..59a61eb
Binary files /dev/null and b/data/images/B32_help_start_right_02.png differ
diff --git a/data/images/B32_help_start_right_03.png b/data/images/B32_help_start_right_03.png
new file mode 100644 (file)
index 0000000..1c40e51
Binary files /dev/null and b/data/images/B32_help_start_right_03.png differ
diff --git a/data/images/B32_help_start_right_04.png b/data/images/B32_help_start_right_04.png
new file mode 100644 (file)
index 0000000..72362c9
Binary files /dev/null and b/data/images/B32_help_start_right_04.png differ
diff --git a/data/images/B32_notification_tray_effect_bg_01.png b/data/images/B32_notification_tray_effect_bg_01.png
new file mode 100644 (file)
index 0000000..9fb2081
Binary files /dev/null and b/data/images/B32_notification_tray_effect_bg_01.png differ
diff --git a/data/images/B32_notification_tray_effect_l_bg.png b/data/images/B32_notification_tray_effect_l_bg.png
new file mode 100644 (file)
index 0000000..61bb4bc
Binary files /dev/null and b/data/images/B32_notification_tray_effect_l_bg.png differ
diff --git a/data/images/Q02_quickpanel_button_nomal_01_center.png b/data/images/Q02_quickpanel_button_nomal_01_center.png
new file mode 100755 (executable)
index 0000000..69c5b73
Binary files /dev/null and b/data/images/Q02_quickpanel_button_nomal_01_center.png differ
diff --git a/data/images/Q02_quickpanel_button_nomal_01_left.png b/data/images/Q02_quickpanel_button_nomal_01_left.png
new file mode 100755 (executable)
index 0000000..4d35a98
Binary files /dev/null and b/data/images/Q02_quickpanel_button_nomal_01_left.png differ
diff --git a/data/images/Q02_quickpanel_button_nomal_01_right.png b/data/images/Q02_quickpanel_button_nomal_01_right.png
new file mode 100755 (executable)
index 0000000..ef53ed9
Binary files /dev/null and b/data/images/Q02_quickpanel_button_nomal_01_right.png differ
diff --git a/data/images/Q02_quickpanel_button_press_01_center.png b/data/images/Q02_quickpanel_button_press_01_center.png
new file mode 100755 (executable)
index 0000000..fcd401b
Binary files /dev/null and b/data/images/Q02_quickpanel_button_press_01_center.png differ
diff --git a/data/images/Q02_quickpanel_button_press_01_left.png b/data/images/Q02_quickpanel_button_press_01_left.png
new file mode 100755 (executable)
index 0000000..585e850
Binary files /dev/null and b/data/images/Q02_quickpanel_button_press_01_left.png differ
diff --git a/data/images/Q02_quickpanel_button_press_01_right.png b/data/images/Q02_quickpanel_button_press_01_right.png
new file mode 100755 (executable)
index 0000000..1e848c7
Binary files /dev/null and b/data/images/Q02_quickpanel_button_press_01_right.png differ
diff --git a/data/images/bg_pattern.png b/data/images/bg_pattern.png
new file mode 100755 (executable)
index 0000000..5ad9848
Binary files /dev/null and b/data/images/bg_pattern.png differ
diff --git a/data/images/bg_press.#.png b/data/images/bg_press.#.png
new file mode 100644 (file)
index 0000000..805ea78
Binary files /dev/null and b/data/images/bg_press.#.png differ
diff --git a/data/images/core_activity_Indicator_medium_00.png b/data/images/core_activity_Indicator_medium_00.png
new file mode 100644 (file)
index 0000000..37b7a90
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_00.png differ
diff --git a/data/images/core_activity_Indicator_medium_01.png b/data/images/core_activity_Indicator_medium_01.png
new file mode 100644 (file)
index 0000000..c14c54b
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_01.png differ
diff --git a/data/images/core_activity_Indicator_medium_02.png b/data/images/core_activity_Indicator_medium_02.png
new file mode 100644 (file)
index 0000000..693f8f2
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_02.png differ
diff --git a/data/images/core_activity_Indicator_medium_03.png b/data/images/core_activity_Indicator_medium_03.png
new file mode 100644 (file)
index 0000000..0270a40
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_03.png differ
diff --git a/data/images/core_activity_Indicator_medium_04.png b/data/images/core_activity_Indicator_medium_04.png
new file mode 100644 (file)
index 0000000..6fc5587
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_04.png differ
diff --git a/data/images/core_activity_Indicator_medium_05.png b/data/images/core_activity_Indicator_medium_05.png
new file mode 100644 (file)
index 0000000..ee5d96b
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_05.png differ
diff --git a/data/images/core_activity_Indicator_medium_06.png b/data/images/core_activity_Indicator_medium_06.png
new file mode 100644 (file)
index 0000000..46e3964
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_06.png differ
diff --git a/data/images/core_activity_Indicator_medium_07.png b/data/images/core_activity_Indicator_medium_07.png
new file mode 100644 (file)
index 0000000..93ebf9e
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_07.png differ
diff --git a/data/images/core_activity_Indicator_medium_08.png b/data/images/core_activity_Indicator_medium_08.png
new file mode 100644 (file)
index 0000000..8e4c688
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_08.png differ
diff --git a/data/images/core_activity_Indicator_medium_09.png b/data/images/core_activity_Indicator_medium_09.png
new file mode 100644 (file)
index 0000000..007218f
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_09.png differ
diff --git a/data/images/core_activity_Indicator_medium_10.png b/data/images/core_activity_Indicator_medium_10.png
new file mode 100644 (file)
index 0000000..75cb0f8
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_10.png differ
diff --git a/data/images/core_activity_Indicator_medium_11.png b/data/images/core_activity_Indicator_medium_11.png
new file mode 100644 (file)
index 0000000..5df320a
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_11.png differ
diff --git a/data/images/core_activity_Indicator_medium_12.png b/data/images/core_activity_Indicator_medium_12.png
new file mode 100644 (file)
index 0000000..c28de6b
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_12.png differ
diff --git a/data/images/core_activity_Indicator_medium_13.png b/data/images/core_activity_Indicator_medium_13.png
new file mode 100644 (file)
index 0000000..2fd2e51
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_13.png differ
diff --git a/data/images/core_activity_Indicator_medium_14.png b/data/images/core_activity_Indicator_medium_14.png
new file mode 100644 (file)
index 0000000..9e07a5d
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_14.png differ
diff --git a/data/images/core_activity_Indicator_medium_15.png b/data/images/core_activity_Indicator_medium_15.png
new file mode 100644 (file)
index 0000000..5fccce5
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_15.png differ
diff --git a/data/images/core_activity_Indicator_medium_16.png b/data/images/core_activity_Indicator_medium_16.png
new file mode 100644 (file)
index 0000000..5bdbcdd
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_16.png differ
diff --git a/data/images/core_activity_Indicator_medium_17.png b/data/images/core_activity_Indicator_medium_17.png
new file mode 100644 (file)
index 0000000..88becef
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_17.png differ
diff --git a/data/images/core_activity_Indicator_medium_18.png b/data/images/core_activity_Indicator_medium_18.png
new file mode 100644 (file)
index 0000000..ef23ee0
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_18.png differ
diff --git a/data/images/core_activity_Indicator_medium_19.png b/data/images/core_activity_Indicator_medium_19.png
new file mode 100644 (file)
index 0000000..e8a6dba
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_19.png differ
diff --git a/data/images/core_activity_Indicator_medium_20.png b/data/images/core_activity_Indicator_medium_20.png
new file mode 100644 (file)
index 0000000..79e50b1
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_20.png differ
diff --git a/data/images/core_activity_Indicator_medium_21.png b/data/images/core_activity_Indicator_medium_21.png
new file mode 100644 (file)
index 0000000..2f9f472
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_21.png differ
diff --git a/data/images/core_activity_Indicator_medium_22.png b/data/images/core_activity_Indicator_medium_22.png
new file mode 100644 (file)
index 0000000..9f77e60
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_22.png differ
diff --git a/data/images/core_activity_Indicator_medium_23.png b/data/images/core_activity_Indicator_medium_23.png
new file mode 100644 (file)
index 0000000..bea093d
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_23.png differ
diff --git a/data/images/core_activity_Indicator_medium_24.png b/data/images/core_activity_Indicator_medium_24.png
new file mode 100644 (file)
index 0000000..dcad32d
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_24.png differ
diff --git a/data/images/core_activity_Indicator_medium_25.png b/data/images/core_activity_Indicator_medium_25.png
new file mode 100644 (file)
index 0000000..46cdca2
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_25.png differ
diff --git a/data/images/core_activity_Indicator_medium_26.png b/data/images/core_activity_Indicator_medium_26.png
new file mode 100644 (file)
index 0000000..62071df
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_26.png differ
diff --git a/data/images/core_activity_Indicator_medium_27.png b/data/images/core_activity_Indicator_medium_27.png
new file mode 100644 (file)
index 0000000..55b2cab
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_27.png differ
diff --git a/data/images/core_activity_Indicator_medium_28.png b/data/images/core_activity_Indicator_medium_28.png
new file mode 100644 (file)
index 0000000..85868f5
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_28.png differ
diff --git a/data/images/core_activity_Indicator_medium_29.png b/data/images/core_activity_Indicator_medium_29.png
new file mode 100644 (file)
index 0000000..6e358a1
Binary files /dev/null and b/data/images/core_activity_Indicator_medium_29.png differ
diff --git a/data/images/core_icon_badge_container.#.png b/data/images/core_icon_badge_container.#.png
new file mode 100644 (file)
index 0000000..4f533f4
Binary files /dev/null and b/data/images/core_icon_badge_container.#.png differ
diff --git a/data/images/core_list_button_bg.#.png b/data/images/core_list_button_bg.#.png
new file mode 100644 (file)
index 0000000..db0c22d
Binary files /dev/null and b/data/images/core_list_button_bg.#.png differ
diff --git a/data/images/core_probress_bar.#.png b/data/images/core_probress_bar.#.png
new file mode 100644 (file)
index 0000000..568d39f
Binary files /dev/null and b/data/images/core_probress_bar.#.png differ
diff --git a/data/images/core_probress_bar.png b/data/images/core_probress_bar.png
new file mode 100644 (file)
index 0000000..5ed62da
Binary files /dev/null and b/data/images/core_probress_bar.png differ
diff --git a/data/images/core_probressbar_bg.#.png b/data/images/core_probressbar_bg.#.png
new file mode 100644 (file)
index 0000000..568d39f
Binary files /dev/null and b/data/images/core_probressbar_bg.#.png differ
diff --git a/data/images/core_progress_bar.#.png b/data/images/core_progress_bar.#.png
new file mode 100644 (file)
index 0000000..5ed62da
Binary files /dev/null and b/data/images/core_progress_bar.#.png differ
diff --git a/data/images/core_progress_bar.png b/data/images/core_progress_bar.png
new file mode 100644 (file)
index 0000000..5ed62da
Binary files /dev/null and b/data/images/core_progress_bar.png differ
diff --git a/data/images/core_progressbar_bg.#.png b/data/images/core_progressbar_bg.#.png
new file mode 100644 (file)
index 0000000..e19c598
Binary files /dev/null and b/data/images/core_progressbar_bg.#.png differ
diff --git a/data/images/core_progressbar_bg.png b/data/images/core_progressbar_bg.png
new file mode 100644 (file)
index 0000000..e19c598
Binary files /dev/null and b/data/images/core_progressbar_bg.png differ
diff --git a/data/images/core_slider_center_point_bg.png b/data/images/core_slider_center_point_bg.png
new file mode 100644 (file)
index 0000000..3acbdeb
Binary files /dev/null and b/data/images/core_slider_center_point_bg.png differ
diff --git a/data/images/core_slider_handle_normal.png b/data/images/core_slider_handle_normal.png
new file mode 100644 (file)
index 0000000..f612432
Binary files /dev/null and b/data/images/core_slider_handle_normal.png differ
diff --git a/data/images/core_slider_handle_press.png b/data/images/core_slider_handle_press.png
new file mode 100644 (file)
index 0000000..96a1a7c
Binary files /dev/null and b/data/images/core_slider_handle_press.png differ
diff --git a/data/images/core_theme_bg_01.png b/data/images/core_theme_bg_01.png
new file mode 100644 (file)
index 0000000..be3057d
Binary files /dev/null and b/data/images/core_theme_bg_01.png differ
diff --git a/data/images/handler_bg.#.png b/data/images/handler_bg.#.png
new file mode 100644 (file)
index 0000000..38bd634
Binary files /dev/null and b/data/images/handler_bg.#.png differ
diff --git a/data/images/handler_bg_ef.#.png b/data/images/handler_bg_ef.#.png
new file mode 100644 (file)
index 0000000..38db7ff
Binary files /dev/null and b/data/images/handler_bg_ef.#.png differ
diff --git a/data/images/handler_btn.png b/data/images/handler_btn.png
new file mode 100644 (file)
index 0000000..7f22db0
Binary files /dev/null and b/data/images/handler_btn.png differ
diff --git a/data/images/handler_btn_02.png b/data/images/handler_btn_02.png
new file mode 100644 (file)
index 0000000..f4fedc3
Binary files /dev/null and b/data/images/handler_btn_02.png differ
diff --git a/data/images/icon_arrow_down.png b/data/images/icon_arrow_down.png
new file mode 100644 (file)
index 0000000..46d3d7b
Binary files /dev/null and b/data/images/icon_arrow_down.png differ
diff --git a/data/images/icon_arrow_up.png b/data/images/icon_arrow_up.png
new file mode 100644 (file)
index 0000000..65fcac2
Binary files /dev/null and b/data/images/icon_arrow_up.png differ
diff --git a/data/images/icon_bg.png b/data/images/icon_bg.png
new file mode 100644 (file)
index 0000000..95ee1b4
Binary files /dev/null and b/data/images/icon_bg.png differ
diff --git a/data/images/icon_bg_press.png b/data/images/icon_bg_press.png
new file mode 100644 (file)
index 0000000..48c8c1c
Binary files /dev/null and b/data/images/icon_bg_press.png differ
diff --git a/data/images/icon_bg_small.png b/data/images/icon_bg_small.png
new file mode 100644 (file)
index 0000000..aaea3e7
Binary files /dev/null and b/data/images/icon_bg_small.png differ
diff --git a/data/images/icon_edit.png b/data/images/icon_edit.png
new file mode 100644 (file)
index 0000000..b48d4b2
Binary files /dev/null and b/data/images/icon_edit.png differ
diff --git a/data/images/icon_indicator_setting.png b/data/images/icon_indicator_setting.png
new file mode 100644 (file)
index 0000000..55b4d61
Binary files /dev/null and b/data/images/icon_indicator_setting.png differ
diff --git a/data/images/icon_press.png b/data/images/icon_press.png
new file mode 100755 (executable)
index 0000000..9102659
Binary files /dev/null and b/data/images/icon_press.png differ
diff --git a/data/images/icon_search.png b/data/images/icon_search.png
new file mode 100644 (file)
index 0000000..3210298
Binary files /dev/null and b/data/images/icon_search.png differ
diff --git a/data/images/icon_settings.png b/data/images/icon_settings.png
new file mode 100644 (file)
index 0000000..f890d51
Binary files /dev/null and b/data/images/icon_settings.png differ
diff --git a/data/images/line_indicator_divider.png b/data/images/line_indicator_divider.png
new file mode 100644 (file)
index 0000000..b818951
Binary files /dev/null and b/data/images/line_indicator_divider.png differ
diff --git a/data/images/notification_bg.png b/data/images/notification_bg.png
new file mode 100755 (executable)
index 0000000..5cf6c0d
Binary files /dev/null and b/data/images/notification_bg.png differ
diff --git a/data/images/quick_btn_close_dim.png b/data/images/quick_btn_close_dim.png
new file mode 100755 (executable)
index 0000000..af02c5d
Binary files /dev/null and b/data/images/quick_btn_close_dim.png differ
diff --git a/data/images/quick_btn_close_nor.png b/data/images/quick_btn_close_nor.png
new file mode 100755 (executable)
index 0000000..9041e29
Binary files /dev/null and b/data/images/quick_btn_close_nor.png differ
diff --git a/data/images/quick_btn_close_press.png b/data/images/quick_btn_close_press.png
new file mode 100755 (executable)
index 0000000..8eb09b8
Binary files /dev/null and b/data/images/quick_btn_close_press.png differ
diff --git a/data/images/quick_btn_close_white_dim.png b/data/images/quick_btn_close_white_dim.png
new file mode 100644 (file)
index 0000000..cac9843
Binary files /dev/null and b/data/images/quick_btn_close_white_dim.png differ
diff --git a/data/images/quick_btn_close_white_nor.png b/data/images/quick_btn_close_white_nor.png
new file mode 100644 (file)
index 0000000..476fe97
Binary files /dev/null and b/data/images/quick_btn_close_white_nor.png differ
diff --git a/data/images/quick_btn_close_white_press.png b/data/images/quick_btn_close_white_press.png
new file mode 100644 (file)
index 0000000..339a81e
Binary files /dev/null and b/data/images/quick_btn_close_white_press.png differ
diff --git a/data/images/quick_button_each_bg.png b/data/images/quick_button_each_bg.png
new file mode 100644 (file)
index 0000000..185839e
Binary files /dev/null and b/data/images/quick_button_each_bg.png differ
diff --git a/data/images/quick_button_each_bg_land.png b/data/images/quick_button_each_bg_land.png
new file mode 100644 (file)
index 0000000..89f8485
Binary files /dev/null and b/data/images/quick_button_each_bg_land.png differ
diff --git a/data/images/quick_button_each_ef.png b/data/images/quick_button_each_ef.png
new file mode 100644 (file)
index 0000000..57c76e4
Binary files /dev/null and b/data/images/quick_button_each_ef.png differ
diff --git a/data/images/quick_button_each_ef_land.png b/data/images/quick_button_each_ef_land.png
new file mode 100644 (file)
index 0000000..ab7ad43
Binary files /dev/null and b/data/images/quick_button_each_ef_land.png differ
diff --git a/data/images/quick_button_over.png b/data/images/quick_button_over.png
new file mode 100644 (file)
index 0000000..5dcd5cf
Binary files /dev/null and b/data/images/quick_button_over.png differ
diff --git a/data/images/quick_button_over_land.png b/data/images/quick_button_over_land.png
new file mode 100644 (file)
index 0000000..d77867f
Binary files /dev/null and b/data/images/quick_button_over_land.png differ
diff --git a/data/images/quick_handle.png b/data/images/quick_handle.png
new file mode 100644 (file)
index 0000000..8016b29
Binary files /dev/null and b/data/images/quick_handle.png differ
diff --git a/data/images/quick_handle_both.png b/data/images/quick_handle_both.png
new file mode 100755 (executable)
index 0000000..485a329
Binary files /dev/null and b/data/images/quick_handle_both.png differ
diff --git a/data/images/quick_icon_bg_01.png b/data/images/quick_icon_bg_01.png
new file mode 100755 (executable)
index 0000000..4fa4a24
Binary files /dev/null and b/data/images/quick_icon_bg_01.png differ
diff --git a/data/images/quick_icon_bg_02.png b/data/images/quick_icon_bg_02.png
new file mode 100755 (executable)
index 0000000..39a1a02
Binary files /dev/null and b/data/images/quick_icon_bg_02.png differ
diff --git a/data/images/quick_icon_bg_small.png b/data/images/quick_icon_bg_small.png
new file mode 100755 (executable)
index 0000000..974be6f
Binary files /dev/null and b/data/images/quick_icon_bg_small.png differ
diff --git a/data/images/quick_icon_brightness.png b/data/images/quick_icon_brightness.png
new file mode 100644 (file)
index 0000000..3053e9c
Binary files /dev/null and b/data/images/quick_icon_brightness.png differ
diff --git a/data/images/quick_icon_brightness_00.png b/data/images/quick_icon_brightness_00.png
new file mode 100644 (file)
index 0000000..eaf1c97
Binary files /dev/null and b/data/images/quick_icon_brightness_00.png differ
diff --git a/data/images/quick_icon_brightness_01.png b/data/images/quick_icon_brightness_01.png
new file mode 100644 (file)
index 0000000..4911739
Binary files /dev/null and b/data/images/quick_icon_brightness_01.png differ
diff --git a/data/images/quick_icon_brightness_02.png b/data/images/quick_icon_brightness_02.png
new file mode 100644 (file)
index 0000000..b5d5a0f
Binary files /dev/null and b/data/images/quick_icon_brightness_02.png differ
diff --git a/data/images/quick_icon_brightness_03.png b/data/images/quick_icon_brightness_03.png
new file mode 100644 (file)
index 0000000..a189fed
Binary files /dev/null and b/data/images/quick_icon_brightness_03.png differ
diff --git a/data/images/quick_icon_brightness_04.png b/data/images/quick_icon_brightness_04.png
new file mode 100644 (file)
index 0000000..8bf8e3d
Binary files /dev/null and b/data/images/quick_icon_brightness_04.png differ
diff --git a/data/images/quick_icon_brightness_05.png b/data/images/quick_icon_brightness_05.png
new file mode 100644 (file)
index 0000000..a9df3fc
Binary files /dev/null and b/data/images/quick_icon_brightness_05.png differ
diff --git a/data/images/quick_icon_brightness_06.png b/data/images/quick_icon_brightness_06.png
new file mode 100644 (file)
index 0000000..a92d320
Binary files /dev/null and b/data/images/quick_icon_brightness_06.png differ
diff --git a/data/images/quick_icon_brightness_07.png b/data/images/quick_icon_brightness_07.png
new file mode 100644 (file)
index 0000000..050c878
Binary files /dev/null and b/data/images/quick_icon_brightness_07.png differ
diff --git a/data/images/quick_icon_brightness_08.png b/data/images/quick_icon_brightness_08.png
new file mode 100644 (file)
index 0000000..8377efa
Binary files /dev/null and b/data/images/quick_icon_brightness_08.png differ
diff --git a/data/images/quick_icon_brightness_09.png b/data/images/quick_icon_brightness_09.png
new file mode 100644 (file)
index 0000000..b90022e
Binary files /dev/null and b/data/images/quick_icon_brightness_09.png differ
diff --git a/data/images/quick_icon_brightness_10.png b/data/images/quick_icon_brightness_10.png
new file mode 100644 (file)
index 0000000..a376394
Binary files /dev/null and b/data/images/quick_icon_brightness_10.png differ
diff --git a/data/images/quick_icon_brightness_11.png b/data/images/quick_icon_brightness_11.png
new file mode 100644 (file)
index 0000000..b2fdfb5
Binary files /dev/null and b/data/images/quick_icon_brightness_11.png differ
diff --git a/data/images/quick_image_dimmed_land.png b/data/images/quick_image_dimmed_land.png
new file mode 100755 (executable)
index 0000000..0b445b8
Binary files /dev/null and b/data/images/quick_image_dimmed_land.png differ
diff --git a/data/images/quick_image_dimmed_port.png b/data/images/quick_image_dimmed_port.png
new file mode 100755 (executable)
index 0000000..ec11f45
Binary files /dev/null and b/data/images/quick_image_dimmed_port.png differ
diff --git a/data/images/quick_menu_divide.png b/data/images/quick_menu_divide.png
new file mode 100644 (file)
index 0000000..35b9519
Binary files /dev/null and b/data/images/quick_menu_divide.png differ
diff --git a/data/images/quick_menu_divide_highlight.png b/data/images/quick_menu_divide_highlight.png
new file mode 100644 (file)
index 0000000..934d07c
Binary files /dev/null and b/data/images/quick_menu_divide_highlight.png differ
diff --git a/data/images/quick_menu_touch.png b/data/images/quick_menu_touch.png
new file mode 100644 (file)
index 0000000..54921fd
Binary files /dev/null and b/data/images/quick_menu_touch.png differ
diff --git a/data/images/quick_progress.9.png b/data/images/quick_progress.9.png
new file mode 100755 (executable)
index 0000000..1675b22
Binary files /dev/null and b/data/images/quick_progress.9.png differ
diff --git a/data/images/quick_progress_bg.9.png b/data/images/quick_progress_bg.9.png
new file mode 100755 (executable)
index 0000000..452e1d7
Binary files /dev/null and b/data/images/quick_progress_bg.9.png differ
diff --git a/data/images/quick_progress_unknown_port_01.png b/data/images/quick_progress_unknown_port_01.png
new file mode 100755 (executable)
index 0000000..87a8a35
Binary files /dev/null and b/data/images/quick_progress_unknown_port_01.png differ
diff --git a/data/images/quick_progress_unknown_port_02.png b/data/images/quick_progress_unknown_port_02.png
new file mode 100755 (executable)
index 0000000..2d9b954
Binary files /dev/null and b/data/images/quick_progress_unknown_port_02.png differ
diff --git a/data/images/quick_standard_btn_focus.9.png b/data/images/quick_standard_btn_focus.9.png
new file mode 100644 (file)
index 0000000..64aee6b
Binary files /dev/null and b/data/images/quick_standard_btn_focus.9.png differ
diff --git a/data/images/quick_standard_btn_nor.9.png b/data/images/quick_standard_btn_nor.9.png
new file mode 100644 (file)
index 0000000..84aba62
Binary files /dev/null and b/data/images/quick_standard_btn_nor.9.png differ
diff --git a/data/images/quick_standard_btn_nor.png b/data/images/quick_standard_btn_nor.png
new file mode 100644 (file)
index 0000000..a7f682d
Binary files /dev/null and b/data/images/quick_standard_btn_nor.png differ
diff --git a/data/images/quick_standard_btn_press.9.png b/data/images/quick_standard_btn_press.9.png
new file mode 100644 (file)
index 0000000..981d56d
Binary files /dev/null and b/data/images/quick_standard_btn_press.9.png differ
diff --git a/data/images/quickpanel_icon_default.png b/data/images/quickpanel_icon_default.png
new file mode 100644 (file)
index 0000000..ef74fd1
Binary files /dev/null and b/data/images/quickpanel_icon_default.png differ
diff --git a/data/images/toggle_mw_bg_nor.png b/data/images/toggle_mw_bg_nor.png
new file mode 100644 (file)
index 0000000..80df1f1
Binary files /dev/null and b/data/images/toggle_mw_bg_nor.png differ
diff --git a/data/images/toggle_mw_bg_touch.png b/data/images/toggle_mw_bg_touch.png
new file mode 100644 (file)
index 0000000..57ac363
Binary files /dev/null and b/data/images/toggle_mw_bg_touch.png differ
diff --git a/data/images_icon/Q02_Notification_brightness.png b/data/images_icon/Q02_Notification_brightness.png
new file mode 100644 (file)
index 0000000..e2c8cf8
Binary files /dev/null and b/data/images_icon/Q02_Notification_brightness.png differ
diff --git a/data/images_icon/Q02_Notification_multi_window.png b/data/images_icon/Q02_Notification_multi_window.png
new file mode 100644 (file)
index 0000000..e9ce062
Binary files /dev/null and b/data/images_icon/Q02_Notification_multi_window.png differ
diff --git a/data/images_icon/Q02_Notification_update.png b/data/images_icon/Q02_Notification_update.png
new file mode 100644 (file)
index 0000000..d95a0d9
Binary files /dev/null and b/data/images_icon/Q02_Notification_update.png differ
diff --git a/data/images_icon/noti_download_01.png b/data/images_icon/noti_download_01.png
new file mode 100644 (file)
index 0000000..1347662
Binary files /dev/null and b/data/images_icon/noti_download_01.png differ
diff --git a/data/images_icon/noti_download_02.png b/data/images_icon/noti_download_02.png
new file mode 100644 (file)
index 0000000..52848ca
Binary files /dev/null and b/data/images_icon/noti_download_02.png differ
diff --git a/data/images_icon/noti_download_03.png b/data/images_icon/noti_download_03.png
new file mode 100644 (file)
index 0000000..ef20442
Binary files /dev/null and b/data/images_icon/noti_download_03.png differ
diff --git a/data/images_icon/noti_download_04.png b/data/images_icon/noti_download_04.png
new file mode 100644 (file)
index 0000000..b609329
Binary files /dev/null and b/data/images_icon/noti_download_04.png differ
diff --git a/data/images_icon/noti_download_05.png b/data/images_icon/noti_download_05.png
new file mode 100644 (file)
index 0000000..bab9835
Binary files /dev/null and b/data/images_icon/noti_download_05.png differ
diff --git a/data/images_icon/noti_download_complete.png b/data/images_icon/noti_download_complete.png
new file mode 100644 (file)
index 0000000..9e35143
Binary files /dev/null and b/data/images_icon/noti_download_complete.png differ
diff --git a/data/images_icon/noti_install_01.png b/data/images_icon/noti_install_01.png
new file mode 100644 (file)
index 0000000..ced3bdd
Binary files /dev/null and b/data/images_icon/noti_install_01.png differ
diff --git a/data/images_icon/noti_install_02.png b/data/images_icon/noti_install_02.png
new file mode 100644 (file)
index 0000000..481ff3f
Binary files /dev/null and b/data/images_icon/noti_install_02.png differ
diff --git a/data/images_icon/noti_install_03.png b/data/images_icon/noti_install_03.png
new file mode 100644 (file)
index 0000000..2d04ca0
Binary files /dev/null and b/data/images_icon/noti_install_03.png differ
diff --git a/data/images_icon/noti_install_04.png b/data/images_icon/noti_install_04.png
new file mode 100644 (file)
index 0000000..16fa161
Binary files /dev/null and b/data/images_icon/noti_install_04.png differ
diff --git a/data/images_icon/noti_install_05.png b/data/images_icon/noti_install_05.png
new file mode 100644 (file)
index 0000000..a33c76c
Binary files /dev/null and b/data/images_icon/noti_install_05.png differ
diff --git a/data/images_icon/noti_install_complete.png b/data/images_icon/noti_install_complete.png
new file mode 100644 (file)
index 0000000..b9bd97c
Binary files /dev/null and b/data/images_icon/noti_install_complete.png differ
diff --git a/data/images_icon/noti_upload_01.png b/data/images_icon/noti_upload_01.png
new file mode 100644 (file)
index 0000000..6445da8
Binary files /dev/null and b/data/images_icon/noti_upload_01.png differ
diff --git a/data/images_icon/noti_upload_02.png b/data/images_icon/noti_upload_02.png
new file mode 100644 (file)
index 0000000..bf230fd
Binary files /dev/null and b/data/images_icon/noti_upload_02.png differ
diff --git a/data/images_icon/noti_upload_03.png b/data/images_icon/noti_upload_03.png
new file mode 100644 (file)
index 0000000..306a258
Binary files /dev/null and b/data/images_icon/noti_upload_03.png differ
diff --git a/data/images_icon/noti_upload_04.png b/data/images_icon/noti_upload_04.png
new file mode 100644 (file)
index 0000000..50c0e9d
Binary files /dev/null and b/data/images_icon/noti_upload_04.png differ
diff --git a/data/images_icon/noti_upload_05.png b/data/images_icon/noti_upload_05.png
new file mode 100644 (file)
index 0000000..fb49ad8
Binary files /dev/null and b/data/images_icon/noti_upload_05.png differ
diff --git a/data/images_icon/noti_upload_complete.png b/data/images_icon/noti_upload_complete.png
new file mode 100644 (file)
index 0000000..2ee11d8
Binary files /dev/null and b/data/images_icon/noti_upload_complete.png differ
diff --git a/data/images_icon/quick_button_icon_bg.png b/data/images_icon/quick_button_icon_bg.png
new file mode 100644 (file)
index 0000000..392389c
Binary files /dev/null and b/data/images_icon/quick_button_icon_bg.png differ
diff --git a/data/images_icon/quick_icon_allshare.png b/data/images_icon/quick_icon_allshare.png
new file mode 100644 (file)
index 0000000..42176ed
Binary files /dev/null and b/data/images_icon/quick_icon_allshare.png differ
diff --git a/data/images_icon/quick_icon_auto_rotate.png b/data/images_icon/quick_icon_auto_rotate.png
new file mode 100644 (file)
index 0000000..48d9136
Binary files /dev/null and b/data/images_icon/quick_icon_auto_rotate.png differ
diff --git a/data/images_icon/quick_icon_blocking_mode.png b/data/images_icon/quick_icon_blocking_mode.png
new file mode 100644 (file)
index 0000000..bea9615
Binary files /dev/null and b/data/images_icon/quick_icon_blocking_mode.png differ
diff --git a/data/images_icon/quick_icon_bluetooth.png b/data/images_icon/quick_icon_bluetooth.png
new file mode 100644 (file)
index 0000000..ec747f8
Binary files /dev/null and b/data/images_icon/quick_icon_bluetooth.png differ
diff --git a/data/images_icon/quick_icon_command.png b/data/images_icon/quick_icon_command.png
new file mode 100644 (file)
index 0000000..2115f86
Binary files /dev/null and b/data/images_icon/quick_icon_command.png differ
diff --git a/data/images_icon/quick_icon_downloadbooster_off.png b/data/images_icon/quick_icon_downloadbooster_off.png
new file mode 100644 (file)
index 0000000..136380a
Binary files /dev/null and b/data/images_icon/quick_icon_downloadbooster_off.png differ
diff --git a/data/images_icon/quick_icon_driving.png b/data/images_icon/quick_icon_driving.png
new file mode 100644 (file)
index 0000000..19815b6
Binary files /dev/null and b/data/images_icon/quick_icon_driving.png differ
diff --git a/data/images_icon/quick_icon_flightmode.png b/data/images_icon/quick_icon_flightmode.png
new file mode 100644 (file)
index 0000000..a2cae7a
Binary files /dev/null and b/data/images_icon/quick_icon_flightmode.png differ
diff --git a/data/images_icon/quick_icon_glovemode.png b/data/images_icon/quick_icon_glovemode.png
new file mode 100644 (file)
index 0000000..92518b2
Binary files /dev/null and b/data/images_icon/quick_icon_glovemode.png differ
diff --git a/data/images_icon/quick_icon_gps.png b/data/images_icon/quick_icon_gps.png
new file mode 100644 (file)
index 0000000..735136e
Binary files /dev/null and b/data/images_icon/quick_icon_gps.png differ
diff --git a/data/images_icon/quick_icon_location.png b/data/images_icon/quick_icon_location.png
new file mode 100644 (file)
index 0000000..ecb55de
Binary files /dev/null and b/data/images_icon/quick_icon_location.png differ
diff --git a/data/images_icon/quick_icon_mirroring.png b/data/images_icon/quick_icon_mirroring.png
new file mode 100644 (file)
index 0000000..e5fbc2d
Binary files /dev/null and b/data/images_icon/quick_icon_mirroring.png differ
diff --git a/data/images_icon/quick_icon_mobile_data.png b/data/images_icon/quick_icon_mobile_data.png
new file mode 100644 (file)
index 0000000..0d7c9bc
Binary files /dev/null and b/data/images_icon/quick_icon_mobile_data.png differ
diff --git a/data/images_icon/quick_icon_multi_window.png b/data/images_icon/quick_icon_multi_window.png
new file mode 100644 (file)
index 0000000..2a9c61b
Binary files /dev/null and b/data/images_icon/quick_icon_multi_window.png differ
diff --git a/data/images_icon/quick_icon_nfc.png b/data/images_icon/quick_icon_nfc.png
new file mode 100644 (file)
index 0000000..baa82d5
Binary files /dev/null and b/data/images_icon/quick_icon_nfc.png differ
diff --git a/data/images_icon/quick_icon_personal_mode.png b/data/images_icon/quick_icon_personal_mode.png
new file mode 100644 (file)
index 0000000..ad6bb1b
Binary files /dev/null and b/data/images_icon/quick_icon_personal_mode.png differ
diff --git a/data/images_icon/quick_icon_power_saving.png b/data/images_icon/quick_icon_power_saving.png
new file mode 100644 (file)
index 0000000..ac6b385
Binary files /dev/null and b/data/images_icon/quick_icon_power_saving.png differ
diff --git a/data/images_icon/quick_icon_private_mode.png b/data/images_icon/quick_icon_private_mode.png
new file mode 100644 (file)
index 0000000..fabadcf
Binary files /dev/null and b/data/images_icon/quick_icon_private_mode.png differ
diff --git a/data/images_icon/quick_icon_ready_to_share.png b/data/images_icon/quick_icon_ready_to_share.png
new file mode 100644 (file)
index 0000000..ca5ac43
Binary files /dev/null and b/data/images_icon/quick_icon_ready_to_share.png differ
diff --git a/data/images_icon/quick_icon_sbeam.png b/data/images_icon/quick_icon_sbeam.png
new file mode 100644 (file)
index 0000000..5f85e1e
Binary files /dev/null and b/data/images_icon/quick_icon_sbeam.png differ
diff --git a/data/images_icon/quick_icon_sf_vf.png b/data/images_icon/quick_icon_sf_vf.png
new file mode 100644 (file)
index 0000000..a585498
Binary files /dev/null and b/data/images_icon/quick_icon_sf_vf.png differ
diff --git a/data/images_icon/quick_icon_sf_vn.png b/data/images_icon/quick_icon_sf_vn.png
new file mode 100644 (file)
index 0000000..ff22abe
Binary files /dev/null and b/data/images_icon/quick_icon_sf_vn.png differ
diff --git a/data/images_icon/quick_icon_smart_stay.png b/data/images_icon/quick_icon_smart_stay.png
new file mode 100644 (file)
index 0000000..2d2ab5d
Binary files /dev/null and b/data/images_icon/quick_icon_smart_stay.png differ
diff --git a/data/images_icon/quick_icon_sn_vf.png b/data/images_icon/quick_icon_sn_vf.png
new file mode 100644 (file)
index 0000000..005e793
Binary files /dev/null and b/data/images_icon/quick_icon_sn_vf.png differ
diff --git a/data/images_icon/quick_icon_sn_vn.png b/data/images_icon/quick_icon_sn_vn.png
new file mode 100644 (file)
index 0000000..3a598ef
Binary files /dev/null and b/data/images_icon/quick_icon_sn_vn.png differ
diff --git a/data/images_icon/quick_icon_sync.png b/data/images_icon/quick_icon_sync.png
new file mode 100644 (file)
index 0000000..72c9d1f
Binary files /dev/null and b/data/images_icon/quick_icon_sync.png differ
diff --git a/data/images_icon/quick_icon_torch.png b/data/images_icon/quick_icon_torch.png
new file mode 100644 (file)
index 0000000..0a90ae8
Binary files /dev/null and b/data/images_icon/quick_icon_torch.png differ
diff --git a/data/images_icon/quick_icon_ultra_power_saving.png b/data/images_icon/quick_icon_ultra_power_saving.png
new file mode 100644 (file)
index 0000000..51968bc
Binary files /dev/null and b/data/images_icon/quick_icon_ultra_power_saving.png differ
diff --git a/data/images_icon/quick_icon_wifi.png b/data/images_icon/quick_icon_wifi.png
new file mode 100644 (file)
index 0000000..2fd7255
Binary files /dev/null and b/data/images_icon/quick_icon_wifi.png differ
diff --git a/data/images_icon/quick_icon_wifi_tethering.png b/data/images_icon/quick_icon_wifi_tethering.png
new file mode 100644 (file)
index 0000000..dceb644
Binary files /dev/null and b/data/images_icon/quick_icon_wifi_tethering.png differ
diff --git a/data/images_icon/voice_control_icon_mic.png b/data/images_icon/voice_control_icon_mic.png
new file mode 100755 (executable)
index 0000000..0e3a54e
Binary files /dev/null and b/data/images_icon/voice_control_icon_mic.png differ
diff --git a/data/images_noti_icons/Account/noti_account_samsung.png b/data/images_noti_icons/Account/noti_account_samsung.png
new file mode 100755 (executable)
index 0000000..9b4efd7
Binary files /dev/null and b/data/images_noti_icons/Account/noti_account_samsung.png differ
diff --git a/data/images_noti_icons/Account/noti_account_tizen.png b/data/images_noti_icons/Account/noti_account_tizen.png
new file mode 100755 (executable)
index 0000000..c13186d
Binary files /dev/null and b/data/images_noti_icons/Account/noti_account_tizen.png differ
diff --git a/data/images_noti_icons/Bluetooth/noti_bluetooth.png b/data/images_noti_icons/Bluetooth/noti_bluetooth.png
new file mode 100755 (executable)
index 0000000..f14c8b9
Binary files /dev/null and b/data/images_noti_icons/Bluetooth/noti_bluetooth.png differ
diff --git a/data/images_noti_icons/Bluetooth/noti_bluetooth_activated.png b/data/images_noti_icons/Bluetooth/noti_bluetooth_activated.png
new file mode 100755 (executable)
index 0000000..059897b
Binary files /dev/null and b/data/images_noti_icons/Bluetooth/noti_bluetooth_activated.png differ
diff --git a/data/images_noti_icons/Bluetooth/noti_bluetooth_fail.png b/data/images_noti_icons/Bluetooth/noti_bluetooth_fail.png
new file mode 100755 (executable)
index 0000000..9439c19
Binary files /dev/null and b/data/images_noti_icons/Bluetooth/noti_bluetooth_fail.png differ
diff --git a/data/images_noti_icons/Bluetooth/noti_bluetooth_not_connected.png b/data/images_noti_icons/Bluetooth/noti_bluetooth_not_connected.png
new file mode 100755 (executable)
index 0000000..2574dbc
Binary files /dev/null and b/data/images_noti_icons/Bluetooth/noti_bluetooth_not_connected.png differ
diff --git a/data/images_noti_icons/Calendar/noti_calendar.png b/data/images_noti_icons/Calendar/noti_calendar.png
new file mode 100755 (executable)
index 0000000..ffed971
Binary files /dev/null and b/data/images_noti_icons/Calendar/noti_calendar.png differ
diff --git a/data/images_noti_icons/Calendar/noti_calendar_02.png b/data/images_noti_icons/Calendar/noti_calendar_02.png
new file mode 100755 (executable)
index 0000000..e537aa9
Binary files /dev/null and b/data/images_noti_icons/Calendar/noti_calendar_02.png differ
diff --git a/data/images_noti_icons/Calendar/noti_calendar_alarm.png b/data/images_noti_icons/Calendar/noti_calendar_alarm.png
new file mode 100755 (executable)
index 0000000..a6244a9
Binary files /dev/null and b/data/images_noti_icons/Calendar/noti_calendar_alarm.png differ
diff --git a/data/images_noti_icons/Clock/noti_clock_snooze.png b/data/images_noti_icons/Clock/noti_clock_snooze.png
new file mode 100755 (executable)
index 0000000..8e07360
Binary files /dev/null and b/data/images_noti_icons/Clock/noti_clock_snooze.png differ
diff --git a/data/images_noti_icons/Common/noti_download_01.png b/data/images_noti_icons/Common/noti_download_01.png
new file mode 100755 (executable)
index 0000000..e753be2
Binary files /dev/null and b/data/images_noti_icons/Common/noti_download_01.png differ
diff --git a/data/images_noti_icons/Common/noti_download_02.png b/data/images_noti_icons/Common/noti_download_02.png
new file mode 100755 (executable)
index 0000000..e221d38
Binary files /dev/null and b/data/images_noti_icons/Common/noti_download_02.png differ
diff --git a/data/images_noti_icons/Common/noti_download_03.png b/data/images_noti_icons/Common/noti_download_03.png
new file mode 100755 (executable)
index 0000000..942b51e
Binary files /dev/null and b/data/images_noti_icons/Common/noti_download_03.png differ
diff --git a/data/images_noti_icons/Common/noti_download_04.png b/data/images_noti_icons/Common/noti_download_04.png
new file mode 100755 (executable)
index 0000000..c3b6e70
Binary files /dev/null and b/data/images_noti_icons/Common/noti_download_04.png differ
diff --git a/data/images_noti_icons/Common/noti_download_05.png b/data/images_noti_icons/Common/noti_download_05.png
new file mode 100755 (executable)
index 0000000..7730941
Binary files /dev/null and b/data/images_noti_icons/Common/noti_download_05.png differ
diff --git a/data/images_noti_icons/Common/noti_download_complete.png b/data/images_noti_icons/Common/noti_download_complete.png
new file mode 100755 (executable)
index 0000000..771bc4e
Binary files /dev/null and b/data/images_noti_icons/Common/noti_download_complete.png differ
diff --git a/data/images_noti_icons/Common/noti_download_failed.png b/data/images_noti_icons/Common/noti_download_failed.png
new file mode 100755 (executable)
index 0000000..012df7b
Binary files /dev/null and b/data/images_noti_icons/Common/noti_download_failed.png differ
diff --git a/data/images_noti_icons/Common/noti_syncing.png b/data/images_noti_icons/Common/noti_syncing.png
new file mode 100755 (executable)
index 0000000..a87d011
Binary files /dev/null and b/data/images_noti_icons/Common/noti_syncing.png differ
diff --git a/data/images_noti_icons/Common/noti_upload_01.png b/data/images_noti_icons/Common/noti_upload_01.png
new file mode 100755 (executable)
index 0000000..208dc94
Binary files /dev/null and b/data/images_noti_icons/Common/noti_upload_01.png differ
diff --git a/data/images_noti_icons/Common/noti_upload_02.png b/data/images_noti_icons/Common/noti_upload_02.png
new file mode 100755 (executable)
index 0000000..2f79bbc
Binary files /dev/null and b/data/images_noti_icons/Common/noti_upload_02.png differ
diff --git a/data/images_noti_icons/Common/noti_upload_03.png b/data/images_noti_icons/Common/noti_upload_03.png
new file mode 100755 (executable)
index 0000000..39b85c9
Binary files /dev/null and b/data/images_noti_icons/Common/noti_upload_03.png differ
diff --git a/data/images_noti_icons/Common/noti_upload_04.png b/data/images_noti_icons/Common/noti_upload_04.png
new file mode 100755 (executable)
index 0000000..ee51d0c
Binary files /dev/null and b/data/images_noti_icons/Common/noti_upload_04.png differ
diff --git a/data/images_noti_icons/Common/noti_upload_05.png b/data/images_noti_icons/Common/noti_upload_05.png
new file mode 100755 (executable)
index 0000000..06dacdc
Binary files /dev/null and b/data/images_noti_icons/Common/noti_upload_05.png differ
diff --git a/data/images_noti_icons/Common/noti_upload_complete.png b/data/images_noti_icons/Common/noti_upload_complete.png
new file mode 100755 (executable)
index 0000000..dc173e1
Binary files /dev/null and b/data/images_noti_icons/Common/noti_upload_complete.png differ
diff --git a/data/images_noti_icons/Common/noti_upload_failed.png b/data/images_noti_icons/Common/noti_upload_failed.png
new file mode 100755 (executable)
index 0000000..7c612ec
Binary files /dev/null and b/data/images_noti_icons/Common/noti_upload_failed.png differ
diff --git a/data/images_noti_icons/Contact/noti_contact_default.png b/data/images_noti_icons/Contact/noti_contact_default.png
new file mode 100755 (executable)
index 0000000..95ba822
Binary files /dev/null and b/data/images_noti_icons/Contact/noti_contact_default.png differ
diff --git a/data/images_noti_icons/Contact/noti_icon_missed.png b/data/images_noti_icons/Contact/noti_icon_missed.png
new file mode 100755 (executable)
index 0000000..f9510ac
Binary files /dev/null and b/data/images_noti_icons/Contact/noti_icon_missed.png differ
diff --git a/data/images_noti_icons/Drop box/moti_dropbox.png b/data/images_noti_icons/Drop box/moti_dropbox.png
new file mode 100755 (executable)
index 0000000..be05743
Binary files /dev/null and b/data/images_noti_icons/Drop box/moti_dropbox.png differ
diff --git a/data/images_noti_icons/E-mail/noti_email.png b/data/images_noti_icons/E-mail/noti_email.png
new file mode 100755 (executable)
index 0000000..58baaaf
Binary files /dev/null and b/data/images_noti_icons/E-mail/noti_email.png differ
diff --git a/data/images_noti_icons/E-mail/noti_email_delivery_report.png b/data/images_noti_icons/E-mail/noti_email_delivery_report.png
new file mode 100755 (executable)
index 0000000..b2237ff
Binary files /dev/null and b/data/images_noti_icons/E-mail/noti_email_delivery_report.png differ
diff --git a/data/images_noti_icons/E-mail/noti_email_read_report.png b/data/images_noti_icons/E-mail/noti_email_read_report.png
new file mode 100755 (executable)
index 0000000..cc1ac9d
Binary files /dev/null and b/data/images_noti_icons/E-mail/noti_email_read_report.png differ
diff --git a/data/images_noti_icons/E-mail/noti_email_scheduled.png b/data/images_noti_icons/E-mail/noti_email_scheduled.png
new file mode 100755 (executable)
index 0000000..59fea6b
Binary files /dev/null and b/data/images_noti_icons/E-mail/noti_email_scheduled.png differ
diff --git a/data/images_noti_icons/E-mail/noti_email_sent.png b/data/images_noti_icons/E-mail/noti_email_sent.png
new file mode 100755 (executable)
index 0000000..a81c959
Binary files /dev/null and b/data/images_noti_icons/E-mail/noti_email_sent.png differ
diff --git a/data/images_noti_icons/Etc/Icon_tethering_unknown_usb_fail.png b/data/images_noti_icons/Etc/Icon_tethering_unknown_usb_fail.png
new file mode 100755 (executable)
index 0000000..d856d54
Binary files /dev/null and b/data/images_noti_icons/Etc/Icon_tethering_unknown_usb_fail.png differ
diff --git a/data/images_noti_icons/Etc/noti_accessory_connected.png b/data/images_noti_icons/Etc/noti_accessory_connected.png
new file mode 100755 (executable)
index 0000000..11452da
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_accessory_connected.png differ
diff --git a/data/images_noti_icons/Etc/noti_all_connected.png b/data/images_noti_icons/Etc/noti_all_connected.png
new file mode 100755 (executable)
index 0000000..e1aef25
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_all_connected.png differ
diff --git a/data/images_noti_icons/Etc/noti_auto_rejected.png b/data/images_noti_icons/Etc/noti_auto_rejected.png
new file mode 100755 (executable)
index 0000000..53277aa
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_auto_rejected.png differ
diff --git a/data/images_noti_icons/Etc/noti_backup.png b/data/images_noti_icons/Etc/noti_backup.png
new file mode 100755 (executable)
index 0000000..f66b841
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_backup.png differ
diff --git a/data/images_noti_icons/Etc/noti_battery_charge.png b/data/images_noti_icons/Etc/noti_battery_charge.png
new file mode 100755 (executable)
index 0000000..6bb9883
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_battery_charge.png differ
diff --git a/data/images_noti_icons/Etc/noti_battery_loading.png b/data/images_noti_icons/Etc/noti_battery_loading.png
new file mode 100755 (executable)
index 0000000..30d9280
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_battery_loading.png differ
diff --git a/data/images_noti_icons/Etc/noti_bluetooth_download.png b/data/images_noti_icons/Etc/noti_bluetooth_download.png
new file mode 100755 (executable)
index 0000000..9c0146b
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_bluetooth_download.png differ
diff --git a/data/images_noti_icons/Etc/noti_camera_connected.png b/data/images_noti_icons/Etc/noti_camera_connected.png
new file mode 100755 (executable)
index 0000000..cadf0de
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_camera_connected.png differ
diff --git a/data/images_noti_icons/Etc/noti_chat.png b/data/images_noti_icons/Etc/noti_chat.png
new file mode 100755 (executable)
index 0000000..d3e0665
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_chat.png differ
diff --git a/data/images_noti_icons/Etc/noti_data_usage_warning.png b/data/images_noti_icons/Etc/noti_data_usage_warning.png
new file mode 100755 (executable)
index 0000000..328e3e4
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_data_usage_warning.png differ
diff --git a/data/images_noti_icons/Etc/noti_desktop_mode.png b/data/images_noti_icons/Etc/noti_desktop_mode.png
new file mode 100755 (executable)
index 0000000..3343b95
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_desktop_mode.png differ
diff --git a/data/images_noti_icons/Etc/noti_dormant_mode.png b/data/images_noti_icons/Etc/noti_dormant_mode.png
new file mode 100755 (executable)
index 0000000..6c503f8
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_dormant_mode.png differ
diff --git a/data/images_noti_icons/Etc/noti_download_booster.png b/data/images_noti_icons/Etc/noti_download_booster.png
new file mode 100755 (executable)
index 0000000..0dad1b5
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_download_booster.png differ
diff --git a/data/images_noti_icons/Etc/noti_ecb_mode.png b/data/images_noti_icons/Etc/noti_ecb_mode.png
new file mode 100755 (executable)
index 0000000..cfaeb11
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_ecb_mode.png differ
diff --git a/data/images_noti_icons/Etc/noti_error.png b/data/images_noti_icons/Etc/noti_error.png
new file mode 100755 (executable)
index 0000000..1cd8e43
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_error.png differ
diff --git a/data/images_noti_icons/Etc/noti_firewall_activated.png b/data/images_noti_icons/Etc/noti_firewall_activated.png
new file mode 100755 (executable)
index 0000000..3e2ec47
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_firewall_activated.png differ
diff --git a/data/images_noti_icons/Etc/noti_fm_radio.png b/data/images_noti_icons/Etc/noti_fm_radio.png
new file mode 100755 (executable)
index 0000000..de1fef5
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_fm_radio.png differ
diff --git a/data/images_noti_icons/Etc/noti_fota.png b/data/images_noti_icons/Etc/noti_fota.png
new file mode 100755 (executable)
index 0000000..7980d1d
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_fota.png differ
diff --git a/data/images_noti_icons/Etc/noti_fota_completion.png b/data/images_noti_icons/Etc/noti_fota_completion.png
new file mode 100755 (executable)
index 0000000..42b4615
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_fota_completion.png differ
diff --git a/data/images_noti_icons/Etc/noti_fota_postpone.png b/data/images_noti_icons/Etc/noti_fota_postpone.png
new file mode 100755 (executable)
index 0000000..90a752c
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_fota_postpone.png differ
diff --git a/data/images_noti_icons/Etc/noti_gqs_on.png b/data/images_noti_icons/Etc/noti_gqs_on.png
new file mode 100755 (executable)
index 0000000..d380339
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_gqs_on.png differ
diff --git a/data/images_noti_icons/Etc/noti_gqs_searching.png b/data/images_noti_icons/Etc/noti_gqs_searching.png
new file mode 100755 (executable)
index 0000000..d380339
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_gqs_searching.png differ
diff --git a/data/images_noti_icons/Etc/noti_im.png b/data/images_noti_icons/Etc/noti_im.png
new file mode 100755 (executable)
index 0000000..7a2ba11
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_im.png differ
diff --git a/data/images_noti_icons/Etc/noti_install_01.png b/data/images_noti_icons/Etc/noti_install_01.png
new file mode 100755 (executable)
index 0000000..ced3bdd
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_install_01.png differ
diff --git a/data/images_noti_icons/Etc/noti_install_02.png b/data/images_noti_icons/Etc/noti_install_02.png
new file mode 100755 (executable)
index 0000000..481ff3f
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_install_02.png differ
diff --git a/data/images_noti_icons/Etc/noti_install_03.png b/data/images_noti_icons/Etc/noti_install_03.png
new file mode 100755 (executable)
index 0000000..2d04ca0
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_install_03.png differ
diff --git a/data/images_noti_icons/Etc/noti_install_04.png b/data/images_noti_icons/Etc/noti_install_04.png
new file mode 100755 (executable)
index 0000000..16fa161
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_install_04.png differ
diff --git a/data/images_noti_icons/Etc/noti_install_05.png b/data/images_noti_icons/Etc/noti_install_05.png
new file mode 100755 (executable)
index 0000000..a33c76c
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_install_05.png differ
diff --git a/data/images_noti_icons/Etc/noti_install_complete.png b/data/images_noti_icons/Etc/noti_install_complete.png
new file mode 100755 (executable)
index 0000000..b9bd97c
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_install_complete.png differ
diff --git a/data/images_noti_icons/Etc/noti_install_failed.png b/data/images_noti_icons/Etc/noti_install_failed.png
new file mode 100755 (executable)
index 0000000..25a8290
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_install_failed.png differ
diff --git a/data/images_noti_icons/Etc/noti_keyboard.png b/data/images_noti_icons/Etc/noti_keyboard.png
new file mode 100755 (executable)
index 0000000..d45dfb7
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_keyboard.png differ
diff --git a/data/images_noti_icons/Etc/noti_keyboard_connected.png b/data/images_noti_icons/Etc/noti_keyboard_connected.png
new file mode 100755 (executable)
index 0000000..cbac392
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_keyboard_connected.png differ
diff --git a/data/images_noti_icons/Etc/noti_mms_delivery_report.png b/data/images_noti_icons/Etc/noti_mms_delivery_report.png
new file mode 100755 (executable)
index 0000000..bafdb6f
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_mms_delivery_report.png differ
diff --git a/data/images_noti_icons/Etc/noti_mms_failed.png b/data/images_noti_icons/Etc/noti_mms_failed.png
new file mode 100755 (executable)
index 0000000..146264c
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_mms_failed.png differ
diff --git a/data/images_noti_icons/Etc/noti_mms_problem.png b/data/images_noti_icons/Etc/noti_mms_problem.png
new file mode 100755 (executable)
index 0000000..1d569bb
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_mms_problem.png differ
diff --git a/data/images_noti_icons/Etc/noti_multi_email.png b/data/images_noti_icons/Etc/noti_multi_email.png
new file mode 100755 (executable)
index 0000000..dcbee96
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_multi_email.png differ
diff --git a/data/images_noti_icons/Etc/noti_multi_window.png b/data/images_noti_icons/Etc/noti_multi_window.png
new file mode 100755 (executable)
index 0000000..e5bac16
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_multi_window.png differ
diff --git a/data/images_noti_icons/Etc/noti_multiple_devices_connected.png b/data/images_noti_icons/Etc/noti_multiple_devices_connected.png
new file mode 100755 (executable)
index 0000000..3536fc8
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_multiple_devices_connected.png differ
diff --git a/data/images_noti_icons/Etc/noti_near_by_device.png b/data/images_noti_icons/Etc/noti_near_by_device.png
new file mode 100755 (executable)
index 0000000..2a1d22b
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_near_by_device.png differ
diff --git a/data/images_noti_icons/Etc/noti_no_sim_full.png b/data/images_noti_icons/Etc/noti_no_sim_full.png
new file mode 100755 (executable)
index 0000000..a6278c2
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_no_sim_full.png differ
diff --git a/data/images_noti_icons/Etc/noti_print.png b/data/images_noti_icons/Etc/noti_print.png
new file mode 100755 (executable)
index 0000000..f60e8cb
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_print.png differ
diff --git a/data/images_noti_icons/Etc/noti_print_waiting.png b/data/images_noti_icons/Etc/noti_print_waiting.png
new file mode 100755 (executable)
index 0000000..a29fc39
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_print_waiting.png differ
diff --git a/data/images_noti_icons/Etc/noti_rcs_chat.png b/data/images_noti_icons/Etc/noti_rcs_chat.png
new file mode 100755 (executable)
index 0000000..d692be8
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_rcs_chat.png differ
diff --git a/data/images_noti_icons/Etc/noti_rcs_file_transfer.png b/data/images_noti_icons/Etc/noti_rcs_file_transfer.png
new file mode 100755 (executable)
index 0000000..1acd33f
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_rcs_file_transfer.png differ
diff --git a/data/images_noti_icons/Etc/noti_safe_mode.png b/data/images_noti_icons/Etc/noti_safe_mode.png
new file mode 100755 (executable)
index 0000000..1f70bd5
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_safe_mode.png differ
diff --git a/data/images_noti_icons/Etc/noti_screen_recorder.png b/data/images_noti_icons/Etc/noti_screen_recorder.png
new file mode 100755 (executable)
index 0000000..2b2a5b6
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_screen_recorder.png differ
diff --git a/data/images_noti_icons/Etc/noti_screen_recorder_dim.png b/data/images_noti_icons/Etc/noti_screen_recorder_dim.png
new file mode 100755 (executable)
index 0000000..367f26f
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_screen_recorder_dim.png differ
diff --git a/data/images_noti_icons/Etc/noti_sd_card.png b/data/images_noti_icons/Etc/noti_sd_card.png
new file mode 100755 (executable)
index 0000000..30fac67
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_sd_card.png differ
diff --git a/data/images_noti_icons/Etc/noti_sd_card_decryption.png b/data/images_noti_icons/Etc/noti_sd_card_decryption.png
new file mode 100755 (executable)
index 0000000..5fc7cab
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_sd_card_decryption.png differ
diff --git a/data/images_noti_icons/Etc/noti_sd_card_encryption.png b/data/images_noti_icons/Etc/noti_sd_card_encryption.png
new file mode 100755 (executable)
index 0000000..f8ff9a5
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_sd_card_encryption.png differ
diff --git a/data/images_noti_icons/Etc/noti_sd_card_encryption_error.png b/data/images_noti_icons/Etc/noti_sd_card_encryption_error.png
new file mode 100755 (executable)
index 0000000..80f6e41
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_sd_card_encryption_error.png differ
diff --git a/data/images_noti_icons/Etc/noti_sd_card_error.png b/data/images_noti_icons/Etc/noti_sd_card_error.png
new file mode 100755 (executable)
index 0000000..9dafe97
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_sd_card_error.png differ
diff --git a/data/images_noti_icons/Etc/noti_sd_card_prepare.png b/data/images_noti_icons/Etc/noti_sd_card_prepare.png
new file mode 100755 (executable)
index 0000000..9ba26d0
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_sd_card_prepare.png differ
diff --git a/data/images_noti_icons/Etc/noti_sd_card_removed.png b/data/images_noti_icons/Etc/noti_sd_card_removed.png
new file mode 100755 (executable)
index 0000000..7ce44e0
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_sd_card_removed.png differ
diff --git a/data/images_noti_icons/Etc/noti_shareshot_receive.png b/data/images_noti_icons/Etc/noti_shareshot_receive.png
new file mode 100755 (executable)
index 0000000..fa36026
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_shareshot_receive.png differ
diff --git a/data/images_noti_icons/Etc/noti_shareshot_receive_problem.png b/data/images_noti_icons/Etc/noti_shareshot_receive_problem.png
new file mode 100755 (executable)
index 0000000..f8969de
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_shareshot_receive_problem.png differ
diff --git a/data/images_noti_icons/Etc/noti_shareshot_send.png b/data/images_noti_icons/Etc/noti_shareshot_send.png
new file mode 100755 (executable)
index 0000000..42bb2d4
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_shareshot_send.png differ
diff --git a/data/images_noti_icons/Etc/noti_shareshot_send_problem.png b/data/images_noti_icons/Etc/noti_shareshot_send_problem.png
new file mode 100755 (executable)
index 0000000..3908b91
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_shareshot_send_problem.png differ
diff --git a/data/images_noti_icons/Etc/noti_side_sync.png b/data/images_noti_icons/Etc/noti_side_sync.png
new file mode 100755 (executable)
index 0000000..d6d4116
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_side_sync.png differ
diff --git a/data/images_noti_icons/Etc/noti_sim_toolkit.png b/data/images_noti_icons/Etc/noti_sim_toolkit.png
new file mode 100755 (executable)
index 0000000..c1a22c3
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_sim_toolkit.png differ
diff --git a/data/images_noti_icons/Etc/noti_smart_stay.png b/data/images_noti_icons/Etc/noti_smart_stay.png
new file mode 100755 (executable)
index 0000000..a5d42bb
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_smart_stay.png differ
diff --git a/data/images_noti_icons/Etc/noti_smemo_sync.png b/data/images_noti_icons/Etc/noti_smemo_sync.png
new file mode 100755 (executable)
index 0000000..86f9cc8
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_smemo_sync.png differ
diff --git a/data/images_noti_icons/Etc/noti_spen.png b/data/images_noti_icons/Etc/noti_spen.png
new file mode 100755 (executable)
index 0000000..0ddd337
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_spen.png differ
diff --git a/data/images_noti_icons/Etc/noti_sync_error.png b/data/images_noti_icons/Etc/noti_sync_error.png
new file mode 100755 (executable)
index 0000000..7cfeb91
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_sync_error.png differ
diff --git a/data/images_noti_icons/Etc/noti_tethering_usb_fail.png b/data/images_noti_icons/Etc/noti_tethering_usb_fail.png
new file mode 100755 (executable)
index 0000000..1613b05
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_tethering_usb_fail.png differ
diff --git a/data/images_noti_icons/Etc/noti_tty_mode.png b/data/images_noti_icons/Etc/noti_tty_mode.png
new file mode 100755 (executable)
index 0000000..da3e17d
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_tty_mode.png differ
diff --git a/data/images_noti_icons/Etc/noti_tv.png b/data/images_noti_icons/Etc/noti_tv.png
new file mode 100755 (executable)
index 0000000..e91bb25
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_tv.png differ
diff --git a/data/images_noti_icons/Etc/noti_updated_complete.png b/data/images_noti_icons/Etc/noti_updated_complete.png
new file mode 100755 (executable)
index 0000000..090db1f
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_updated_complete.png differ
diff --git a/data/images_noti_icons/Etc/noti_updated_failed.png b/data/images_noti_icons/Etc/noti_updated_failed.png
new file mode 100755 (executable)
index 0000000..4b20c1f
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_updated_failed.png differ
diff --git a/data/images_noti_icons/Etc/noti_usb_connected.png b/data/images_noti_icons/Etc/noti_usb_connected.png
new file mode 100755 (executable)
index 0000000..ba90b5c
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_usb_connected.png differ
diff --git a/data/images_noti_icons/Etc/noti_usb_fail.png b/data/images_noti_icons/Etc/noti_usb_fail.png
new file mode 100755 (executable)
index 0000000..46e39e9
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_usb_fail.png differ
diff --git a/data/images_noti_icons/Etc/noti_usb_mass_storage_connected.png b/data/images_noti_icons/Etc/noti_usb_mass_storage_connected.png
new file mode 100755 (executable)
index 0000000..55c5b54
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_usb_mass_storage_connected.png differ
diff --git a/data/images_noti_icons/Etc/noti_usb_unknown_fail.png b/data/images_noti_icons/Etc/noti_usb_unknown_fail.png
new file mode 100755 (executable)
index 0000000..49cff79
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_usb_unknown_fail.png differ
diff --git a/data/images_noti_icons/Etc/noti_video.png b/data/images_noti_icons/Etc/noti_video.png
new file mode 100755 (executable)
index 0000000..de05b7d
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_video.png differ
diff --git a/data/images_noti_icons/Etc/noti_voice_mail.png b/data/images_noti_icons/Etc/noti_voice_mail.png
new file mode 100755 (executable)
index 0000000..64eba75
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_voice_mail.png differ
diff --git a/data/images_noti_icons/Etc/noti_voice_mail_01.png b/data/images_noti_icons/Etc/noti_voice_mail_01.png
new file mode 100755 (executable)
index 0000000..ea8d328
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_voice_mail_01.png differ
diff --git a/data/images_noti_icons/Etc/noti_voice_mail_02.png b/data/images_noti_icons/Etc/noti_voice_mail_02.png
new file mode 100755 (executable)
index 0000000..e60b417
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_voice_mail_02.png differ
diff --git a/data/images_noti_icons/Etc/noti_voice_mail_03.png b/data/images_noti_icons/Etc/noti_voice_mail_03.png
new file mode 100755 (executable)
index 0000000..772159f
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_voice_mail_03.png differ
diff --git a/data/images_noti_icons/Etc/noti_voice_memo.png b/data/images_noti_icons/Etc/noti_voice_memo.png
new file mode 100755 (executable)
index 0000000..26fad27
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_voice_memo.png differ
diff --git a/data/images_noti_icons/Etc/noti_voice_recorder_paused.png b/data/images_noti_icons/Etc/noti_voice_recorder_paused.png
new file mode 100755 (executable)
index 0000000..854662e
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_voice_recorder_paused.png differ
diff --git a/data/images_noti_icons/Etc/noti_voice_recorder_play.png b/data/images_noti_icons/Etc/noti_voice_recorder_play.png
new file mode 100755 (executable)
index 0000000..5356e18
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_voice_recorder_play.png differ
diff --git a/data/images_noti_icons/Etc/noti_wifi_translate.png b/data/images_noti_icons/Etc/noti_wifi_translate.png
new file mode 100755 (executable)
index 0000000..9939949
Binary files /dev/null and b/data/images_noti_icons/Etc/noti_wifi_translate.png differ
diff --git a/data/images_noti_icons/FOTA/noti_fota.png b/data/images_noti_icons/FOTA/noti_fota.png
new file mode 100755 (executable)
index 0000000..df041ce
Binary files /dev/null and b/data/images_noti_icons/FOTA/noti_fota.png differ
diff --git a/data/images_noti_icons/FOTA/noti_fota_completion.png b/data/images_noti_icons/FOTA/noti_fota_completion.png
new file mode 100755 (executable)
index 0000000..76ed4bd
Binary files /dev/null and b/data/images_noti_icons/FOTA/noti_fota_completion.png differ
diff --git a/data/images_noti_icons/FOTA/noti_fota_diagmon.png b/data/images_noti_icons/FOTA/noti_fota_diagmon.png
new file mode 100755 (executable)
index 0000000..b9665be
Binary files /dev/null and b/data/images_noti_icons/FOTA/noti_fota_diagmon.png differ
diff --git a/data/images_noti_icons/FOTA/noti_fota_diagmon_completion.png b/data/images_noti_icons/FOTA/noti_fota_diagmon_completion.png
new file mode 100755 (executable)
index 0000000..577fa94
Binary files /dev/null and b/data/images_noti_icons/FOTA/noti_fota_diagmon_completion.png differ
diff --git a/data/images_noti_icons/FOTA/noti_fota_postpone.png b/data/images_noti_icons/FOTA/noti_fota_postpone.png
new file mode 100755 (executable)
index 0000000..cf08c4d
Binary files /dev/null and b/data/images_noti_icons/FOTA/noti_fota_postpone.png differ
diff --git a/data/images_noti_icons/Facebook/noti_facebook.png b/data/images_noti_icons/Facebook/noti_facebook.png
new file mode 100755 (executable)
index 0000000..d24776a
Binary files /dev/null and b/data/images_noti_icons/Facebook/noti_facebook.png differ
diff --git a/data/images_noti_icons/Facebook/noti_facebook_female_default.png b/data/images_noti_icons/Facebook/noti_facebook_female_default.png
new file mode 100755 (executable)
index 0000000..32a5e7d
Binary files /dev/null and b/data/images_noti_icons/Facebook/noti_facebook_female_default.png differ
diff --git a/data/images_noti_icons/Facebook/noti_facebook_male_default.png b/data/images_noti_icons/Facebook/noti_facebook_male_default.png
new file mode 100755 (executable)
index 0000000..9061b78
Binary files /dev/null and b/data/images_noti_icons/Facebook/noti_facebook_male_default.png differ
diff --git a/data/images_noti_icons/Find my mobile/noti_FMM_call_log.png b/data/images_noti_icons/Find my mobile/noti_FMM_call_log.png
new file mode 100755 (executable)
index 0000000..83e52b6
Binary files /dev/null and b/data/images_noti_icons/Find my mobile/noti_FMM_call_log.png differ
diff --git a/data/images_noti_icons/Find my mobile/noti_FMM_device_located.png b/data/images_noti_icons/Find my mobile/noti_FMM_device_located.png
new file mode 100755 (executable)
index 0000000..f454a2b
Binary files /dev/null and b/data/images_noti_icons/Find my mobile/noti_FMM_device_located.png differ
diff --git a/data/images_noti_icons/Find my mobile/noti_FMM_device_unlocked.png b/data/images_noti_icons/Find my mobile/noti_FMM_device_unlocked.png
new file mode 100755 (executable)
index 0000000..70060f0
Binary files /dev/null and b/data/images_noti_icons/Find my mobile/noti_FMM_device_unlocked.png differ
diff --git a/data/images_noti_icons/Gallery/noti_gallery_image.png b/data/images_noti_icons/Gallery/noti_gallery_image.png
new file mode 100755 (executable)
index 0000000..bfc9522
Binary files /dev/null and b/data/images_noti_icons/Gallery/noti_gallery_image.png differ
diff --git a/data/images_noti_icons/Gallery/noti_gallery_image_error.png b/data/images_noti_icons/Gallery/noti_gallery_image_error.png
new file mode 100755 (executable)
index 0000000..ec95669
Binary files /dev/null and b/data/images_noti_icons/Gallery/noti_gallery_image_error.png differ
diff --git a/data/images_noti_icons/Internet/noti_internet_flightmode.png b/data/images_noti_icons/Internet/noti_internet_flightmode.png
new file mode 100755 (executable)
index 0000000..9f47133
Binary files /dev/null and b/data/images_noti_icons/Internet/noti_internet_flightmode.png differ
diff --git a/data/images_noti_icons/Lock screen/noti_message.png b/data/images_noti_icons/Lock screen/noti_message.png
new file mode 100755 (executable)
index 0000000..2da638e
Binary files /dev/null and b/data/images_noti_icons/Lock screen/noti_message.png differ
diff --git a/data/images_noti_icons/Lock screen/noti_missed_call.png b/data/images_noti_icons/Lock screen/noti_missed_call.png
new file mode 100755 (executable)
index 0000000..1384e6f
Binary files /dev/null and b/data/images_noti_icons/Lock screen/noti_missed_call.png differ
diff --git a/data/images_noti_icons/Low battery&charge/noti_battery_fully_charging.png b/data/images_noti_icons/Low battery&charge/noti_battery_fully_charging.png
new file mode 100755 (executable)
index 0000000..84b1b56
Binary files /dev/null and b/data/images_noti_icons/Low battery&charge/noti_battery_fully_charging.png differ
diff --git a/data/images_noti_icons/Low battery&charge/noti_charging_battery_low.png b/data/images_noti_icons/Low battery&charge/noti_charging_battery_low.png
new file mode 100755 (executable)
index 0000000..f2d3c78
Binary files /dev/null and b/data/images_noti_icons/Low battery&charge/noti_charging_battery_low.png differ
diff --git a/data/images_noti_icons/Low battery&charge/noti_charging_cable_disconnected.png b/data/images_noti_icons/Low battery&charge/noti_charging_cable_disconnected.png
new file mode 100755 (executable)
index 0000000..09b9e09
Binary files /dev/null and b/data/images_noti_icons/Low battery&charge/noti_charging_cable_disconnected.png differ
diff --git a/data/images_noti_icons/Message/noti_message.png b/data/images_noti_icons/Message/noti_message.png
new file mode 100755 (executable)
index 0000000..e2983d7
Binary files /dev/null and b/data/images_noti_icons/Message/noti_message.png differ
diff --git a/data/images_noti_icons/Message/noti_message_OTA.png b/data/images_noti_icons/Message/noti_message_OTA.png
new file mode 100755 (executable)
index 0000000..4c2a6ba
Binary files /dev/null and b/data/images_noti_icons/Message/noti_message_OTA.png differ
diff --git a/data/images_noti_icons/Message/noti_message_cb-msg.png b/data/images_noti_icons/Message/noti_message_cb-msg.png
new file mode 100755 (executable)
index 0000000..11a9029
Binary files /dev/null and b/data/images_noti_icons/Message/noti_message_cb-msg.png differ
diff --git a/data/images_noti_icons/Message/noti_message_delivery_report.png b/data/images_noti_icons/Message/noti_message_delivery_report.png
new file mode 100755 (executable)
index 0000000..9f35482
Binary files /dev/null and b/data/images_noti_icons/Message/noti_message_delivery_report.png differ
diff --git a/data/images_noti_icons/Message/noti_message_failed.png b/data/images_noti_icons/Message/noti_message_failed.png
new file mode 100755 (executable)
index 0000000..cd7b0ab
Binary files /dev/null and b/data/images_noti_icons/Message/noti_message_failed.png differ
diff --git a/data/images_noti_icons/Message/noti_message_mms_failed.png b/data/images_noti_icons/Message/noti_message_mms_failed.png
new file mode 100755 (executable)
index 0000000..6b9d46d
Binary files /dev/null and b/data/images_noti_icons/Message/noti_message_mms_failed.png differ
diff --git a/data/images_noti_icons/Message/noti_message_mms_problem.png b/data/images_noti_icons/Message/noti_message_mms_problem.png
new file mode 100755 (executable)
index 0000000..2732355
Binary files /dev/null and b/data/images_noti_icons/Message/noti_message_mms_problem.png differ
diff --git a/data/images_noti_icons/Message/noti_message_read_report.png b/data/images_noti_icons/Message/noti_message_read_report.png
new file mode 100755 (executable)
index 0000000..ed7d6df
Binary files /dev/null and b/data/images_noti_icons/Message/noti_message_read_report.png differ
diff --git a/data/images_noti_icons/Message/noti_message_reply.png b/data/images_noti_icons/Message/noti_message_reply.png
new file mode 100755 (executable)
index 0000000..132964f
Binary files /dev/null and b/data/images_noti_icons/Message/noti_message_reply.png differ
diff --git a/data/images_noti_icons/Message/noti_message_scheduled.png b/data/images_noti_icons/Message/noti_message_scheduled.png
new file mode 100755 (executable)
index 0000000..271b598
Binary files /dev/null and b/data/images_noti_icons/Message/noti_message_scheduled.png differ
diff --git a/data/images_noti_icons/Message/noti_message_sending.png b/data/images_noti_icons/Message/noti_message_sending.png
new file mode 100755 (executable)
index 0000000..71afba0
Binary files /dev/null and b/data/images_noti_icons/Message/noti_message_sending.png differ
diff --git a/data/images_noti_icons/Message/noti_message_sim-card.png b/data/images_noti_icons/Message/noti_message_sim-card.png
new file mode 100755 (executable)
index 0000000..2d079de
Binary files /dev/null and b/data/images_noti_icons/Message/noti_message_sim-card.png differ
diff --git a/data/images_noti_icons/Message/noti_mms.png b/data/images_noti_icons/Message/noti_mms.png
new file mode 100755 (executable)
index 0000000..501d72b
Binary files /dev/null and b/data/images_noti_icons/Message/noti_mms.png differ
diff --git a/data/images_noti_icons/Message/noti_voice_mail.png b/data/images_noti_icons/Message/noti_voice_mail.png
new file mode 100755 (executable)
index 0000000..e795964
Binary files /dev/null and b/data/images_noti_icons/Message/noti_voice_mail.png differ
diff --git a/data/images_noti_icons/Multi SIM/noti_no_sim.png b/data/images_noti_icons/Multi SIM/noti_no_sim.png
new file mode 100755 (executable)
index 0000000..4ce3264
Binary files /dev/null and b/data/images_noti_icons/Multi SIM/noti_no_sim.png differ
diff --git a/data/images_noti_icons/Multi SIM/noti_sim_full.png b/data/images_noti_icons/Multi SIM/noti_sim_full.png
new file mode 100755 (executable)
index 0000000..5e73f19
Binary files /dev/null and b/data/images_noti_icons/Multi SIM/noti_sim_full.png differ
diff --git a/data/images_noti_icons/Patterns/noti_cooling_down.png b/data/images_noti_icons/Patterns/noti_cooling_down.png
new file mode 100755 (executable)
index 0000000..39f6bc9
Binary files /dev/null and b/data/images_noti_icons/Patterns/noti_cooling_down.png differ
diff --git a/data/images_noti_icons/Patterns/noti_screen_captured.png b/data/images_noti_icons/Patterns/noti_screen_captured.png
new file mode 100755 (executable)
index 0000000..e11837f
Binary files /dev/null and b/data/images_noti_icons/Patterns/noti_screen_captured.png differ
diff --git a/data/images_noti_icons/Private mode/noti_private_mode.png b/data/images_noti_icons/Private mode/noti_private_mode.png
new file mode 100755 (executable)
index 0000000..4b1e51b
Binary files /dev/null and b/data/images_noti_icons/Private mode/noti_private_mode.png differ
diff --git a/data/images_noti_icons/Send help messages/noti_icon_emergency.png b/data/images_noti_icons/Send help messages/noti_icon_emergency.png
new file mode 100755 (executable)
index 0000000..8ca7153
Binary files /dev/null and b/data/images_noti_icons/Send help messages/noti_icon_emergency.png differ
diff --git a/data/images_noti_icons/Send help messages/noti_send_emergency_msg.png b/data/images_noti_icons/Send help messages/noti_send_emergency_msg.png
new file mode 100755 (executable)
index 0000000..a162d25
Binary files /dev/null and b/data/images_noti_icons/Send help messages/noti_send_emergency_msg.png differ
diff --git a/data/images_noti_icons/Share with contents/noti_icon_Id_default.png b/data/images_noti_icons/Share with contents/noti_icon_Id_default.png
new file mode 100755 (executable)
index 0000000..0fd98f7
Binary files /dev/null and b/data/images_noti_icons/Share with contents/noti_icon_Id_default.png differ
diff --git a/data/images_noti_icons/Tethering/noti_tethering.png b/data/images_noti_icons/Tethering/noti_tethering.png
new file mode 100755 (executable)
index 0000000..c065f82
Binary files /dev/null and b/data/images_noti_icons/Tethering/noti_tethering.png differ
diff --git a/data/images_noti_icons/Tethering/noti_tethering_all.png b/data/images_noti_icons/Tethering/noti_tethering_all.png
new file mode 100755 (executable)
index 0000000..398ffd7
Binary files /dev/null and b/data/images_noti_icons/Tethering/noti_tethering_all.png differ
diff --git a/data/images_noti_icons/Tethering/noti_tethering_bt.png b/data/images_noti_icons/Tethering/noti_tethering_bt.png
new file mode 100755 (executable)
index 0000000..c51f6a5
Binary files /dev/null and b/data/images_noti_icons/Tethering/noti_tethering_bt.png differ
diff --git a/data/images_noti_icons/Tethering/noti_tethering_usb.png b/data/images_noti_icons/Tethering/noti_tethering_usb.png
new file mode 100755 (executable)
index 0000000..0062f02
Binary files /dev/null and b/data/images_noti_icons/Tethering/noti_tethering_usb.png differ
diff --git a/data/images_noti_icons/Tethering/noti_tethering_wifi.png b/data/images_noti_icons/Tethering/noti_tethering_wifi.png
new file mode 100755 (executable)
index 0000000..76eb00e
Binary files /dev/null and b/data/images_noti_icons/Tethering/noti_tethering_wifi.png differ
diff --git a/data/images_noti_icons/Tizen store/noti_tizen_store.png b/data/images_noti_icons/Tizen store/noti_tizen_store.png
new file mode 100755 (executable)
index 0000000..883ac2a
Binary files /dev/null and b/data/images_noti_icons/Tizen store/noti_tizen_store.png differ
diff --git a/data/images_noti_icons/Wi-Fi/noti_wifi.png b/data/images_noti_icons/Wi-Fi/noti_wifi.png
new file mode 100755 (executable)
index 0000000..f480fd0
Binary files /dev/null and b/data/images_noti_icons/Wi-Fi/noti_wifi.png differ
diff --git a/data/images_noti_icons/Wi-Fi/noti_wifi_availablility_check1.png b/data/images_noti_icons/Wi-Fi/noti_wifi_availablility_check1.png
new file mode 100755 (executable)
index 0000000..274cf15
Binary files /dev/null and b/data/images_noti_icons/Wi-Fi/noti_wifi_availablility_check1.png differ
diff --git a/data/images_noti_icons/Wi-Fi/noti_wifi_direct.png b/data/images_noti_icons/Wi-Fi/noti_wifi_direct.png
new file mode 100755 (executable)
index 0000000..5c1b553
Binary files /dev/null and b/data/images_noti_icons/Wi-Fi/noti_wifi_direct.png differ
diff --git a/data/images_noti_icons/Wi-Fi/noti_wifi_direct_auto_off.png b/data/images_noti_icons/Wi-Fi/noti_wifi_direct_auto_off.png
new file mode 100755 (executable)
index 0000000..5c1b553
Binary files /dev/null and b/data/images_noti_icons/Wi-Fi/noti_wifi_direct_auto_off.png differ
diff --git a/data/images_noti_icons/Wi-Fi/noti_wifi_in_range.png b/data/images_noti_icons/Wi-Fi/noti_wifi_in_range.png
new file mode 100755 (executable)
index 0000000..1aac451
Binary files /dev/null and b/data/images_noti_icons/Wi-Fi/noti_wifi_in_range.png differ
diff --git a/data/images_noti_icons/Wi-Fi/noti_wifi_network_available.png b/data/images_noti_icons/Wi-Fi/noti_wifi_network_available.png
new file mode 100755 (executable)
index 0000000..f480fd0
Binary files /dev/null and b/data/images_noti_icons/Wi-Fi/noti_wifi_network_available.png differ
diff --git a/data/images_noti_icons/Wi-Fi/noti_wifi_no_detected.png b/data/images_noti_icons/Wi-Fi/noti_wifi_no_detected.png
new file mode 100755 (executable)
index 0000000..274cf15
Binary files /dev/null and b/data/images_noti_icons/Wi-Fi/noti_wifi_no_detected.png differ
diff --git a/data/images_noti_icons/Wi-Fi/noti_wifi_no_sign.png b/data/images_noti_icons/Wi-Fi/noti_wifi_no_sign.png
new file mode 100755 (executable)
index 0000000..1aac451
Binary files /dev/null and b/data/images_noti_icons/Wi-Fi/noti_wifi_no_sign.png differ
diff --git a/data/images_noti_icons/Wi-Fi/noti_wifi_translate.png b/data/images_noti_icons/Wi-Fi/noti_wifi_translate.png
new file mode 100755 (executable)
index 0000000..9939949
Binary files /dev/null and b/data/images_noti_icons/Wi-Fi/noti_wifi_translate.png differ
diff --git a/data/quickpanel b/data/quickpanel
new file mode 100755 (executable)
index 0000000..9af4b47
--- /dev/null
@@ -0,0 +1 @@
+/usr/apps/org.tizen.quickpanel/bin/quickpanel &
diff --git a/data/quickpanel.desktop.in b/data/quickpanel.desktop.in
new file mode 100755 (executable)
index 0000000..654043c
--- /dev/null
@@ -0,0 +1,14 @@
+[Desktop Entry]
+Encoding=UTF-8
+Name=@PROJECT_NAME@
+Comment=@PROJECT_NAME@
+Exec=@BINDIR@/@PROJECT_NAME@
+Icon=@PKGNAME@.png
+Terminal=false
+Type=Application
+Categories=Application;Utility;
+Version=0.1.0
+Nodisplay=True
+X-TIZEN-TaskManage=False
+X-TIZEN-Multiple=False
+X-TIZEN-Removable=False
diff --git a/data/quickpanel.edc b/data/quickpanel.edc
new file mode 100755 (executable)
index 0000000..8cde33a
--- /dev/null
@@ -0,0 +1,539 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#include "quickpanel_def.h"
+#include "color_classes.edc"
+
+#define QP_SETTING_H   221
+#define QP_SETTING_SEPERATOR_H 0
+#define QP_SETTING_SEPERATOR_COLOR "AO007"
+#define QP_HANDLER_COLOR "AO010"
+#define QP_HANDLER_PRESS_COLOR "AO010S"
+
+
+
+#define QUICKPANEL_FOCUS_OBJECT(NAME, TO_1, TO_2)\
+                       part {\
+                               name: NAME;\
+                               type: SWALLOW;\
+                               scale: 1;\
+                               mouse_events: 1;\
+                               repeat_events: 1;\
+                               description {\
+                                       state: "default" 0.0;\
+                                       rel1 { relative: 0.0 0.00; to, TO_1; }\
+                                       rel2 { relative: 1.0 1.00; to, TO_2; }\
+                                       fixed: 1 1;\
+                                       visible: 1;\
+                               }\
+                               description {\
+                                       state: "show" 0.0;\
+                                       inherit: "default" 0.0;\
+                                       visible: 1;\
+                               }\
+                               description {\
+                                       state: "hide" 0.0;\
+                                       inherit: "default" 0.0;\
+                                       visible: 0;\
+                               }\
+                       }\
+
+#define QUICKPANEL_FOCUS_OBJECT_WITH_OFFSET(NAME, TO_1, TO_2, OFFSET_X, OFFSET_Y)\
+                       part {\
+                               name: NAME;\
+                               type: SWALLOW;\
+                               scale: 1;\
+                               mouse_events: 1;\
+                               repeat_events: 1;\
+                               description {\
+                                       state: "default" 0.0;\
+                                       rel1 { relative: 0.0 0.00; to, TO_1; offset: -OFFSET_X -OFFSET_Y;}\
+                                       rel2 { relative: 1.0 1.00; to, TO_2; offset: +OFFSET_X +OFFSET_Y; }\
+                                       fixed: 1 1;\
+                                       visible: 1;\
+                               }\
+                       }\
+
+images
+{
+       image: "handler_bg.#.png" COMP;
+       image: "handler_bg_ef.#.png" COMP;
+       image: "handler_btn_02.png" COMP;
+       image: "core_theme_bg_01.png" COMP;
+}
+
+collections {
+       base_scale: 1.8;
+       group {
+               name: "quickpanel/root";
+
+               script {
+                       public g_is_portrait;
+
+                       public init_variables() {
+                               set_int(g_is_portrait, 1);
+                       }
+               }
+
+               parts {
+                       part {
+                               name: "base";
+                               type: RECT;
+                               scale: 1;
+                               mouse_events: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       visible: 1;
+                               }
+                       }
+
+
+                       part {
+                               name: "background";
+                               type: IMAGE;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 1 1;
+                                       align: 0.5 0.5;
+                                       rel1 {
+                                               to: "base";
+                                       }
+                                       rel2 {
+                                               to: "base";
+                                       }
+                                       image {
+                                               normal: "core_theme_bg_01.png";
+                                       }
+                               }
+                       }
+
+                       part{
+                               name: "qp.base.rect.datetime";
+                               type:SPACER;
+                               scale:1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 0 1;
+                                       min: 0 QP_DATE_H;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to: "background";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 0.0;
+                                               to: "background";
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part{
+                               name: "qp.base.datetime.swallow";
+                               type:SWALLOW;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 0 1;
+                                       rel1 {
+                                               to: "qp.base.rect.datetime";
+                                       }
+                                       rel2 {
+                                               to: "qp.base.rect.datetime";
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part{
+                               name: "qp.root.swallow";
+                               type:SWALLOW;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1 {
+                                               relative: 0.0 1.0;
+                                               to_x: "background";
+                                               to_y: "qp.base.datetime.swallow";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 0.0;
+                                               to_x: "background";
+                                               to_y: "qp.handler.bg";
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part
+                       {
+                               name: "qp.handler.bg";
+                               type:IMAGE;
+                               scale:1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 0 1;
+                                       min: 0 QP_HANDLE_H;
+                                       rel1 {
+                                               relative: 0.0 1.0;
+                                               to: "background";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 1.0;
+                                               to: "background";
+                                       }
+                                       image {
+                                               normal:"handler_bg.#.png";
+                                       }
+                                       align: 0.0 1.0;
+                                       color_class: "W0113";
+                               }
+                               description {
+                                       state: "pressed" 0.0;
+                                       inherit: "default";
+                                       color_class: "W0113P";
+                               }
+                       }
+
+                       part
+                       {
+                               name: "qp.handler.effect";
+                               type:IMAGE;
+                               scale:1;
+                               description {
+                                       state: "default" 0.0;
+
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to: "qp.handler.bg";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 1.0;
+                                               to: "qp.handler.bg";
+                                       }
+                                       image {
+                                               normal:"handler_bg_ef.#.png";
+                                       }
+                                       align: 0.0 1.0;
+                                       color_class: "AO007L2";
+                               }
+                       }
+
+                       part
+                       {
+                               name: "qp.handler.button";
+                               type:IMAGE;
+                               scale:1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 50 50;
+                                       max: 50 50;
+                                       fixed: 1 1;
+                                       rel1
+                                       {
+                                               relative: 0.5 0.0;
+                                               to: "qp.handler.bg";
+                                       }
+                                       rel2
+                                       {
+                                               relative: 0.5 1.0;
+                                               to: "qp.handler.bg";
+                                       }
+                                       image {
+                                               normal:"handler_btn_02.png";
+                                       }
+
+                                       align: 0.5 0.5;
+                                       color_class: "AO007L1";
+                                       visible: 1;
+                               }
+                               description {
+                                       state: "text.show" 0.0;
+                                       inherit: "default";
+                                       visible: 0;
+                               }
+                               description {
+                                       state: "text.hide" 0.0;
+                                       inherit: "default";
+                                       visible: 1;
+                               }
+                       }
+
+                       part
+                       {
+                               name: "qp.handler.text";
+                               type:TEXT;
+                               scale:1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 0 1;
+                                       min: 0 QP_HANDLE_H;
+                                       align: 0.5 0.5;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to: "qp.handler.bg";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 1.0;
+                                               to: "qp.handler.bg";
+                                       }
+
+                                       text {
+                                               font : "Tizen:style=Regular";
+                                               size : 25;
+                                               text_class : "Tizen";
+                                       }
+                                       color_class: "AO007L1";
+                                       visible: 1;
+                               }
+                               description
+                               {
+                                       state: "text.show" 0.0;
+                                       inherit: "default";
+                                       visible: 1;
+                               }
+                               description
+                               {
+                                       state: "text.hide" 0.0;
+                                       inherit: "default";
+                                       visible: 0;
+                               }
+                       }
+               }
+
+               programs
+               {
+                       program
+                       {
+                               name: "init.layout";
+                               signal: "load";
+                               source: "";
+                               in: 0.0 0.0;
+                               script{
+                                       init_variables();
+                               }
+                       }
+                       program {
+                               name: "text.show";
+                               signal: "show";
+                               source: "qp.handler.text";
+                               action: STATE_SET "text.show" 0.0;
+                               target: "qp.handler.button";
+                               target: "qp.handler.text";
+                       }
+                       program {
+                               name: "text.hide";
+                               signal: "hide";
+                               source: "qp.handler.text";
+                               action: STATE_SET "text.hide" 0.0;
+                               target: "qp.handler.button";
+                               target: "qp.handler.text";
+                       }
+                       program {
+                               name: "handler.press";
+                               signal: "mouse,down,1";
+                               source: "qp.handler.bg";
+                               action: STATE_SET "pressed" 0.0;
+                               target: "qp.handler.bg";
+                       }
+                       program {
+                               name: "handler.release";
+                               signal: "mouse,up,1";
+                               source: "qp.handler.bg";
+                               action: STATE_SET "default" 0.0;
+                               target: "qp.handler.bg";
+                       }
+               }
+       }
+
+       group {
+               name: "quickpanel/base";
+               parts {
+                       part {
+                               name: "background";
+                               type: SPACER;
+                               scale: 1;
+                               mouse_events: 1;
+                               description {
+                                       state: "default" 0.0;
+                               }
+                               description {
+                                       state: "portrait" 0.0;
+                                       inherit: "default" 0.0;
+                               }
+                               description {
+                                       state: "landscape" 0.0;
+                                       inherit: "default" 0.0;
+                               }
+                       }
+                       part{
+                               name: "qp.base.rect.setting";
+                               type:SPACER;
+                               scale:1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 0 1;
+                                       min: 0 QP_SETTING_H;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to: "background";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 0.0;
+                                               to: "background";
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                               description {
+                                       state: "show" 0.0;
+                                       inherit: "default" 0.0;
+                               }
+                               description {
+                                       state: "hide" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: 0 0;
+                                       max: 0 0;
+                               }
+                       }
+                       part{
+                               name: "qp.base.setting.swallow";
+                               type:SWALLOW;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 0 1;
+                                       rel1 {
+                                               to: "qp.base.rect.setting";
+                                       }
+                                       rel2 {
+                                               to: "qp.base.rect.setting";
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "background.touch";
+                               type: SWALLOW;
+                               scale: 1;
+                               mouse_events:1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 0 0;
+                                       min: 0 QP_SETTING_SEPERATOR_H;
+                                       rel1 {
+                                               to_y:"qp.base.setting.swallow";
+                                               relative: 0.0 1.0;
+                                       }
+                                       rel2 {
+                                               to_y:"background";
+                                               relative: 1.0 1.0;
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                               description {
+                                       state: "enable_voice_icon" 0.0;
+                                       inherit: "default";
+                                       rel1 {
+                                               to_y:"qp.base.setting.swallow";
+                                               relative: 0.0 1.0;
+                                               offset : 0 110;
+                                       }
+                               }
+                       }
+                       part {
+                               name: "qp.base.list.swallow";
+                               type: SWALLOW;
+                               scale: 1;
+                               repeat_events: 1;
+                               mouse_events:1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 0 0;
+                                       rel1 {
+                                               to_y:"qp.base.setting.swallow";
+                                               relative: 0.0 1.0;
+                                       }
+                                       rel2 {
+                                               to_y:"background";
+                                               relative: 1.0 1.0;
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+               }
+               programs {
+                       program{
+                               name: "portrait";
+                               signal: "portrait";
+                               source: "prog";
+                               action: STATE_SET "portrait" 0.0;
+                               target: "background";
+                       }
+                       program{
+                               name: "landscape";
+                               signal: "landscape";
+                               source: "prog";
+                               action: STATE_SET "landscape" 0.0;
+                               target: "background";
+                       }
+                       program {
+                               name: "setting.show";
+                               action: STATE_SET "show" 0.0;
+                               signal: "quickpanel.setting.show";
+                               source: "quickpanel.prog";
+                               target: "qp.base.rect.setting";
+                               target: "qp.base.setting.swallow";
+                       }
+                       program {
+                               name: "setting.hide";
+                               action: STATE_SET "hide" 0.0;
+                               signal: "quickpanel.setting.hide";
+                               source: "quickpanel.prog";
+                               target: "qp.base.rect.setting";
+                               target: "qp.base.setting.swallow";
+                       }
+                       program {
+                               name: "voice_icon.show";
+                               action: STATE_SET "enable_voice_icon" 0.0;
+                               signal: "voice_icon.show";
+                               source: "quickpanel.prog";
+                               target: "background.touch";
+                       }
+                       program {
+                               name: "voice_icon.hide";
+                               action: STATE_SET "default" 0.0;
+                               signal: "voice_icon.hide";
+                               source: "quickpanel.prog";
+                               target: "background.touch";
+                       }
+                       program {
+                               name: "background.touch";
+                               action: SIGNAL_EMIT "close.quickpanel" "";
+                               signal: "mouse,down,1";
+                               source: "background";
+                       }
+               }
+       }
+
+#include "quickpanel_setting.edc"
+#include "quickpanel_datetime.edc"
+#include "quickpanel_brightness.edc"
+#include "quickpanel_minictrl.edc"
+#include "quickpanel_noti_section.edc"
+#include "quickpanel_listitem_noti.edc"
+#include "quickpanel_listitem_ongoing.edc"
+#include "quickpanel_animated_icon.edc"
+#include "quickpanel_images.edc"
+}
diff --git a/data/quickpanel.sh.in b/data/quickpanel.sh.in
new file mode 100755 (executable)
index 0000000..cf77090
--- /dev/null
@@ -0,0 +1 @@
+@BINDIR@/@PROJECT_NAME@ &
diff --git a/data/quickpanel.xml.in b/data/quickpanel.xml.in
new file mode 100755 (executable)
index 0000000..432bf3f
--- /dev/null
@@ -0,0 +1,32 @@
+<?xml version="1.0" encoding="utf-8"?>
+<manifest xmlns="http://tizen.org/ns/packages" package="@PKGNAME@" version="0.8.0" install-location="internal-only" api-version="3.0">
+       <label>@PROJECT_NAME@</label>
+       <author email="yjoo93.park@samsung.com" href="www.samsung.com">Youngjoo Park</author>
+       <author email="jin0.kim@samsung.com" href="www.samsung.com">Jinyoung Kim</author>
+       <description>@PROJECT_NAME@</description>
+       <ui-application appid="@PKGNAME@" exec="@BINDIR@/@PROJECT_NAME@" nodisplay="true" multiple="false" type="capp" taskmanage="false" hw-acceleration="use-GL">
+               <label>@PROJECT_NAME@</label>
+       </ui-application>
+       <privileges>
+               <privilege>http://tizen.org/privilege/appmanager.launch</privilege>
+               <privilege>http://tizen.org/privilege/system</privilege>
+               <privilege>http://tizen.org/privilege/systemsettings.admin</privilege>
+               <privilege>http://tizen.org/privilege/location</privilege>
+               <privilege>http://tizen.org/privilege/location.enable</privilege>
+               <privilege>http://tizen.org/privilege/bluetooth</privilege>
+               <privilege>http://tizen.org/privilege/bluetooth.admin</privilege>
+               <privilege>http://tizen.org/privilege/notification</privilege>
+               <privilege>http://tizen.org/privilege/telephony</privilege>
+               <privilege>http://tizen.org/privilege/telephony.admin</privilege>
+               <privilege>http://tizen.org/privilege/tethering.admin</privilege>
+               <privilege>http://tizen.org/privilege/wifidirect</privilege>
+               <privilege>http://tizen.org/privilege/network.set</privilege>
+               <privilege>http://tizen.org/privilege/network.get</privilege>
+               <privilege>http://tizen.org/privilege/packagemanager.info</privilege>
+               <privilege>http://tizen.org/privilege/display</privilege>
+               <privilege>http://tizen.org/privilege/haptic</privilege>
+               <privilege>http://tizen.org/privilege/led</privilege>
+               <privilege>http://tizen.org/privilege/keygrab</privilege>
+               <privilege>http://tizen.org/privilege/window.priority.set</privilege>
+       </privileges>
+</manifest>
diff --git a/data/quickpanel_activenoti.edc b/data/quickpanel_activenoti.edc
new file mode 100755 (executable)
index 0000000..af4e638
--- /dev/null
@@ -0,0 +1,641 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include "color_classes.edc"
+
+#define ACTIVENOTI_BG_COLOR "AO003"
+#define ACTIVENOTI_MAIN_TEXT_HEIGHT_INC 1
+
+#define BOX_ICON_SIZE_W 96
+#define BOX_ICON_SIZE_H 96
+#define BOX_ICON_BG_SIZE_W 96
+#define BOX_ICON_BG_SIZE_H 96
+
+images
+{
+       image: "handler_btn_02.png" COMP;
+       image: "core_theme_bg_01.png" COMP;
+       image: "core_list_button_bg.#.png" COMP;
+}
+
+collections
+{
+       base_scale: 1.8;
+
+       group {
+               name: "headsup/base";
+
+               styles {
+                       style {
+                               name: "style_title_text";
+                               base: "font=Tizen:style=Bold font_size="33" color=#FFFFFFFF  text_class=tizen wrap=mixed ellipsis=1.0";
+                       }
+               }
+
+               styles {
+                       style {
+                               name: "style_main_text";
+                               base: "font=Tizen:style=Regular font_size="29" color=#FFFFFFFF  text_class=tizen wrap=mixed ellipsis=1.0";
+                       }
+               }
+
+               images {
+                       image: "quick_button_icon_bg.png" COMP;
+               }
+
+               parts {
+                       part {
+                               name: "background";
+                               type: SWALLOW;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+
+                       part {
+                               name: "bg";
+                               type: IMAGE;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.0 0.0;
+                                       rel1 {
+                                               to: "background";
+                                       }
+                                       rel2 {
+                                               to: "background";
+                                       }
+                                       image {
+                                               normal: "core_theme_bg_01.png";
+                                       }
+                               }
+                       }
+
+
+                       part {
+                               name: "bg_img";
+                               type: SWALLOW;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.0 0.0;
+                                       rel1 {
+                                               to: "bg";
+                                       }
+                                       rel2 {
+                                               to: "bg";
+                                       }
+                               }
+                       }
+
+
+                       part {
+                               name: "rect_main";
+                               type: RECT;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1
+                                       {
+                                               relative: 0.0 0.05;
+                                               to: "bg";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 0.6;
+                                               to: "bg";
+                                       }
+                                       align: 0.0 0.0;
+                                       visible: 0;
+                               }
+                       }
+
+                       part{
+                               name: "button.space";
+                               type:SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1 {
+                                               relative: 0.0 0.6;
+                                               to: "bg";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 0.9;
+                                               to: "bg";
+                                       }
+                               }
+                       }
+
+                       part{
+                               name: "button.swallow";
+                               type:SWALLOW;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to: "button.space";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 1.0;
+                                               to: "button.space";
+                                       }
+                                       visible: 1;
+                               }
+                               description {
+                                       state: "btn_hide" 0.0;
+                                       inherit: "default" 0.0;
+                                       visible: 0;
+                               }
+                               description {
+                                       state: "btn_show" 0.0;
+                                       inherit: "default" 0.0;
+                               }
+                       }
+
+
+                       part {
+                               name: "rect_handle";
+                               type: RECT;
+                               mouse_events: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.0 1.0;
+                                       fixed: 0 1;
+                                       min: 0 40;
+                                       rel1 {
+                                               relative: 0.0 0.9;
+                                               to: "bg";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 1.0;
+                                               to: "bg";
+                                       }
+                                       visible: 1;
+                                       color : 0 0 0 0;
+                               }
+                       }
+
+                       part {
+                               name: "handle_img";
+                               type: IMAGE;
+                               mouse_events: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       max: 40 40;
+                                       align: 0.5 0.5;
+                                       rel1 {
+                                               to: "rect_handle";
+                                       }
+                                       rel2 {
+                                               to: "rect_handle";
+                                       }
+                                       image {
+                                               normal: "handler_btn_02.png";
+                                       }
+                               }
+                       }
+
+
+                       part {
+                               name: "elm.padding.image";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 32 0;
+                                       fixed: 1 0;
+                                       rel1.to:"rect_main";
+                                       rel2.to:"rect_main";
+                                       rel1.relative: 1.0 0.0;
+                                       rel2.relative: 1.0 1.0;
+                                       align: 1.0 0.0;
+                               }
+                       }
+
+
+                       // Icon
+                       part {
+                               name: "icon_space";
+                               mouse_events: 1;
+                               type: RECT;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.0 0.0;
+                                       rel1 {
+                                               relative: 0.03 0.1;
+                                               to: "rect_main";
+                                       }
+                                       rel2 {
+                                               relative: 0.2 0.7;
+                                               to: "rect_main";
+                                       }
+                                       visible: 0;
+                               }
+                       }
+
+                       part {
+                               name: "masking";
+                               type: IMAGE;
+                               precise_is_inside: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min : BOX_ICON_BG_SIZE_W BOX_ICON_BG_SIZE_H;
+                                       fixed : 1 1;
+                                       rel1 {
+                                               relative: 0.5 0.5;
+                                               to: "icon_space";
+                                       }
+                                       rel2 {
+                                               relative: 0.5 0.5;
+                                               to: "icon_space";
+                                       }
+                                       image.normal: "quick_button_icon_bg.png";
+                               }
+                       }
+
+                       part {
+                               name: "icon_big";
+                               type: SWALLOW;
+                               clip_to : "masking";
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.5 0.5;
+                                       min : BOX_ICON_SIZE_W BOX_ICON_SIZE_H;
+                                       max : BOX_ICON_BG_SIZE_W BOX_ICON_BG_SIZE_W;
+                                       fixed : 1 1;
+                                       rel1 {
+                                               relative: 0.5 0.5;
+                                               to: "icon_space";
+                                       }
+                                       rel2 {
+                                               relative: 0.5 0.5;
+                                               to: "icon_space";
+                                       }
+                               }
+                       }
+
+                       part {
+                               name: "icon_badge";
+                               type: SWALLOW;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.0 1.0;
+                                       fixed : 1 1;
+                                       min : 45 45;
+                                       rel1 {
+                                               relative: 0.6 0.6;
+                                               to: "icon_big";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 1.0;
+                                               to: "icon_big";
+                                       }
+                               }
+                       }
+
+
+                       /*text*/
+                       part {
+                               name: "text_space";
+                               type: RECT;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.0 0.5;
+                                       rel1 {
+                                               relative: 0.22 0.0;
+                                               to: "rect_main";
+                                       }
+                                       rel2 {
+                                               relative: 0.98 0.89;
+                                               to: "rect_main";
+                                       }
+                                       visible: 0;
+                               }
+                       }
+
+                       part {
+                               name: "subtitle_text";
+                               type: TEXTBLOCK;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.0 0.0;
+                                       fixed: 1 1;
+                                       text {
+                                               style : "style_main_text";
+                                               align: 0.0 0.0;
+                                       }
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to: "text_space";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 0.0;
+                                               to: "text_space";
+                                       }
+                               }
+                               description {
+                                       state: "sub_show" 0.0;
+                                       inherit: "default" 0.0;
+                                       fixed: 0 0;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to: "text_space";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 0.25;
+                                               to: "text_space";
+                                       }
+                               }
+                               description {
+                                       state: "sub_hide" 0.0;
+                                       inherit: "default" 0.0;
+                               }
+                       }
+
+                       part {
+                               name: "title_text";
+                               type: TEXTBLOCK;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.0 0.0;
+                                       text {
+                                               style : "style_title_text";
+                                               align: 0.0 0.0;
+                                       }
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to: "text_space";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 0.3;
+                                               to: "text_space";
+                                       }
+                               }
+                               description {
+                                       state: "sub_show" 0.0;
+                                       inherit: "default" 0.0;
+                                       rel1 {
+                                               relative: 0.0 0.3;
+                                               to: "text_space";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 0.6;
+                                               to: "text_space";
+                                       }
+
+                               }
+                               description {
+                                       state: "sub_hide" 0.0;
+                                       inherit: "default" 0.0;
+                               }
+                       }
+
+                       part {
+                               name: "content_text";
+                               type: TEXTBLOCK;
+                               scale: 1;
+                               multiline: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.0 0.0;
+                                       text {
+                                               style: "style_main_text";
+                                               align: 0.0 0.5;
+                                       }
+                                       rel1 {
+                                               relative: 0.0 0.3;
+                                               to: "text_space";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 0.9;
+                                               to: "text_space";
+                                       }
+                               }
+                               description {
+                                       state: "sub_show" 0.0;
+                                       inherit: "default" 0.0;
+                                       rel1 {
+                                               relative: 0.0 0.6;
+                                               to: "text_space";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 1.0;
+                                               to: "text_space";
+                                       }
+                               }
+                               description {
+                                       state: "sub_hide" 0.0;
+                                       inherit: "default" 0.0;
+                               }
+                       }
+
+                       part {
+                               name: "touch";
+                               mouse_events: 1;
+                               type: RECT;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.0 0.0;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to: "text_space";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 1.0;
+                                               to: "text_space";
+                                       }
+                                       color : 0 0 0 0;
+                               }
+                       }
+               }
+
+
+               programs {
+                       program {
+                               name: "pressed_noti";
+                               signal: "mouse,clicked,1";
+                               source: "touch";
+                               action: SIGNAL_EMIT "noti_press" "";
+                       }
+
+                       program {
+                               name: "pressed_image";
+                               signal: "mouse,clicked,1";
+                               source: "icon_big";
+                               action: SIGNAL_EMIT "image_press" "";
+                       }
+
+                       program {
+                               name: "pressed_handle";
+                               signal: "mouse,clicked,1";
+                               source: "rect_handle";
+                               source: "handle_img";
+                               action: SIGNAL_EMIT "del" "";
+                       }
+
+                       program {
+                               name: "subtext_show";
+                               signal: "sub_show";
+                               source: "subtitle_text";
+                               action: STATE_SET "sub_show" 0.0;
+                               target: "subtitle_text";
+                               target: "title_text";
+                               target: "content_text";
+                       }
+
+                       program {
+                               name: "subtext_hide";
+                               signal: "sub_hide";
+                               source: "subtitle_text";
+                               action: STATE_SET "sub_hide" 0.0;
+                               target: "subtitle_text";
+                               target: "title_text";
+                               target: "content_text";
+                       }
+
+                       program {
+                               name: "btn_hide";
+                               signal: "btn_hide";
+                               source: "button.space";
+                               action: STATE_SET "btn_hide" 0.0;
+                               target: "button.swallow";
+                       }
+
+                       program {
+                               name: "btn_show";
+                               signal: "btn_show";
+                               source: "button.space";
+                               action: STATE_SET "btn_show" 0.0;
+                               target: "button.swallow";
+                       }
+               }
+       }
+
+
+       group {
+               name: "button_layout";
+
+               parts {
+                       part {
+                               name: "rect.button";
+                               type: RECT;
+                               description {
+                                       state: "default" 0.0;
+                                       color_class: "ATO006P";
+                                       align: 0.0 0.0;
+                                       visible: 0;
+                               }
+                       }
+
+                       part {
+                               name: "button.bg.img";
+                               type:IMAGE;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1 {
+                                               relative: 0.1 0.1;
+                                               to: "rect.button";
+                                       }
+                                       rel2 {
+                                               relative: 0.9 0.9;
+                                               to: "rect.button";
+                                       }
+                                       color_class: "AO001L1";
+                                       image {
+                                               normal: "core_list_button_bg.#.png";
+                                       }
+                                       align: 0.5 0.5;
+                               }
+                               description {
+                                       state: "pressed" 0.0;
+                                       inherit: "default" 0.0;
+                                       color_class: "AO001L1P";
+                               }
+                       }
+
+                       part {
+                               name: "content.button.image";
+                               type: SWALLOW;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.5 0.5;
+                                       rel1 {
+                                               to: "button.bg.img";
+                                       }
+                                       rel2 {
+                                               to: "button.bg.img";
+                                       }
+                               }
+                       }
+
+                       part {
+                               name: "content.button.text";
+                               type: TEXT;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.5 0.5;
+                                       rel1 {
+                                               to: "button.bg.img";
+                                       }
+                                       rel2 {
+                                               to: "button.bg.img";
+                                       }
+                                       text {
+                                               font: "Tizen:style=Regular";
+                                               size: 30;
+                                               text_class: "tizen";
+                                               align: 0.5 0.5;
+                                       }
+                               }
+                       }
+
+                       part {
+                               name: "touch";
+                               mouse_events: 1;
+                               type: RECT;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.0 0.0;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to: "rect.button";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 1.0;
+                                               to: "rect.button";
+                                       }
+                                       color : 0 0 0 0;
+                               }
+                       }
+
+                       programs {
+                               program {
+                                       name: "pressed_button";
+                                       signal: "mouse,clicked,1";
+                                       source: "touch";
+                                       action: SIGNAL_EMIT "button_clicked" "";
+                               }
+
+                       }
+
+               }
+       }
+}
diff --git a/data/quickpanel_animated_icon.edc b/data/quickpanel_animated_icon.edc
new file mode 100755 (executable)
index 0000000..1abefd7
--- /dev/null
@@ -0,0 +1,515 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#define FRAME_TIME 0.3
+
+images {
+       image: "noti_download_01.png" COMP;
+       image: "noti_download_02.png" COMP;
+       image: "noti_download_03.png" COMP;
+       image: "noti_download_04.png" COMP;
+       image: "noti_download_05.png" COMP;
+       image: "noti_download_complete.png" COMP;
+
+       image: "noti_upload_01.png" COMP;
+       image: "noti_upload_02.png" COMP;
+       image: "noti_upload_03.png" COMP;
+       image: "noti_upload_04.png" COMP;
+       image: "noti_upload_05.png" COMP;
+       image: "noti_upload_complete.png" COMP;
+
+       image: "noti_install_01.png" COMP;
+       image: "noti_install_02.png" COMP;
+       image: "noti_install_03.png" COMP;
+       image: "noti_install_04.png" COMP;
+       image: "noti_install_05.png" COMP;
+       image: "noti_install_complete.png" COMP;
+}
+
+group {
+       name: "quickpanel/animated_icon_download";
+       parts {
+               part { name: "background";
+                       type: SPACER;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 47 47;
+                               max: 47 47;
+                       }
+               }
+               part{
+                       name: "obj.image";
+                       type:IMAGE;
+                       scale:1;
+                       description {
+                               state: "default" 0.0;
+                               fixed: 1 1;
+                               state: "default" 0.0;
+                               min: 47 47;
+                               max: 47 47;
+                               rel1 {
+                                       to: "background";
+                               }
+                               rel2 {
+                                       to: "background";
+                               }
+                               image {
+                                       normal:"noti_download_01.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                               color_class: QP_THEME_LIST_ITEM_ICON_COLOR;
+                               visible:1;
+                       }
+                       description {
+                               state: "state.0" 0.0;
+                               inherit: "default" 0.0;
+                               image {
+                                       normal:"noti_download_01.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                       }
+                       description {
+                               state: "state.1" 0.0;
+                               inherit: "default" 0.0;
+                               image {
+                                       normal:"noti_download_02.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                       }
+                       description {
+                               state: "state.2" 0.0;
+                               inherit: "default" 0.0;
+                               image {
+                                       normal:"noti_download_03.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                       }
+                       description {
+                               state: "state.3" 0.0;
+                               inherit: "default" 0.0;
+                               image {
+                                       normal:"noti_download_04.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                       }
+                       description {
+                               state: "state.4" 0.0;
+                               inherit: "default" 0.0;
+                               image {
+                                       normal:"noti_download_05.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                       }
+                       description {
+                               state: "state.5" 0.0;
+                               inherit: "default" 0.0;
+                               image {
+                                       normal:"noti_download_complete.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                       }
+               }
+       }
+
+       programs {
+               program {
+                       name: "init.layout";
+                       signal: "load";
+                       source: "";
+                       in: 0.0 0.0;
+                       action: SIGNAL_EMIT "icon.state.0" "prog";
+               }
+               program{
+                       name: "icon.state.0";
+                       signal: "icon.state.0";
+                       source: "prog";
+                       in: FRAME_TIME 0.0;
+                       action: STATE_SET "state.0" 0.0;
+                       target: "obj.image";
+                       after: "icon.state.1";
+               }
+               program{
+                       name: "icon.state.1";
+                       signal: "icon.state.1";
+                       source: "prog";
+                       in: FRAME_TIME 0.0;
+                       action: STATE_SET "state.1" 0.0;
+                       target: "obj.image";
+                       after: "icon.state.2";
+               }
+               program{
+                       name: "icon.state.2";
+                       signal: "icon.state.2";
+                       source: "prog";
+                       in: FRAME_TIME 0.0;
+                       action: STATE_SET "state.2" 0.0;
+                       target: "obj.image";
+                       after: "icon.state.3";
+               }
+               program{
+                       name: "icon.state.3";
+                       signal: "icon.state.3";
+                       source: "prog";
+                       in: FRAME_TIME 0.0;
+                       action: STATE_SET "state.3" 0.0;
+                       target: "obj.image";
+                       after: "icon.state.4";
+               }
+               program{
+                       name: "icon.state.4";
+                       signal: "icon.state.4";
+                       source: "prog";
+                       in: FRAME_TIME 0.0;
+                       action: STATE_SET "state.4" 0.0;
+                       target: "obj.image";
+                       after: "icon.state.5";
+               }
+               program{
+                       name: "icon.state.5";
+                       signal: "icon.state.5";
+                       source: "prog";
+                       in: FRAME_TIME 0.0;
+                       action: STATE_SET "state.5" 0.0;
+                       target: "obj.image";
+                       after: "icon.state.0";
+               }
+       }
+}
+
+group {
+       name: "quickpanel/animated_icon_upload";
+       parts {
+               part { name: "background";
+                       type: SPACER;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 47 47;
+                               max: 47 47;
+                       }
+               }
+               part{
+                       name: "obj.image";
+                       type:IMAGE;
+                       scale:1;
+                       description {
+                               state: "default" 0.0;
+                               fixed: 1 1;
+                               state: "default" 0.0;
+                               min: 47 47;
+                               max: 47 47;
+                               rel1 {
+                                       to: "background";
+                               }
+                               rel2 {
+                                       to: "background";
+                               }
+                               image {
+                                       normal:"noti_upload_01.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                               color_class: QP_THEME_LIST_ITEM_ICON_COLOR;
+                               visible:1;
+                       }
+                       description {
+                               state: "state.0" 0.0;
+                               inherit: "default" 0.0;
+                               image {
+                                       normal:"noti_upload_01.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                       }
+                       description {
+                               state: "state.1" 0.0;
+                               inherit: "default" 0.0;
+                               image {
+                                       normal:"noti_upload_02.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                       }
+                       description {
+                               state: "state.2" 0.0;
+                               inherit: "default" 0.0;
+                               image {
+                                       normal:"noti_upload_03.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                       }
+                       description {
+                               state: "state.3" 0.0;
+                               inherit: "default" 0.0;
+                               image {
+                                       normal:"noti_upload_04.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                       }
+                       description {
+                               state: "state.4" 0.0;
+                               inherit: "default" 0.0;
+                               image {
+                                       normal:"noti_upload_05.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                       }
+                       description {
+                               state: "state.5" 0.0;
+                               inherit: "default" 0.0;
+                               image {
+                                       normal:"noti_upload_complete.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                       }
+               }
+       }
+
+       programs {
+               program {
+                       name: "init.layout";
+                       signal: "load";
+                       source: "";
+                       in: 0.0 0.0;
+                       action: SIGNAL_EMIT "icon.state.0" "prog";
+               }
+               program{
+                       name: "icon.state.0";
+                       signal: "icon.state.0";
+                       source: "prog";
+                       in: FRAME_TIME 0.0;
+                       action: STATE_SET "state.0" 0.0;
+                       target: "obj.image";
+                       after: "icon.state.1";
+               }
+               program{
+                       name: "icon.state.1";
+                       signal: "icon.state.1";
+                       source: "prog";
+                       in: FRAME_TIME 0.0;
+                       action: STATE_SET "state.1" 0.0;
+                       target: "obj.image";
+                       after: "icon.state.2";
+               }
+               program{
+                       name: "icon.state.2";
+                       signal: "icon.state.2";
+                       source: "prog";
+                       in: FRAME_TIME 0.0;
+                       action: STATE_SET "state.2" 0.0;
+                       target: "obj.image";
+                       after: "icon.state.3";
+               }
+               program{
+                       name: "icon.state.3";
+                       signal: "icon.state.3";
+                       source: "prog";
+                       in: FRAME_TIME 0.0;
+                       action: STATE_SET "state.3" 0.0;
+                       target: "obj.image";
+                       after: "icon.state.4";
+               }
+               program{
+                       name: "icon.state.4";
+                       signal: "icon.state.4";
+                       source: "prog";
+                       in: FRAME_TIME 0.0;
+                       action: STATE_SET "state.4" 0.0;
+                       target: "obj.image";
+                       after: "icon.state.5";
+               }
+               program{
+                       name: "icon.state.5";
+                       signal: "icon.state.5";
+                       source: "prog";
+                       in: FRAME_TIME 0.0;
+                       action: STATE_SET "state.5" 0.0;
+                       target: "obj.image";
+                       after: "icon.state.0";
+               }
+       }
+}
+
+group {
+       name: "quickpanel/animated_icon_install";
+       parts {
+               part { name: "background";
+                       type: SPACER;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 47 47;
+                               max: 47 47;
+                       }
+               }
+               part{
+                       name: "obj.image";
+                       type:IMAGE;
+                       scale:1;
+                       description {
+                               state: "default" 0.0;
+                               fixed: 1 1;
+                               state: "default" 0.0;
+                               min: 47 47;
+                               max: 47 47;
+                               rel1 {
+                                       to: "background";
+                               }
+                               rel2 {
+                                       to: "background";
+                               }
+                               image {
+                                       normal:"noti_install_01.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                               color_class: QP_THEME_LIST_ITEM_ICON_COLOR;
+                               visible:1;
+                       }
+                       description {
+                               state: "state.0" 0.0;
+                               inherit: "default" 0.0;
+                               image {
+                                       normal:"noti_install_01.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                       }
+                       description {
+                               state: "state.1" 0.0;
+                               inherit: "default" 0.0;
+                               image {
+                                       normal:"noti_install_02.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                       }
+                       description {
+                               state: "state.2" 0.0;
+                               inherit: "default" 0.0;
+                               image {
+                                       normal:"noti_install_03.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                       }
+                       description {
+                               state: "state.3" 0.0;
+                               inherit: "default" 0.0;
+                               image {
+                                       normal:"noti_install_04.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                       }
+                       description {
+                               state: "state.4" 0.0;
+                               inherit: "default" 0.0;
+                               image {
+                                       normal:"noti_install_05.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                       }
+                       description {
+                               state: "state.5" 0.0;
+                               inherit: "default" 0.0;
+                               image {
+                                       normal:"noti_install_complete.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                       }
+               }
+       }
+
+       programs {
+               program {
+                       name: "init.layout";
+                       signal: "load";
+                       source: "";
+                       in: 0.0 0.0;
+                       action: SIGNAL_EMIT "icon.state.0" "prog";
+               }
+               program{
+                       name: "icon.state.0";
+                       signal: "icon.state.0";
+                       source: "prog";
+                       in: FRAME_TIME 0.0;
+                       action: STATE_SET "state.0" 0.0;
+                       target: "obj.image";
+                       after: "icon.state.1";
+               }
+               program{
+                       name: "icon.state.1";
+                       signal: "icon.state.1";
+                       source: "prog";
+                       in: FRAME_TIME 0.0;
+                       action: STATE_SET "state.1" 0.0;
+                       target: "obj.image";
+                       after: "icon.state.2";
+               }
+               program{
+                       name: "icon.state.2";
+                       signal: "icon.state.2";
+                       source: "prog";
+                       in: FRAME_TIME 0.0;
+                       action: STATE_SET "state.2" 0.0;
+                       target: "obj.image";
+                       after: "icon.state.3";
+               }
+               program{
+                       name: "icon.state.3";
+                       signal: "icon.state.3";
+                       source: "prog";
+                       in: FRAME_TIME 0.0;
+                       action: STATE_SET "state.3" 0.0;
+                       target: "obj.image";
+                       after: "icon.state.4";
+               }
+               program{
+                       name: "icon.state.4";
+                       signal: "icon.state.4";
+                       source: "prog";
+                       in: FRAME_TIME 0.0;
+                       action: STATE_SET "state.4" 0.0;
+                       target: "obj.image";
+                       after: "icon.state.5";
+               }
+               program{
+                       name: "icon.state.5";
+                       signal: "icon.state.5";
+                       source: "prog";
+                       in: FRAME_TIME 0.0;
+                       action: STATE_SET "state.5" 0.0;
+                       target: "obj.image";
+                       after: "icon.state.0";
+               }
+       }
+}
\ No newline at end of file
diff --git a/data/quickpanel_brightness.edc b/data/quickpanel_brightness.edc
new file mode 100755 (executable)
index 0000000..f65b58b
--- /dev/null
@@ -0,0 +1,684 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+
+//#define DEBUG
+//#define DEBUG_TEXT
+
+#define BRIGHTNESS_ICON_COLOR "AO004"
+#define BRIGHTNESS_TEXT_COLOR "AO014"
+
+       styles {
+               style {
+                       name: "checkbox_text";
+                       base: "font=Tizen:style=Regular text_class=tizen font_size=24 color=#FFFFFF color_class="BRIGHTNESS_TEXT_COLOR" ellipsis=0.0 wrap=mixed";
+               }
+       }
+
+       group {
+               name: "quickpanel/brightness_controller/wrapper";
+               parts {
+                       part { name: "base";
+                               type: SPACER;
+                               repeat_events: 1;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 QP_THEME_LIST_ITEM_BRIGHTNESS_HEIGHT;
+                                       max: 9999 QP_THEME_LIST_ITEM_BRIGHTNESS_HEIGHT;
+                                       fixed: 1 1;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                       }
+                                       rel2 {
+                                               relative: 1.0 0.0;
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part { name: "elm.swallow.controller";
+                               type: SWALLOW;
+                               mouse_events: 1;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 1 1;
+                                       rel1 {
+                                               to: "base";
+                                       }
+                                       rel2 {
+                                               to: "base";
+                                       }
+                               }
+                       }
+               }
+       }
+
+       group {
+               name: "quickpanel/brightness_controller/default";
+
+               images {
+                       image: "quick_icon_brightness.png" COMP;
+                       image: "quick_icon_brightness_00.png" COMP;
+                       image: "quick_icon_brightness_01.png" COMP;
+                       image: "quick_icon_brightness_02.png" COMP;
+                       image: "quick_icon_brightness_03.png" COMP;
+                       image: "quick_icon_brightness_04.png" COMP;
+                       image: "quick_icon_brightness_05.png" COMP;
+                       image: "quick_icon_brightness_06.png" COMP;
+                       image: "quick_icon_brightness_07.png" COMP;
+                       image: "quick_icon_brightness_08.png" COMP;
+                       image: "quick_icon_brightness_09.png" COMP;
+                       image: "quick_icon_brightness_10.png" COMP;
+                       image: "quick_icon_brightness_11.png" COMP;
+                       image: "core_theme_bg_01.png" COMP;
+               }
+
+               script {
+                       public ctnt_shown;
+                       public time_shown;
+               }
+
+               parts {
+                       part { name: "base";
+                               type: RECT;
+                               repeat_events: 1;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 QP_THEME_LIST_ITEM_BRIGHTNESS_HEIGHT;
+                                       max: 9999 QP_THEME_LIST_ITEM_BRIGHTNESS_HEIGHT;
+                                       fixed: 1 1;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                       }
+                                       rel2 {
+                                               relative: 1.0 0.0;
+                                       }
+                                       align: 0.0 0.0;
+                                       color_class: QP_BACKGROUND_COLOR;
+                                       visible: QP_THEME_BG_VISIBILITY;
+                               }
+                       }
+
+                       part {
+                               name: "background";
+                               type: IMAGE;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 1 1;
+                                       align: 0.5 0.5;
+                                       rel1 {
+                                               to: "base";
+                                       }
+                                       rel2 {
+                                               to: "base";
+                                       }
+                                       image {
+                                               normal: "core_theme_bg_01.png";
+                                       }
+                                       visible: 0;
+                               }
+                               description {
+                                       state: "show.bg" 0.0;
+                                       inherit: "default" 0.0;
+                                       visible: 1;
+                               }
+                               description {
+                                       state: "hide.bg" 0.0;
+                                       inherit: "default" 0.0;
+                                       visible: 0;
+                               }
+                       }
+
+                       part { name: "disabler";
+                               type: RECT;
+                               mouse_events: 0;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1 {
+                                               to: "base";
+                                       }
+                                       rel2 {
+                                               to: "base";
+                                       }
+                                       color_class: AO004;
+                               }
+                               description {
+                                       state: "disabled" 0.0;
+                                       inherit: "default" 0.0;
+                                       color_class: AO004D;
+                               }
+                       }
+                       part { name: "bg_image";
+                               type: RECT;
+                               mouse_events: 0;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       color_class: QP_THEME_BRIGHTNESS_BG_COLOR;
+                                       visible: QP_THEME_BG_VISIBILITY;
+                               }
+                               description {
+                                       state: "selected" 0.0;
+                                       inherit: "default" 0.0;
+                                       color_class: QP_THEME_BRIGHTNESS_BG_COLOR;
+                               }
+                       }
+                       part { name: "elm.content.bg";
+                               type: RECT;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 9 0;
+                                       fixed: 1 0;
+                                       rel1 {
+                                               to_x:"base";
+                                               to_y:"base";
+                                               relative: 1.0 0.0;
+                                       }
+                                       rel2 {
+                                               to_x:"base";
+                                               to_y:"base";
+                                               relative: 0.0 1.0;
+                                       }
+                                       align: 0.0 0.0;
+                                       visible: 0;
+                                       //color_class: QP_BACKGROUND_COLOR;
+                               }
+                       }
+                       QUICKPANEL_FOCUS_OBJECT("focus", "elm.content.bg", "elm.content.bg")
+                       part { name: "elm.padding.left";
+                               type: RECT;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 15 0;
+                                       max: 15 0;
+                                       fixed: 1 0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel2.relative: 0.0 0.0;
+                                       rel2.relative: 0.0 1.0;
+                                       align: 0.0 0.0;
+                                       visible: 0;
+                               }
+                       }
+                       part { name: "elm.rect.thumbnail";
+                               type: RECT;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 42 42;
+                                       max: 42 42;
+                                       fixed: 1 1;
+                                       rel1 {
+                                               to_x:"elm.padding.left";
+                                               to_y:"base";
+                                               relative: 1.0 0.0;
+                                       }
+                                       rel2 {
+                                               to_x:"elm.padding.left";
+                                               to_y:"base";
+                                               relative: 1.0 1.0;
+                                       }
+                                       align: 0.0 0.5;
+                                       visible:0;
+                               }
+                       }
+                       part { name: "elm.image.thumbnail";
+                               type:IMAGE;
+                               clip_to: "disabler";
+                               scale:1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 0 0;
+                                       rel1 {
+                                               to: "elm.rect.thumbnail";
+                                       }
+                                       rel2 {
+                                               to: "elm.rect.thumbnail";
+                                       }
+                                       image {
+                                               normal:"quick_icon_brightness_00.png";
+                                       }
+                               }
+                               description {
+                                       state: "state.0" 0.0;
+                                       inherit: "default" 0.0;
+                                       image {
+                                               normal:"quick_icon_brightness_00.png";
+                                       }
+                               }
+                               description {
+                                       state: "state.1" 0.0;
+                                       inherit: "default" 0.0;
+                                       image {
+                                               normal:"quick_icon_brightness_01.png";
+                                       }
+                               }
+                               description {
+                                       state: "state.2" 0.0;
+                                       inherit: "default" 0.0;
+                                       image {
+                                               normal:"quick_icon_brightness_02.png";
+                                       }
+                               }
+                               description {
+                                       state: "state.3" 0.0;
+                                       inherit: "default" 0.0;
+                                       image {
+                                               normal:"quick_icon_brightness_03.png";
+                                       }
+                               }
+                               description {
+                                       state: "state.4" 0.0;
+                                       inherit: "default" 0.0;
+                                       image {
+                                               normal:"quick_icon_brightness_04.png";
+                                       }
+                               }
+                               description {
+                                       state: "state.5" 0.0;
+                                       inherit: "default" 0.0;
+                                       image {
+                                               normal:"quick_icon_brightness_05.png";
+                                       }
+                               }
+                               description {
+                                       state: "state.6" 0.0;
+                                       inherit: "default" 0.0;
+                                       image {
+                                               normal:"quick_icon_brightness_06.png";
+                                       }
+                               }
+                               description {
+                                       state: "state.7" 0.0;
+                                       inherit: "default" 0.0;
+                                       image {
+                                               normal:"quick_icon_brightness_07.png";
+                                       }
+                               }
+                               description {
+                                       state: "state.8" 0.0;
+                                       inherit: "default" 0.0;
+                                       image {
+                                               normal:"quick_icon_brightness_08.png";
+                                       }
+                               }
+                               description {
+                                       state: "state.9" 0.0;
+                                       inherit: "default" 0.0;
+                                       image {
+                                               normal:"quick_icon_brightness_09.png";
+                                       }
+                               }
+                               description {
+                                       state: "state.10" 0.0;
+                                       inherit: "default" 0.0;
+                                       image {
+                                               normal:"quick_icon_brightness_10.png";
+                                       }
+                               }
+                               description {
+                                       state: "state.11" 0.0;
+                                       inherit: "default" 0.0;
+                                       image {
+                                               normal:"quick_icon_brightness_11.png";
+                                       }
+                               }
+                               description {
+                                       state: "state.auto" 0.0;
+                                       inherit: "default" 0.0;
+                                       image {
+                                               normal:"quick_icon_brightness.png";
+                                       }
+                               }
+                       }
+                       part { name: "elm.padding.thumbnail.x";
+                               type: RECT;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 0;
+                                       fixed: 1 0;
+                                       rel1 {
+                                               to:"elm.rect.thumbnail";
+                                               relative: 1.0 0.0;
+                                       }
+                                       rel2 {
+                                               to:"elm.rect.thumbnail";
+                                               relative: 1.0 1.0;
+                                       }
+                                       align: 0.0 0.0;
+                                       visible: 0;
+                               }
+                       }
+                       part { name: "elm.swallow.slider";
+                               type: SWALLOW;
+                               //clip_to: "disabler";
+                               mouse_events: 1;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 1 1;
+                                       rel1 {
+                                               relative: 1.0 0.0;
+                                               to: "elm.padding.thumbnail.x";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to: "elm.padding.bf.check";
+                                       }
+                               }
+                       }
+                       part { name: "elm.rect.slider";
+                               type: RECT;
+                               mouse_events: 1;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 48;
+                                       fixed: 0 1;
+                                       rel1 {
+                                               relative: 1.0 0.0;
+                                               to_x: "elm.padding.thumbnail.x";
+                                               to_y: "base";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.padding.bf.check";
+                                               to_y: "base";
+                                       }
+                                       align: 0.0 0.5;
+                                       color: 0 0 0 0;
+                                       visible: 0;
+                               }
+                               description {
+                                       state: "disabled" 0.0;
+                                       inherit: "default" 0.0;
+                                       visible: 1;
+                               }
+                       }
+                       part { name: "elm.padding.bf.check";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to: "elm.check.swallow";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to: "elm.check.swallow";
+                                       }
+                                       align: 1.0 0.5;
+                               }
+                       }
+
+                       part { name: "elm.check.swallow";
+                               type: SWALLOW;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to: "elm.padding.bf.auto";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to: "elm.padding.bf.auto";
+                                       }
+                                       align: 1.0 0.5;
+                                       min: 0 40;
+                                       fixed: 1 1;
+                               }
+                       }
+
+                       part { name: "elm.padding.bf.auto";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to: "elm.rect.auto";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to: "elm.rect.auto";
+                                       }
+                                       align: 1.0 0.5;
+                                       min: 0 0;
+                                       fixed: 1 0;
+                               }
+                       }
+                       part { name: "elm.rect.auto";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1 {
+                                               relative : 0.0 0.0;
+                                               to : "elm.check.text";
+                                       }
+                                       rel2 {
+                                               relative : 1.0 1.0;
+                                               to : "elm.check.text";
+                                       }
+                               }
+                       }
+                       part { name: "elm.check.text";
+                               type: TEXT;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align : 1.0 0.5;
+                                       fixed : 1 1;
+                                       rel1 {
+                                               relative : 0.0 0.5;
+                                               to : "elm.padding.right";
+                                       }
+                                       rel2 {
+                                               relative : 0.0 0.5;
+                                               to : "elm.padding.right";
+                                       }
+                                       text {
+                                               font : "Tizen:style=Regular";
+                                               size : 22;
+                                               text_class : "Tizen";
+                                               align : 1.0 0.5;
+                                               min : 1 1;
+                                       }
+                                       color_class: ATO019;
+                               }
+                       }
+                       
+                       part { name: "elm.padding.right";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1 {
+                                               relative: 1.0 0.0;
+                                               to: "base";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 1.0;
+                                               to: "base";
+                                       }
+                                       align: 1.0 0.5;
+                                       min: 15 0;
+                                       fixed: 1 0;
+                               }
+                       }
+               }
+
+               programs {
+                       program { name: "show_content";
+                               signal: "elm,state,elm.swallow.slider,active";
+                               source: "elm";
+                               script {
+                                       set_state(PART:"elm.swallow.slider", "show", 0.0);
+                                       set_int(ctnt_shown, 1);
+                               }
+                       }
+                       program { name: "go_active";
+                               signal: "elm,state,selected";
+                               source: "elm";
+                               script {
+                                       set_state(PART:"bg_image", "selected", 0.0);
+                                       if (get_int(ctnt_shown) == 1)
+                                       set_state(PART:"elm.swallow.slider", "selected", 0.0);
+                               }
+                       }
+                       program { name: "go_passive";
+                               signal: "elm,state,unselected";
+                               source: "elm";
+                               script {
+                                       set_state(PART:"bg_image", "default", 0.0);
+                                       if (get_int(ctnt_shown) == 1)
+                                       set_state(PART:"elm.swallow.slider", "show", 0.0);
+                               }
+                       }
+                       program{
+                               name: "show.bg";
+                               signal: "show.bg";
+                               source: "prog.bg";
+                               action: STATE_SET "show.bg" 0.0;
+                               target: "background";
+                       }
+                       program{
+                               name: "hide.bg";
+                               signal: "hide.bg";
+                               source: "prog.bg";
+                               action: STATE_SET "hide.bg" 0.0;
+                               target: "background";
+                       }
+                       program{
+                               name: "icon.state.0";
+                               signal: "icon.state.0";
+                               source: "prog";
+                               action: STATE_SET "state.0" 0.0;
+                               target: "elm.image.thumbnail";
+                       }
+                       program{
+                               name: "icon.state.1";
+                               signal: "icon.state.1";
+                               source: "prog";
+                               action: STATE_SET "state.1" 0.0;
+                               target: "elm.image.thumbnail";
+                       }
+                       program{
+                               name: "icon.state.2";
+                               signal: "icon.state.2";
+                               source: "prog";
+                               action: STATE_SET "state.2" 0.0;
+                               target: "elm.image.thumbnail";
+                       }
+                       program{
+                               name: "icon.state.3";
+                               signal: "icon.state.3";
+                               source: "prog";
+                               action: STATE_SET "state.3" 0.0;
+                               target: "elm.image.thumbnail";
+                       }
+                       program{
+                               name: "icon.state.4";
+                               signal: "icon.state.4";
+                               source: "prog";
+                               action: STATE_SET "state.4" 0.0;
+                               target: "elm.image.thumbnail";
+                       }
+                       program{
+                               name: "icon.state.5";
+                               signal: "icon.state.5";
+                               source: "prog";
+                               action: STATE_SET "state.5" 0.0;
+                               target: "elm.image.thumbnail";
+                       }
+                       program{
+                               name: "icon.state.6";
+                               signal: "icon.state.6";
+                               source: "prog";
+                               action: STATE_SET "state.6" 0.0;
+                               target: "elm.image.thumbnail";
+                       }
+                       program{
+                               name: "icon.state.7";
+                               signal: "icon.state.7";
+                               source: "prog";
+                               action: STATE_SET "state.7" 0.0;
+                               target: "elm.image.thumbnail";
+                       }
+                       program{
+                               name: "icon.state.8";
+                               signal: "icon.state.8";
+                               source: "prog";
+                               action: STATE_SET "state.8" 0.0;
+                               target: "elm.image.thumbnail";
+                       }
+                       program{
+                               name: "icon.state.9";
+                               signal: "icon.state.9";
+                               source: "prog";
+                               action: STATE_SET "state.9" 0.0;
+                               target: "elm.image.thumbnail";
+                       }
+                       program{
+                               name: "icon.state.10";
+                               signal: "icon.state.10";
+                               source: "prog";
+                               action: STATE_SET "state.10" 0.0;
+                               target: "elm.image.thumbnail";
+                       }
+                       program{
+                               name: "icon.state.11";
+                               signal: "icon.state.11";
+                               source: "prog";
+                               action: STATE_SET "state.11" 0.0;
+                               target: "elm.image.thumbnail";
+                       }
+                       program{
+                               name: "icon.state.auto";
+                               signal: "icon.state.auto";
+                               source: "prog";
+                               action: STATE_SET "state.auto" 0.0;
+                               target: "elm.image.thumbnail";
+                       }
+                       program{
+                               signal: "disable";
+                               source: "disabler";
+                               action: STATE_SET "default" 0.0;
+                               target: "disabler";
+                               target: "elm.rect.slider";
+                       }
+                       program{
+                               signal: "enable";
+                               source: "disabler";
+                               action: STATE_SET "disabled" 0.0;
+                               target: "disabler";
+                               target: "elm.rect.slider";
+                       }
+               }
+       }
diff --git a/data/quickpanel_datetime.edc b/data/quickpanel_datetime.edc
new file mode 100755 (executable)
index 0000000..2c15eaf
--- /dev/null
@@ -0,0 +1,411 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+
+images {
+       image: "icon_indicator_setting.png" COMP;
+       image: "line_indicator_divider.png" COMP;
+       image: "bg_press.#.png" COMP;
+}
+
+styles {
+       style {
+               name: "font_time_am_pm_style";
+               base: "font=Tizen:style=Regular  font_size=22 valign=middle  ellipsis=1.0 wrap=none";
+               tag: "time" "+ color=#FFFFFF ";
+               tag: "ampm" "+ color=#FFFFFF ";
+       }
+
+       style {
+               name: "font_date_style";
+               base: "font=Tizen:style=Regular  font_size=22 color=#FFFFFF valign=middle color_class=tizen  ellipsis=1.0 wrap=none";
+       }
+}
+
+group {
+       name: "quickpanel/datetime";
+
+       script {
+               public g_is_timedate_clickable;
+       }
+
+       parts {
+               part { name: "base";
+                       type: RECT;
+                       repeat_events: 1;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               color_class: QP_BACKGROUND_COLOR;
+                               visible: 0;
+                       }
+               }
+               QUICKPANEL_FOCUS_OBJECT("focus", "base", "base")
+
+               part { name: "space.button.setting";
+                       type: SPACER;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 60 0;
+                               fixed: 1 0;
+                               align: 1.0 0.5;
+                               rel1 {
+                                       relative : 1.0 0.0;
+                                       to: "base";
+                               }
+                               rel2 {
+                                       relative : 1.0 1.0;
+                                       to: "base";
+                               }
+                       }
+               }
+               QUICKPANEL_FOCUS_OBJECT("focus.setting", "space.button.setting", "space.button.setting")
+
+               part { name: "space.divider";
+                       type: SPACER;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 1 0;
+                               fixed: 1 0;
+                               align: 1.0 0.5;
+                               rel1 {
+                                       relative : 0.0 0.0;
+                                       to: "space.button.setting";
+                               }
+                               rel2 {
+                                       relative : 0.0 1.0;
+                                       to: "space.button.setting";
+                               }
+                       }
+               }
+
+               part {
+                       name: "space.datetime";
+                       type: SPACER;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               rel1 {
+                                       relative : 0.0 0.0;
+                                       to: "base";
+                               }
+                               rel2 {
+                                       relative : 0.0 1.0;
+                                       to: "space.divider";
+                               }
+                       }
+               }
+               QUICKPANEL_FOCUS_OBJECT("focus.datetime", "space.datetime", "space.datetime")
+
+               part { name: "image.button.setting.bg";
+                       type: IMAGE;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 0 36;
+                               fixed: 0 1;
+                               align: 0.0 0.5;
+                               rel1 {
+                                       relative: 0.0 0.5;
+                                       to: "space.button.setting";
+                               }
+                               rel2 {
+                                       relative: 1.0 0.5;
+                                       to: "space.button.setting";
+                               }
+                               image {
+                                       normal: "bg_press.#.png";
+                               }
+                               color_class: "F043P";
+                               visible: 0;
+                       }
+                       description {
+                               state: "pressed" 0.0;
+                               inherit: "default";
+                               visible: 1;
+                       }
+               }
+
+               part { name: "image.datetime.bg";
+                       type: IMAGE;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 0 36;
+                               fixed: 0 1;
+                               align: 0.0 0.5;
+                               rel1 {
+                                       relative : 0.0 0.5;
+                                       to: "space.datetime";
+                               }
+                               rel2 {
+                                       relative : 1.0 0.5;
+                                       to: "space.datetime";
+                               }
+                               image {
+                                       normal: "bg_press.#.png";
+                               }
+                               color_class: "F043P";
+                               visible: 0;
+                       }
+                       description {
+                               state: "pressed" 0.0;
+                               inherit: "default";
+                               visible: 1;
+                       }
+               }
+
+               part { name: "image.button.setting";
+                       type: IMAGE;
+                       mouse_events: 0;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 42 42;
+                               fixed: 1 1;
+                               align: 0.5 0.5;
+                               rel1 {
+                                       relative: 0.5 0.5;
+                                       to: "space.button.setting";
+                               }
+                               rel2 {
+                                       relative: 0.5 0.5;
+                                       to: "space.button.setting";
+                               }
+                               image {
+                                       normal:"icon_indicator_setting.png";
+                               }
+                               color_class: "AO025";
+                       }
+               }
+
+               part { name: "image.divider";
+                       type: IMAGE;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 1 24;
+                               fixed: 1 1;
+                               align: 0.5 0.5;
+                               rel1 {
+                                       relative: 0.5 0.5;
+                                       to: "space.divider";
+                               }
+                               rel2 {
+                                       relative: 1.0 0.5;
+                                       to: "space.divider";
+                               }
+                               image {
+                                       normal: "line_indicator_divider.png";
+                               }
+                               color_class: "AO003E1";
+                       }
+               }
+
+               part { name: "divider.padding.left";
+                       type: SPACER;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 15 0;
+                               fixed: 1 0;
+                               align: 1.0 0.5;
+                               rel1 {
+                                       relative: 0.0 0.0;
+                                       to: "space.divider";
+                               }
+                               rel2 {
+                                       relative: 0.0 1.0;
+                                       to: "space.divider";
+                               }
+                       }
+               }
+
+               part { name: "text.time";
+                       type: TEXTBLOCK;
+                       mouse_events: 0;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 0 (3 + 30 + 3);
+                               fixed: 0 1;
+                               align: 1.0 0.5;
+                               rel1 {
+                                       relative : 0.0 0.5;
+                                       to: "divider.padding.left";
+                               }
+                               rel2 {
+                                       relative : 0.0 0.5;
+                                       to: "divider.padding.left";
+                               }
+                               text {
+                                       style: "font_time_am_pm_style";
+                                       min: 1 0;
+                                       max: 1 0;
+                                       align: 1.0 0.5;
+                               }
+                       }
+               }
+
+               part { name: "date.left.padding";
+                       type: SPACER;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 15 0;
+                               fixed: 1 0;
+                               align: 0.0 0.0;
+                               rel1 {
+                                       relative : 0.0 0.0;
+                                       to: "space.datetime";
+                               }
+                               rel2 {
+                                       relative : 0.0 1.0;
+                                       to: "space.datetime";
+                               }
+                       }
+               }
+
+               part {
+                       name: "date.top.padding";
+                       type: SPACER;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 0 0;
+                               fixed: 0 1;
+                               align: 0.0 0.0;
+                               rel1 {
+                                       relative: 0.0 0.0;
+                                       to: "space.datetime";
+                               }
+                               rel2 {
+                                       relative: 1.0 0.0;
+                                       to: "space.datetime";
+                               }
+                       }
+               }
+
+               part { name: "text.time.left.padding";
+                       type: SPACER;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 15 0;
+                               fixed: 1 0;
+                               align: 1.0 0.0;
+                               rel1 {
+                                       //relative : 0.0 0.0;
+                                       to: "text.time";
+                               }
+                               rel2 {
+                                       relative : 0.0 1.0;
+                                       to: "text.time";
+                               }
+                       }
+               }
+
+               part { name: "text.date";
+                       type: TEXTBLOCK;
+                       mouse_events: 0;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 0 (8 + 20 + 8);
+                               fixed: 0 1;
+                               align: 0.0 0.5;
+                               rel1 {
+                                       relative : 1.0 1.0;
+                                       to_x: "date.left.padding";
+                                       to_y: "date.top.padding";
+                               }
+                               rel2 {
+                                       relative : 0.0 1.0;
+                                       to_x : "text.time.left.padding";
+                                       to_y: "space.datetime";
+                               }
+                               text {
+                                       style: "font_date_style";
+                                       min: 0 0;
+                                       max: 1 0;
+                                       align: 0.0 0.5;
+                               }
+                       }
+               }
+       }
+
+       programs {
+               program {
+                       name: "timedate.init";
+                       signal: "load";
+                       script{
+                               set_int(g_is_timedate_clickable, 1);
+                       }
+               }
+               program{
+                       name: "button.setting.down";
+                       signal: "mouse,down,*";
+                       source: "focus.setting";
+                       action: STATE_SET "pressed" 0.0;
+                       target: "image.button.setting.bg";
+               }
+               program{
+                       name: "button.setting.up";
+                       signal: "mouse,up,*";
+                       source: "focus.setting";
+                       action: STATE_SET "default" 0.0;
+                       target: "image.button.setting.bg";
+               }
+               program {
+                       name: "timendate.click.enable";
+                       signal: "timendate.click.enable";
+                       source: "prog";
+                       script {
+                               set_int(g_is_timedate_clickable, 1);
+                       }
+               }
+               program {
+                       name: "timendate.click.disable";
+                       signal: "timendate.click.disable";
+                       source: "prog";
+                       script {
+                               set_int(g_is_timedate_clickable, 0);
+                       }
+               }
+               program{
+                       name: "date_time.down";
+                       signal: "mouse,down,*";
+                       source: "focus.datetime";
+                       script {
+                               if (get_int(g_is_timedate_clickable) == 1) {
+                                       set_state(PART:"image.datetime.bg", "pressed", 0.0);
+                               }
+                       }
+               }
+               program{
+                       name: "date_time.up";
+                       signal: "mouse,up,*";
+                       source: "focus.datetime";
+                       action: STATE_SET "default" 0.0;
+                       target: "image.datetime.bg";
+               }
+       }
+}
+
diff --git a/data/quickpanel_def.h b/data/quickpanel_def.h
new file mode 100755 (executable)
index 0000000..958df82
--- /dev/null
@@ -0,0 +1,126 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __QUICKPANEL_EDC_DEF_H__
+#define __QUICKPANEL_EDC_DEF_H__
+
+#define QP_BACKGROUND_COLOR "B011"
+
+#define QP_WIN_W 480
+#define QP_WIN_H 800
+
+#define QP_BG_VISIBILITY       1
+#define QP_BG_COLOR    "AO001"
+
+#define QP_INDICATOR_H 0
+#define QP_HANDLE_H    50
+
+#define QP_SPN_H 41 //66
+#define QP_SPN_TEXT_W 343 //520
+
+#define QP_DATE_H      50
+
+#define QP_COLOR_BLACK 0 0 0 255
+
+#define QP_SETTING_NUM_PORTRAIT_ICONS 5
+#define QP_SETTING_NUM_MINIMUM_ICON 8
+#define QP_SETTING_NUM_TOTAL_ICON 8
+
+#define QP_SETTING_MARGIN_L_W_P 0
+#define QP_SETTING_MARGIN_L_W_L 0
+#define QP_SETTING_MARGIN_R_W_P 0
+#define QP_SETTING_MARGIN_R_W_L 0
+
+#define QP_SETTING_DIVIDER_W_P 0
+#define QP_SETTING_DIVIDER_W_L 0
+#define QP_SETTING_ICON_MIN_H 66//154
+
+#define QP_SETTING_BG_H        151
+#define QP_SETTING_ICON_DRAGGING_BG_CORRECTION_W_P 0
+#define QP_SETTING_ICON_DRAGGING_BG_CORRECTION_W_L 0
+#define QP_SETTING_ICON_DRAGGING_BG_MIN_H 72
+#define QP_SETTING_ICON_DRAGGING_MARGIN 0
+
+// WVGA
+#define QP_SETTING_ICON_MIN_WH_WVGA 66
+#define QP_SETTING_ICON_BG_MIN_W_P_WVGA 96
+#define QP_SETTING_ICON_BG_MIN_W_P_TEXT_OFFSET_WVGA 7
+#define QP_SETTING_ICON_BG_MIN_W_L_WVGA 100
+#define QP_SETTING_ICON_BG_MIN_W_L_TEXT_OFFSET_WVGA 4
+#define QP_SETTING_ICON_DRAGGING_BG_MIN_W_WVGA 66
+
+// HD
+#define QP_SETTING_ICON_MIN_WH_HD 72
+#define QP_SETTING_ICON_BG_MIN_W_P_HD 109
+#define QP_SETTING_ICON_BG_MIN_W_P_TEXT_OFFSET_HD 0
+#define QP_SETTING_ICON_BG_MIN_W_L_HD 107
+#define QP_SETTING_ICON_BG_MIN_W_L_TEXT_OFFSET_HD 0
+#define QP_SETTING_ICON_DRAGGING_BG_MIN_W_HD 72
+
+#define QP_THEME_BRIGHTNESS_BG_COLOR "B011"
+
+#define QP_THEME_BG_VISIBILITY                         0
+#define QP_THEME_BG_COLOR                              "B011"
+#define QP_THEME_BANDED_COLOR  "B0211"
+#define QP_THEME_ITEM_BG_COLOR "B041"
+#define QP_THEME_ITEM_BG_PRESS_COLOR "B041P"
+#define QP_THEME_ITEM_BG_PRESS_DIM_COLOR "AO013DP"
+#define QP_THEME_SECTION_ICON_DIVIDER_COLOR "AO003"
+
+#define QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT 0
+#define QP_THEME_LIST_ITEM_BRIGHTNESS_HEIGHT   76
+#define QP_THEME_LIST_ITEM_MULTIWINDOW_HEIGHT 96 //135
+#define QP_THEME_LIST_ITEM_SHORCUT_SOUND_HEIGHT 96 //135
+#define QP_THEME_LIST_ITEM_SHORCUT_FEATURED_HEIGHT 96 //84
+#define QP_THEME_LIST_ITEM_MINICONTRL_HEIGHT 140 //180
+#define QP_THEME_LIST_ITEM_ONGOING_PROGRESS_HEIGHT 96//135
+#define QP_THEME_LIST_ITEM_ONGOING_EVENT_HEIGHT 96 //135
+#define QP_THEME_LIST_ITEM_ONGOING_EVENT_LINE3_HEIGHT 96
+#define QP_THEME_LIST_ITEM_NOTI_SECTION_HEIGHT 51 //80
+#define QP_THEME_LIST_ITEM_NOTIFICATION_LISTTYPE_HEIGHT 96
+#define QP_THEME_LIST_ITEM_NOTIFICATION_LEGACY_SINGLE_MULTI_HEIGHT 96 //246
+
+#define QP_THEME_LIST_ITEM_ICON_COLOR  "W0661"
+
+#define BOX_PART_ICON "object.icon"
+#define BOX_PART_ICON_SUB "object.icon.sub"
+#define BOX_ICON_BG_SIZE_W 96
+#define BOX_ICON_BG_SIZE_H 96
+#define BOX_ICON_SIZE_W 96
+#define BOX_ICON_SIZE_H 96
+#define BOX_ICON_SUB_SIZE_W 29 //44
+#define BOX_ICON_SUB_SIZE_H 29 //44
+#define BOX_TEXT_TOP_PADDING 15
+#define BOX_ICON_TOP_PADDING 20
+
+
+#define BOX_COLOR_BG QP_THEME_ITEM_BG_COLOR
+#define BOX_COLOR_BG_HIGHLIGHT QP_THEME_ITEM_BG_PRESS_COLOR
+#define BOX_COLOR_BG_HIGHLIGHT_DIM QP_THEME_ITEM_BG_PRESS_DIM_COLOR
+#define BOX_WIDTH_P 224 //340
+#define BOX_HEIGHT_P 183 //278
+#define BOX_WIDTH_L 269 //408
+#define BOX_HEIGHT_L 183 //278
+
+#define BOX_MARGIN_L_TEXT_H 10 //16
+#define BOX_MARGIN_R_TEXT_H 6 //10
+#define BOX_TEXT_CONTENTS_HEIGHT 25 //38
+#define BOX_TEXT_INFO_HEIGHT 25 //38
+#define BOX_TEXT_SUB_PADDING_WIDTH -2 //-3
+
+#endif /*__QUICKPANEL_EDC_DEF_H__*/
diff --git a/data/quickpanel_images.edc b/data/quickpanel_images.edc
new file mode 100755 (executable)
index 0000000..8fcd36d
--- /dev/null
@@ -0,0 +1,77 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#define RESOURCE_IMAGE( FILE_NAME ) \
+   group { \
+      name: FILE_NAME; \
+      images.image: FILE_NAME COMP; \
+      parts { \
+         part { name: "image"; \
+            description { \
+               state: "default" 0.0; \
+               image.normal: FILE_NAME; \
+               aspect: 1 1; \
+               aspect_preference: BOTH; \
+            } \
+         } \
+      } \
+   }
+
+#define RESOURCE_IMAGE_LOSSY( FILE_NAME ) \
+   group { \
+      name: FILE_NAME; \
+      images.image: FILE_NAME LOSSY 85; \
+      parts { \
+         part { name: "image"; \
+            description { \
+               state: "default" 0.0; \
+               image.normal: FILE_NAME; \
+               aspect: 1 1; \
+               aspect_preference: BOTH; \
+            } \
+         } \
+      } \
+   }
+
+       RESOURCE_IMAGE("Q02_Notification_update.png");
+       RESOURCE_IMAGE("quick_icon_torch.png");
+       RESOURCE_IMAGE("quick_icon_allshare.png");
+       RESOURCE_IMAGE("quick_icon_blocking_mode.png");
+       RESOURCE_IMAGE("quick_icon_bluetooth.png");
+       RESOURCE_IMAGE("quick_icon_command.png");
+       RESOURCE_IMAGE("quick_icon_driving.png");
+       RESOURCE_IMAGE("quick_icon_flightmode.png");
+       RESOURCE_IMAGE("quick_icon_location.png");
+       RESOURCE_IMAGE("quick_icon_mirroring.png");
+       RESOURCE_IMAGE("quick_icon_multi_window.png");
+       RESOURCE_IMAGE("quick_icon_nfc.png");
+       RESOURCE_IMAGE("quick_icon_private_mode.png");
+       RESOURCE_IMAGE("quick_icon_power_saving.png");
+       RESOURCE_IMAGE("quick_icon_ultra_power_saving.png");
+       RESOURCE_IMAGE("quick_icon_ready_to_share.png");
+       RESOURCE_IMAGE("quick_icon_auto_rotate.png");
+       RESOURCE_IMAGE("quick_icon_sbeam.png");
+       RESOURCE_IMAGE("quick_icon_sf_vf.png");
+       RESOURCE_IMAGE("quick_icon_smart_stay.png");
+       RESOURCE_IMAGE("quick_icon_sn_vf.png");
+       RESOURCE_IMAGE("quick_icon_sf_vn.png");
+       RESOURCE_IMAGE("quick_icon_sync.png");
+       RESOURCE_IMAGE("quick_icon_wifi_tethering.png");
+       RESOURCE_IMAGE("quick_icon_mobile_data.png");
+       RESOURCE_IMAGE("quick_icon_wifi.png");
+       RESOURCE_IMAGE("quick_icon_downloadbooster_off.png");
\ No newline at end of file
diff --git a/data/quickpanel_listitem_noti.edc b/data/quickpanel_listitem_noti.edc
new file mode 100755 (executable)
index 0000000..ba7c66f
--- /dev/null
@@ -0,0 +1,777 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+//#define DEBUG
+//#define DEBUG_TEXT
+
+
+#define QP_NOTI_LISTTYPE_TITLE_COLOR "T023"
+#define QP_NOTI_LISTTYPE_TITLE_PRESS_COLOR "T023P"
+#define QP_NOTI_LISTTYPE_CONTENTS_COLOR "ATO012"
+#define QP_NOTI_LISTTYPE_COUNT_COLOR "T112"
+#define QP_NOTI_LISTTYPE_COUNT_BG_COLOR "B0517"
+#define QP_NOTI_LISTTYPE_TIME_COLOR "ATO012"
+
+#define QP_NOTI_LISTTYPE_TITLE_FONT_SIZE 30
+#define QP_NOTI_LISTTYPE_CONTENTS_FONT_SIZE 24
+#define QP_NOTI_LISTTYPE_COUNT_FONT_SIZE 21
+#define QP_NOTI_LISTTYPE_TIME_FONT_SIZE 24
+
+       styles {
+               style {
+                       name: "noti_content_text";
+                       base: "font=Tizen:style=Regular text_class=tizen align=left valign=0.5 font_size="QP_NOTI_LISTTYPE_CONTENTS_FONT_SIZE" ellipsis=1.0 color=#2B2B2BFF color_class="QP_NOTI_LISTTYPE_CONTENTS_COLOR" wrap=none";
+               }
+       }
+
+       images {
+               image: "core_icon_badge_container.#.png" COMP;
+               image: "quick_button_icon_bg.png" COMP;
+       }
+
+       group {
+               name: "quickpanel/listitem/notification";
+               data.item: "bgcolor" QP_THEME_BANDED_COLOR;
+
+               parts {
+                       part {
+                               name: "base";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 QP_THEME_LIST_ITEM_NOTIFICATION_LISTTYPE_HEIGHT;
+                                       max: -1 QP_THEME_LIST_ITEM_NOTIFICATION_LISTTYPE_HEIGHT;
+                               }
+                       }
+                       part {
+                               name: "bgcolor";
+                               type: "RECT";
+                               mouse_events: 0;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       color_class: QP_THEME_BANDED_COLOR;
+                                       visible: 1;
+                               }
+                               description {
+                                       state: "effect" 0.0;
+                                       inherit: "default" 0.0;
+                                       color_class: QP_THEME_BG_COLOR;
+                                       color: 255 255 255 128;
+                               }
+                       }
+
+                       part {
+                               name: "elm.padding.right";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 15 0;
+                                       fixed: 1 0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 1.0 0.0;
+                                       rel2.relative: 1.0 1.0;
+                                       align: 1.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.top.icon";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       //min: 0 BOX_ICON_TOP_PADDING;
+                                       //fixed: 0 1;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 1.0 0.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.left.icon";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 15 0;
+                                       fixed: 1 0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 0.0 1.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.top.text";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 BOX_TEXT_TOP_PADDING;
+                                       fixed: 0 1;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 1.0 0.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.bottom.text";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 BOX_TEXT_TOP_PADDING;
+                                       fixed: 0 1;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 1.0;
+                                       rel2.relative: 1.0 1.0;
+                                       align: 0.0 1.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.left.text";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: (15 + BOX_ICON_SIZE_W + 15) 0;
+                                       fixed: 1 0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 0.0 1.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.rect.thumbnail";
+                               type: SPACER;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: BOX_ICON_SIZE_W BOX_ICON_SIZE_W;
+                                       fixed: 1 1;
+                                       rel1 {
+                                               relative: 1.0 1.0;
+                                               to_x: "elm.padding.left.icon";
+                                               to_y: "elm.padding.top.icon";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 1.0;
+                                               to_x: "elm.padding.left.icon";
+                                               to_y: "elm.padding.top.icon";
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.rect.icon";
+                               type: SPACER;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 36 36;
+                                       fixed: 1 1;
+                                       rel1 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.thumbnail";
+                                       }
+                                       rel2 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.thumbnail";
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.rect.text";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 38;
+                                       fixed: 0 1;
+                                       rel1 {
+                                               relative: 1.0 1.0;
+                                               to_x: "elm.padding.left.text";
+                                               to_y: "elm.padding.top.text";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.padding.right";
+                                               to_y: "elm.padding.top.text";
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.rect.text.title";
+                               type: SPACER;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 38;
+                                       fixed: 0 1;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to: "elm.rect.text";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 1.0;
+                                               to: "elm.rect.text";
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                               description {
+                                       state: "move.center" 0.0;
+                                       inherit: "default" 0.0;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to_x: "elm.rect.text";
+                                               to_y: "base";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 1.0;
+                                               to_x: "elm.rect.text";
+                                               to_y: "base";
+                                       }
+                                       align: 0.0 0.5;
+                               }
+                       }
+                       part {
+                               name: "elm.rect.text.content";
+                               type: SPACER;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 32;
+                                       fixed: 0 1;
+                                       rel1 {
+                                               relative: 0.0 1.0;
+                                               to: "elm.rect.text";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 0.0;
+                                               to_x: "elm.rect.text";
+                                               to_y: "elm.padding.bottom.text";
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "masking";
+                               type: IMAGE;
+                               precise_is_inside: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: BOX_ICON_BG_SIZE_W BOX_ICON_BG_SIZE_W;
+                                       fixed : 1 1;
+                                       rel1 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.thumbnail";
+                                       }
+                                       rel2 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.thumbnail";
+                                       }
+                                       image.normal: "quick_button_icon_bg.png";
+                               }
+                       }
+                       part {
+                               name: "elm.swallow.thumbnail";
+                               type: SWALLOW;
+                               mouse_events: 0;
+                               scale: 1;
+                               clip_to: "masking";
+                               description {
+                                       state: "default" 0.0;
+                                       min: BOX_ICON_SIZE_W BOX_ICON_SIZE_H;
+                                       max: BOX_ICON_BG_SIZE_W BOX_ICON_BG_SIZE_H;
+                                       fixed: 1 1;
+                                       rel1 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.thumbnail";
+                                       }
+                                       rel2 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.thumbnail";
+                                       }
+                                       align: 0.5 0.5;
+                               }
+                       }
+                       part {
+                               name: "elm.swallow.icon";
+                               type: SWALLOW;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 30 30;
+                                       fixed: 1 1;
+                                       rel1 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.icon";
+                                       }
+                                       rel2 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.icon";
+                                       }
+                                       align: 0.5 0.5;
+                               }
+                       }
+                       part {
+                               name: "elm.text.title";
+                               type: TEXT;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.0 0.0;
+                                       //fixed: 0 1;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to:"elm.rect.text.title";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 1.0;
+                                               to:"elm.rect.text.title";
+                                       }
+                                       color_class: QP_NOTI_LISTTYPE_TITLE_COLOR;
+                                       text {
+                                               font: "Tizen:style=Regular";
+                                               text_class: "tizen";
+                                               size: QP_NOTI_LISTTYPE_TITLE_FONT_SIZE;
+                                               ellipsis: 0.0;
+                                               align: 0.0 0.5;
+                                       }
+                               }
+                               description {
+                                       state: "short" 0.0;
+                                       inherit: "default" 0.0;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to: "elm.rect.text.title";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.padding.left.time";
+                                               to_y: "elm.rect.text.title";
+                                               offset: -15 0;
+                                       }
+                               }
+                               description {
+                                       state: "short.center" 0.0;
+                                       inherit: "default" 0.0;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to: "elm.rect.text.title";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.padding.left.time";
+                                               to_y: "elm.rect.text.title";
+                                               offset: -15 0;
+                                       }
+                               }
+                       }
+
+                       part {
+                               name: "elm.padding.left.time";
+                               type: SPACER;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 1 0;
+                                       min: 10 0;
+                                       rel1 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.text.time";
+                                               to_y: "elm.padding.top.text";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.text.time";
+                                               to_y: "elm.padding.top.text";
+                                       }
+                                       align: 1.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.right.time";
+                               type: SPACER;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 1 0;
+                                       min: 10 0;
+                                       rel1 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.padding.right";
+                                               to_y: "elm.padding.top.text";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.padding.right";
+                                               to_y: "elm.padding.top.text";
+                                       }
+                                       align: 1.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.text.time";
+                               type: TEXT;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 1.0 0.5;
+                                       fixed: 1 1;
+                                       min: 0 38;
+                                       rel1 {
+                                               relative: 0.0 0.5;
+                                               to_x: "elm.padding.right";
+                                               to_y: "elm.rect.text";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 0.5;
+                                               to_x: "elm.padding.right";
+                                               to_y: "elm.rect.text";
+                                       }
+                                       color_class: QP_NOTI_LISTTYPE_TIME_COLOR;
+                                       text {
+                                               font: "Tizen:style=Regular";
+                                               text_class: "tizen";
+                                               size: QP_NOTI_LISTTYPE_TIME_FONT_SIZE;
+                                               ellipsis: 0.0;
+                                               align: 0.0 0.5;
+                                               min: 1 0;
+                                       }
+
+                               }
+                               description {
+                                       state: "center" 0.0;
+                                       inherit: "default" 0.0;
+                                       rel1 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.padding.right";
+                                               to_y: "elm.rect.text";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.padding.right";
+                                               to_y: "elm.rect.text";
+                                       }
+                               }
+                       }
+                       part {
+                               name: "elm.text.content";
+                               type: TEXT;
+                               mouse_events: 0;
+                               multiline: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.0 0.0;
+                                       fixed: 1 1;
+                                       min: 0 34;
+                                       max: -1 30;
+                                       rel1 {
+                                               to: "elm.rect.text.content";
+                                       }
+                                       rel2 {
+                                               to: "elm.rect.text.content";
+                                       }
+                                       color_class: QP_NOTI_LISTTYPE_CONTENTS_COLOR;
+                                       text {
+                                               //style: "noti_content_text";
+                                               font: "Tizen:style=Regular";
+                                               text_class: "tizen";
+                                               size: QP_NOTI_LISTTYPE_CONTENTS_FONT_SIZE;
+                                               ellipsis: 0.0;
+                                               align: 0.0 0.5;
+                                               min: 0 1;
+                                       }
+                               }
+                               description {
+                                       state: "short" 0.0;
+                                       inherit: "default" 0.0;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to: "elm.rect.text.content";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.image.count.bg";
+                                               to_y: "elm.rect.text.content";
+                                               offset: -15 0;
+                                       }
+                               }
+                       }
+                       part{
+                               name: "elm.image.count.bg";
+                               type:IMAGE;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 1.0 0.0;
+                                       fixed: 1 1;
+                                       min: 32 32;
+                                       max: 68 32;
+                                       rel1 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.padding.left.count";
+                                               to_y: "elm.rect.text";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 0.0;
+                                               to_x: "elm.padding.right.count";
+                                               to_y: "elm.padding.bottom.text";
+                                       }
+                                       image {
+                                               normal:"core_icon_badge_container.#.png";
+                                       }
+                                       color_class: QP_NOTI_LISTTYPE_COUNT_BG_COLOR;
+                                       visible:0;
+                               }
+                               description {
+                                       state: "show" 0.0;
+                                       inherit: "default" 0.0;
+                                       visible:1;
+                               }
+                               description {
+                                       state: "hide" 0.0;
+                                       inherit: "default" 0.0;
+                                       visible:0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.left.count";
+                               type: SPACER;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 1 0;
+                                       min: 10 0;
+                                       rel1 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.text.count";
+                                               to_y: "elm.padding.bottom.text";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.text.count";
+                                               to_y: "elm.padding.bottom.text";
+                                       }
+                                       align: 1.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.right.count";
+                               type: SPACER;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 1 0;
+                                       min: 10 0;
+                                       rel1 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.padding.right";
+                                               to_y: "elm.padding.bottom.text";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.padding.right";
+                                               to_y: "elm.padding.bottom.text";
+                                       }
+                                       align: 1.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.text.count";
+                               type: TEXT;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 1.0 0.0;
+                                       fixed: 1 1;
+                                       min: 0 32;
+                                       rel1 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.padding.right.count";
+                                               to_y: "elm.rect.text";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.padding.right.count";
+                                               to_y: "elm.rect.text";
+                                       }
+                                       color_class: QP_NOTI_LISTTYPE_COUNT_COLOR;
+                                       text {
+                                               font: "Tizen:style=Regular";
+                                               text_class: "tizen";
+                                               size: QP_NOTI_LISTTYPE_COUNT_FONT_SIZE;
+                                               ellipsis: 0.0;
+                                               align: 0.0 0.5;
+                                               min: 1 0;
+                                       }
+                               }
+                       }
+                       part {
+                               name: "object.layer.touch.background";
+                               mouse_events: 1;
+                               repeat_events: 1;
+                               scale: 1;
+                               type: RECT;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1 {to: "base";}
+                                       rel2 {to: "base";}
+                                       color: 0 0 0 0;
+                               }
+                       }
+                       QUICKPANEL_FOCUS_OBJECT("focus", "base", "base")
+               }
+
+               programs {
+                       program{
+                               name: "listbox.touch.down";
+                               signal: "mouse,clicked,1";
+                               source: "object.layer.touch.background";
+                               action: SIGNAL_EMIT "selected" "edje";
+                       }
+                       program{
+                               name: "effect,mouse,down";
+                               signal: "mouse,down,1";
+                               source: "object.layer.touch.background";
+                               script {
+                                       set_state(PART:"bgcolor", "effect", 0.0);
+                               }
+                       }
+                       program{
+                               name: "effect,mouse,up";
+                               signal: "mouse,up,1";
+                               source: "object.layer.touch.background";
+                               action: STATE_SET "default" 0.0;
+                               transition: ACCELERATE 0.20;
+                               target: "bgcolor";
+                       }
+                       program{
+                               name: "title.long";
+                               signal: "title.long";
+                               source: "prog";
+                               action: STATE_SET "default" 0.0;
+                               target: "elm.text.title";
+                       }
+                       program{
+                               name: "title.short";
+                               signal: "title.short";
+                               source: "prog";
+                               action: STATE_SET "short" 0.0;
+                               target: "elm.text.title";
+                       }
+                       program{
+                               name: "title.short.center";
+                               signal: "title.short.center";
+                               source: "prog";
+                               action: STATE_SET "short.center" 0.0;
+                               target: "elm.text.title";
+                       }
+                       program{
+                               name: "title.text.default";
+                               signal: "title.text.default";
+                               source: "prog";
+                               action: STATE_SET "default" 0.0;
+                               target: "elm.text.title";
+                       }
+                       program{
+                               name: "content.long";
+                               signal: "content.long";
+                               source: "prog";
+                               action: STATE_SET "default" 0.0;
+                               target: "elm.text.content";
+                       }
+                       program{
+                               name: "content.short";
+                               signal: "content.short";
+                               source: "prog";
+                               action: STATE_SET "short" 0.0;
+                               target: "elm.text.content";
+                       }
+                       program{
+                               name: "count.show";
+                               signal: "count.show";
+                               source: "prog";
+                               action: STATE_SET "show" 0.0;
+                               target: "elm.image.count.bg";
+                       }
+                       program{
+                               name: "count.hide";
+                               signal: "count.hide";
+                               source: "prog";
+                               action: STATE_SET "hide" 0.0;
+                               target: "elm.image.count.bg";
+                       }
+                       program {
+                               name: "title.move.center";
+                               signal: "title.move.center";
+                               source: "prog";
+                               action: STATE_SET "move.center" 0.0;
+                               target: "elm.rect.text.title";
+                       }
+                       program {
+                               name: "title.move.default";
+                               signal: "title.move.default";
+                               source: "prog";
+                               action: STATE_SET "default" 0.0;
+                               target: "elm.rect.text.title";
+                       }
+                       program {
+                               name: "time.move.center";
+                               signal: "time.move.center";
+                               source: "prog";
+                               action: STATE_SET "center" 0.0;
+                               target: "elm.text.time";
+                       }
+                       program {
+                               name: "time.move.default";
+                               signal: "time.move.default";
+                               source: "prog";
+                               action: STATE_SET "default" 0.0;
+                               target: "elm.text.time";
+                       }
+               }
+       }
diff --git a/data/quickpanel_listitem_ongoing.edc b/data/quickpanel_listitem_ongoing.edc
new file mode 100755 (executable)
index 0000000..c8f97ab
--- /dev/null
@@ -0,0 +1,1338 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+//#define DEBUG
+//#define DEBUG_TEXT
+
+#define QP_ONGOING_PROGRESS_TITLE_COLOR "T023"
+#define QP_ONGOING_PROGRESS_TITLE_PRESS_COLOR "T023P"
+#define QP_ONGOING_PROGRESS_CONTENTS_COLOR "ATO012"
+#define QP_ONGOING_PROGRESS_RATE_COLOR "ATO012"
+
+#define QP_ONGOING_PROGRESS_TITLE_FONT_SIZE 30
+#define QP_ONGOING_PROGRESS_CONTENTS_FONT_SIZE 24
+#define QP_ONGOING_PROGRESS_RATE_FONT_SIZE 24
+
+       group {
+               name: "quickpanel/listitem/progress";
+               data.item: "bgcolor" QP_THEME_BANDED_COLOR;
+
+               parts {
+                       part {
+                               name: "background";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 (QP_THEME_LIST_ITEM_ONGOING_PROGRESS_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT);
+                                       max: -1 (QP_THEME_LIST_ITEM_ONGOING_PROGRESS_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT);
+                               }
+                       }
+                       part {
+                               name: "seperator.top";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT;
+                                       fixed: 0 1;
+                                       rel1 {
+                                               to: "background";
+                                               relative: 0.0 0.0;
+                                       }
+                                       rel2 {
+                                               to: "background";
+                                               relative: 1.0 0.0;
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "seperator.left";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 0;
+                                       fixed: 1 0;
+                                       rel1 {
+                                               to: "background";
+                                               relative: 0.0 0.0;
+                                       }
+                                       rel2 {
+                                               to: "background";
+                                               relative: 0.0 1.0;
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "seperator.right";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 0;
+                                       fixed: 1 0;
+                                       rel1 {
+                                               to: "background";
+                                               relative: 1.0 0.0;
+                                       }
+                                       rel2 {
+                                               to: "background";
+                                               relative: 1.0 1.0;
+                                       }
+                                       align: 1.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "base";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 0 1;
+                                       min: 0 QP_THEME_LIST_ITEM_ONGOING_PROGRESS_HEIGHT;
+                                       max: 9999 QP_THEME_LIST_ITEM_ONGOING_PROGRESS_HEIGHT;
+                                       rel1 {
+                                               relative: 1.0 1.0;
+                                               to_x: "seperator.left";
+                                               to_y: "seperator.top";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to_x: "seperator.right";
+                                               to_y: "seperator.top";
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "bgcolor";
+                               type: "RECT";
+                               mouse_events: 0;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       color_class: QP_THEME_BANDED_COLOR;
+                                       visible: 1;
+                               }
+                               description {
+                                       state: "effect" 0.0;
+                                       inherit: "default" 0.0;
+                                       color_class: QP_THEME_BG_COLOR;
+                                       color: 255 255 255 128;
+                                       visible:1;
+                               }
+                       }
+
+                       part {
+                               name: "elm.padding.right";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 15 0;
+                                       fixed: 1 0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 1.0 0.0;
+                                       rel2.relative: 1.0 1.0;
+                                       align: 1.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.right.content";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 15 0;
+                                       fixed: 1 0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 1.0 0.0;
+                                       rel2.relative: 1.0 1.0;
+                                       align: 1.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.top.icon";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       //min: 0 BOX_ICON_TOP_PADDING;
+                                       //fixed: 0 1;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 1.0 0.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.left.icon";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 15 0;
+                                       fixed: 1 0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 0.0 1.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.top.text";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 9;
+                                       fixed: 0 1;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 1.0 0.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.bottom.text";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 9;
+                                       fixed: 0 1;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 1.0;
+                                       rel2.relative: 1.0 1.0;
+                                       align: 0.0 1.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.left.title";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: (15 + BOX_ICON_SIZE_W + 15) 0;
+                                       fixed: 1 0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 0.0 1.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.left.progress.text";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: (15 + BOX_ICON_SIZE_W + 15) 0;
+                                       fixed: 1 0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 0.0 1.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.left.progress";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: (15 + BOX_ICON_SIZE_W + 15) 0;
+                                       fixed: 1 0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 0.0 1.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.top.progress";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 (9 + 33 + 3);
+                                       fixed: 0 1;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 1.0 0.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.rect.thumbnail";
+                               type: SPACER;
+                               mouse_events: 0;
+                               scale: 1;
+                               description { state: "default" 0.0;
+                                       min: BOX_ICON_SIZE_W BOX_ICON_SIZE_W;
+                                       fixed: 1 1;
+                                       rel1 {
+                                               relative: 1.0 1.0;
+                                               to_x: "elm.padding.left.icon";
+                                               to_y: "elm.padding.top.icon";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 1.0;
+                                               to_x: "elm.padding.left.icon";
+                                               to_y: "elm.padding.top.icon";
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.rect.icon";
+                               type: SPACER;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 29 29;
+                                       fixed: 1 1;
+                                       rel1 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.thumbnail";
+                                       }
+                                       rel2 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.thumbnail";
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.rect.text.title";
+                               type: SPACER;
+                               mouse_events: 0;
+                               scale: 1;
+                               description { state: "default" 0.0;
+                                       min: 0 33;
+                                       fixed: 0 1;
+                                       rel1 {
+                                               relative: 1.0 1.0;
+                                               to_x: "elm.padding.left.title";
+                                               to_y: "elm.padding.top.text";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.padding.right";
+                                               to_y: "elm.padding.top.text";
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.rect.text.progress";
+                               type: SPACER;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 99 33;
+                                       fixed: 1 1;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to_x: "elm.padding.right";
+                                               to_y: "elm.padding.bottom.text";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 0.0;
+                                               to_x: "elm.padding.right";
+                                               to_y: "elm.padding.bottom.text";
+                                       }
+                                       align: 1.0 1.0;
+                               }
+                       }
+                       part {
+                               name: "elm.rect.text.content";
+                               type: SPACER;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 33;
+                                       fixed: 0 1;
+                                       rel1 {
+                                               relative: 1.0 0.0;
+                                               to_x: "elm.padding.left.title";
+                                               to_y: "elm.padding.bottom.text";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 0.0;
+                                               to_x: "elm.rect.text.progress";
+                                               to_y: "elm.padding.bottom.text";
+                                       }
+                                       align: 0.0 1.0;
+                               }
+                       }
+                       part {
+                               name: "elm.rect.progress";
+                               type: SPACER;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.0 0.0;
+                                       min: 0 6;
+                                       max: 9999 6;
+                                       fixed: 0 1;
+                                       rel1 {
+                                               relative: 1.0 1.0;
+                                               to_x: "elm.padding.left.progress";
+                                               to_y: "elm.padding.top.progress";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.padding.right";
+                                               to_y: "elm.padding.top.progress";
+                                       }
+                               }
+                       }
+
+                       part {
+                               name: "masking";
+                               type: IMAGE;
+                               precise_is_inside: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: BOX_ICON_BG_SIZE_W BOX_ICON_BG_SIZE_W;
+                                       fixed : 1 1;
+                                       rel1 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.thumbnail";
+                                       }
+                                       rel2 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.thumbnail";
+                                       }
+                                       image.normal: "quick_button_icon_bg.png";
+                               }
+                       }
+
+                       part {
+                               name: "elm.swallow.thumbnail";
+                               type: SWALLOW;
+                               mouse_events: 0;
+                               scale: 1;
+                               clip_to: "masking";
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 1 1;
+                                       min: BOX_ICON_SIZE_W BOX_ICON_SIZE_H;
+                                       max: BOX_ICON_BG_SIZE_W BOX_ICON_BG_SIZE_H;
+                                       rel1 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.thumbnail";
+                                       }
+                                       rel2 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.thumbnail";
+                                       }
+                                       align: 0.5 0.5;
+                               }
+                       }
+                       part {
+                               name: "elm.swallow.icon";
+                               type: SWALLOW;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 45 45;
+                                       fixed: 1 1;
+                                       rel1 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.icon";
+                                       }
+                                       rel2 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.icon";
+                                       }
+                                       align: 0.5 0.5;
+                               }
+                       }
+                       part {
+                               name: "elm.text.title";
+                               type: TEXT;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.0 0.5;
+                                       fixed: 0 1;
+                                       rel1 {
+                                               to:"elm.rect.text.title";
+                                       }
+                                       rel2 {
+                                               to:"elm.rect.text.title";
+                                       }
+                                       color_class: QP_ONGOING_PROGRESS_TITLE_COLOR;
+                                       text {
+                                               font: "Tizen:style=Regular";
+                                               text_class: "tizen";
+                                               size: QP_ONGOING_PROGRESS_TITLE_FONT_SIZE;
+                                               ellipsis: 0.0;
+                                               align: 0.0 0.5;
+                                       }
+                               }
+                               description {
+                                       state: "short" 0.0;
+                                       inherit: "default" 0.0;
+                                       rel1 {
+                                               to: "elm.rect.text.content";
+                                               to_y: "elm.rect.text.title";
+                                       }
+                                       rel2 {
+                                               to: "elm.rect.text.content";
+                                               to_y: "elm.rect.text.title";
+                                       }
+                               }
+                               description {
+                                       state: "selected" 0.0;
+                                       inherit: "default" 0.0;
+                               }
+                       }
+
+                       part {
+                               name: "elm.text.count";
+                               type: TEXT;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 1.0 0.5;
+                                       fixed: 0 1;
+                                       min: 0 38;
+                                       rel1 {
+                                               to:"elm.rect.text.title";
+                                       }
+                                       rel2 {
+                                               to:"elm.rect.text.title";
+
+                                       }
+                                       color_class: QP_ONGOING_PROGRESS_RATE_COLOR;
+                                       text {
+                                               font: "Tizen:style=Regular";
+                                               text_class: "tizen";
+                                               size: QP_ONGOING_PROGRESS_RATE_FONT_SIZE;
+                                               ellipsis: 0.0;
+                                               align: 1.0 0.5;
+                                       }
+                               }
+                               description {
+                                       state: "show" 0.0;
+                                       inherit: "default" 0.0;
+                                       visible:1;
+                               }
+                               description {
+                                       state: "hide" 0.0;
+                                       inherit: "default" 0.0;
+                                       visible:0;
+                               }
+                               description {
+                                       state: "selected" 0.0;
+                                       inherit: "default" 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.text.time";
+                               type: TEXT;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 1.0 0.5;
+                                       rel1 {
+                                               to:"elm.rect.text.title";
+                                       }
+                                       rel2 {
+                                               to:"elm.rect.text.title";
+                                       }
+                                       color_class: QP_ONGOING_PROGRESS_RATE_COLOR;
+                                       text {
+                                               font: "Tizen:style=Regular";
+                                               text_class: "tizen";
+                                               size: QP_ONGOING_PROGRESS_RATE_FONT_SIZE;
+                                               align: 1.0 0.5;
+                                       }
+                               }
+                               description {
+                                       state: "selected" 0.0;
+                                       inherit: "default" 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.text.content";
+                               type: TEXT;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.0 0.5;
+                                       fixed: 0 1;
+                                       rel1 {
+                                               to: "elm.rect.text.content";
+                                       }
+                                       rel2 {
+                                               to: "elm.rect.text.content";
+                                       }
+                                       color_class: QP_ONGOING_PROGRESS_CONTENTS_COLOR;
+                                       text {
+                                               font: "Tizen:style=Regular";
+                                               text_class: "tizen";
+                                               size: QP_ONGOING_PROGRESS_CONTENTS_FONT_SIZE;
+                                               align: 0.0 0.5;
+                                       }
+                                       visible: 1;
+                               }
+                       }
+                       part {
+                               name: "elm.swallow.progress";
+                               type: SWALLOW;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1 {
+                                               to: "elm.rect.progress";
+                                       }
+                                       rel2 {
+                                               to: "elm.rect.progress";
+                                       }
+                               }
+                       }
+                       part {
+                               name: "object.layer.touch.background";
+                               mouse_events: 1;
+                               repeat_events: 1;
+                               scale: 1;
+                               type: RECT;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1 {to: "base";}
+                                       rel2 {to: "base";}
+                                       color: 0 0 0 0;
+                               }
+                       }
+                       QUICKPANEL_FOCUS_OBJECT("focus", "base", "base")
+               }
+
+               programs {
+                       program{
+                               name: "effect,mouse,down";
+                               signal: "mouse,down,1";
+                               source: "object.layer.touch.background";
+                               script {
+                                       set_state(PART:"bgcolor", "effect", 0.0);
+                               }
+                       }
+                       program{
+                               name: "effect,mouse,up";
+                               signal: "mouse,up,1";
+                               source: "object.layer.touch.background";
+                               action: STATE_SET "default" 0.0;
+                               transition: ACCELERATE 0.20;
+                               target: "bgcolor";
+                       }
+#ifdef TBD
+                       program{
+                               name: "listbox.touch.down";
+                               signal: "mouse,clicked,1";
+                               source: "object.layer.touch.background";
+                               action: SIGNAL_EMIT "selected" "edje";
+                       }
+#endif
+
+                       program{
+                               name: "content.long";
+                               signal: "content.long";
+                               source: "prog";
+                               action: STATE_SET "default" 0.0;
+                               target: "elm.text.title";
+                       }
+                       program{
+                               name: "content.short";
+                               signal: "content.short";
+                               source: "prog";
+                               action: STATE_SET "short" 0.0;
+                               target: "elm.text.title";
+                       }
+                       program{
+                               name: "count.show";
+                               signal: "count.show";
+                               source: "prog";
+                               action: STATE_SET "show" 0.0;
+                               target: "elm.text.count";
+                       }
+                       program{
+                               name: "count.hide";
+                               signal: "count.hide";
+                               source: "prog";
+                               action: STATE_SET "hide" 0.0;
+                               target: "elm.text.count";
+                       }
+
+               }
+       }
+
+#define QP_ONGOING_EVENT_TITLE_COLOR "T023"
+#define QP_ONGOING_EVENT_CONTENTS_COLOR "T024"
+
+#define QP_ONGOING_EVENT_TITLE_FONT_SIZE 30
+#define QP_ONGOING_EVENT_CONTENTS_FONT_SIZE 24
+
+       group {
+               name: "quickpanel/listitem/event";
+               data.item: "bgcolor" QP_THEME_BANDED_COLOR;
+
+               styles {
+                       style {
+                               name: "ongoing_event_content_text";
+                               base: "font=Tizen:style=Regular text_class=tizen align=left valign=0.5 font_size="QP_ONGOING_EVENT_CONTENTS_FONT_SIZE" ellipsis=1.0 color=#2B2B2BFF color_class="QP_ONGOING_EVENT_CONTENTS_COLOR" wrap=none";
+                       }
+               }
+               parts {
+                       part {
+                               name: "background";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 (QP_THEME_LIST_ITEM_ONGOING_EVENT_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT);
+                                       max: -1 (QP_THEME_LIST_ITEM_ONGOING_EVENT_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT);
+                               }
+                               description {
+                                       state: "line1" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: 0 (QP_THEME_LIST_ITEM_ONGOING_EVENT_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT);
+                                       max: -1 (QP_THEME_LIST_ITEM_ONGOING_EVENT_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT);
+                               }
+                               description {
+                                       state: "line2" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: 0 (QP_THEME_LIST_ITEM_ONGOING_EVENT_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT);
+                                       max: -1 (QP_THEME_LIST_ITEM_ONGOING_EVENT_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT);
+                               }
+                               description {
+                                       state: "line3" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: 0 (QP_THEME_LIST_ITEM_ONGOING_EVENT_LINE3_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT);
+                                       max: -1 (QP_THEME_LIST_ITEM_ONGOING_EVENT_LINE3_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT);
+                               }
+                       }
+
+                       part {
+                               name: "seperator.top";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT;
+                                       fixed: 0 1;
+                                       rel1 {
+                                               to: "background";
+                                               relative: 0.0 0.0;
+                                       }
+                                       rel2 {
+                                               to: "background";
+                                               relative: 1.0 0.0;
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "seperator.left";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 0;
+                                       fixed: 1 0;
+                                       rel1 {
+                                               to: "background";
+                                               relative: 0.0 0.0;
+                                       }
+                                       rel2 {
+                                               to: "background";
+                                               relative: 0.0 1.0;
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "seperator.right";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 0;
+                                       fixed: 1 0;
+                                       rel1 {
+                                               to: "background";
+                                               relative: 1.0 0.0;
+                                       }
+                                       rel2 {
+                                               to: "background";
+                                               relative: 1.0 1.0;
+                                       }
+                                       align: 1.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "base";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 0 1;
+                                       min: 0 QP_THEME_LIST_ITEM_ONGOING_EVENT_HEIGHT;
+                                       max: -1 QP_THEME_LIST_ITEM_ONGOING_EVENT_HEIGHT;
+                                       rel1 {
+                                               relative: 1.0 1.0;
+                                               to_x: "seperator.left";
+                                               to_y: "seperator.top";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to_x: "seperator.right";
+                                               to_y: "seperator.top";
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                               description {
+                                       state: "line1" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: 0 QP_THEME_LIST_ITEM_ONGOING_EVENT_HEIGHT;
+                                       max: -1 QP_THEME_LIST_ITEM_ONGOING_EVENT_HEIGHT;
+                               }
+                               description {
+                                       state: "line2" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: 0 QP_THEME_LIST_ITEM_ONGOING_EVENT_HEIGHT;
+                                       max: -1 QP_THEME_LIST_ITEM_ONGOING_EVENT_HEIGHT;
+                               }
+                               description {
+                                       state: "line3" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: 0 QP_THEME_LIST_ITEM_ONGOING_EVENT_LINE3_HEIGHT;
+                                       max: -1 QP_THEME_LIST_ITEM_ONGOING_EVENT_LINE3_HEIGHT;
+                               }
+                       }
+
+                       part {
+                               name: "bgcolor";
+                               type: "RECT";
+                               mouse_events: 0;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       color_class: QP_THEME_BANDED_COLOR;
+                                       visible: 1;
+                               }
+                               description {
+                                       state: "effect" 0.0;
+                                       inherit: "default" 0.0;
+                                       color_class: QP_THEME_BG_COLOR;
+                                       color: 255 255 255 128;
+                               }
+                       }
+
+                       part {
+                               name: "elm.padding.right";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 8 0;
+                                       fixed: 1 0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 1.0 0.0;
+                                       rel2.relative: 1.0 1.0;
+                                       align: 1.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.top.icon";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       //min: 0 BOX_ICON_TOP_PADDING;
+                                       //fixed: 0 1;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 1.0 0.0;
+                                       align: 0.0 0.0;
+                               }
+                               description {
+                                       state: "line1" 0.0;
+                                       inherit: "default" 0.0;
+                                       //min: 0 BOX_ICON_TOP_PADDING;
+                               }
+                               description {
+                                       state: "line2" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: 0 2BOX_ICON_PADDING_H5;
+                               }
+                               description {
+                                       state: "line3" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: 0 35;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.left.icon";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 15 0;
+                                       fixed: 1 0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 0.0 1.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.top.text";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 BOX_TEXT_TOP_PADDING;
+                                       fixed: 0 1;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 1.0 0.0;
+                                       align: 0.0 0.0;
+                               }
+                               description {
+                                       state: "line1" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: 0 BOX_TEXT_TOP_PADDING;
+                               }
+                               description {
+                                       state: "line2" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: 0 9;
+                               }
+                               description {
+                                       state: "line3" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: 0 12;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.bottom.text";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 BOX_TEXT_TOP_PADDING;
+                                       fixed: 0 1;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 1.0;
+                                       rel2.relative: 1.0 1.0;
+                                       align: 0.0 1.0;
+                               }
+                               description {
+                                       state: "line1" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: 0 BOX_TEXT_TOP_PADDING;
+                               }
+                               description {
+                                       state: "line2" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: 0 0; //13.5
+                               }
+                               description {
+                                       state: "line3" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: 0 0; //19
+                               }
+                       }
+                       part {
+                               name: "elm.padding.left.title";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: (15 + BOX_ICON_SIZE_W + 15) 0;
+                                       fixed: 1 0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 0.0 1.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part { name: "elm.padding.left.contents";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: (15 + BOX_ICON_SIZE_W + 15) 0;
+                                       fixed: 1 0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 0.0 1.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.rect.thumbnail";
+                               type: SPACER;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: BOX_ICON_SIZE_W BOX_ICON_SIZE_W;
+                                       fixed: 1 1;
+                                       rel1 {
+                                               relative: 1.0 1.0;
+                                               to_x: "elm.padding.left.icon";
+                                               to_y: "elm.padding.top.icon";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 1.0;
+                                               to_x: "elm.padding.left.icon";
+                                               to_y: "elm.padding.top.icon";
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.rect.icon";
+                               type: SPACER;
+                               mouse_events: 0;
+                               scale: 1;
+                               description { state: "default" 0.0;
+                                       min: 35 35;
+                                       fixed: 1 1;
+                                       rel1 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.thumbnail";
+                                       }
+                                       rel2 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.thumbnail";
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.rect.text.title";
+                               type: SPACER;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 38;
+                                       fixed: 0 1;
+                                       rel1 {
+                                               relative: 1.0 1.0;
+                                               to_x: "elm.padding.left.title";
+                                               to_y: "elm.padding.top.text";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to_x: "elm.padding.right";
+                                               to_y: "elm.padding.top.text";
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                               description {
+                                       state: "move.center" 0.0;
+                                       inherit: "default" 0.0;
+                                       rel1 {
+                                               relative: 1.0 0.0;
+                                               to_x: "elm.padding.left.title";
+                                               to_y: "base";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 1.0;
+                                               to_x: "elm.padding.right";
+                                               to_y: "base";
+                                       }
+                                       align: 0.0 0.5;
+                               }
+                       }
+                       part {
+                               name: "elm.rect.text.content";
+                               type: SPACER;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 35 35;
+                                       fixed: 0 1;
+                                       rel1 {
+                                               relative: 1.0 1.0;
+                                               to_x: "elm.padding.left.contents";
+                                               to_y: "elm.rect.text.title";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 0.0;
+                                               to_x: "elm.padding.right";
+                                               to_y: "elm.padding.bottom.text";
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "masking";
+                               type: IMAGE;
+                               precise_is_inside: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: BOX_ICON_BG_SIZE_W BOX_ICON_BG_SIZE_W;
+                                       fixed : 1 1;
+                                       rel1 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.thumbnail";
+                                       }
+                                       rel2 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.thumbnail";
+                                       }
+                                       image.normal: "quick_button_icon_bg.png";
+                               }
+                       }
+                       part {
+                               name: "elm.swallow.thumbnail";
+                               type: SWALLOW;
+                               mouse_events: 0;
+                               scale: 1;
+                               clip_to: "masking";
+                               description {
+                                       state: "default" 0.0;
+                                       min: BOX_ICON_SIZE_W BOX_ICON_SIZE_W;
+                                       max: BOX_ICON_BG_SIZE_W BOX_ICON_BG_SIZE_W;
+                                       fixed: 1 1;
+                                       rel1 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.thumbnail";
+                                       }
+                                       rel2 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.thumbnail";
+                                       }
+                                       align: 0.5 0.5;
+                               }
+                       }
+                       part {
+                               name: "elm.swallow.icon";
+                               type: SWALLOW;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: BOX_ICON_SIZE_W BOX_ICON_SIZE_W;
+                                       fixed: 1 1;
+                                       rel1 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.icon";
+                                       }
+                                       rel2 {
+                                               relative: 0.5 0.5;
+                                               to: "elm.rect.icon";
+                                       }
+                                       align: 0.5 0.5;
+                               }
+                       }
+                       part {
+                               name: "elm.text.title";
+                               type: TEXT;
+                               mouse_events: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.0 0.0;
+                                       fixed: 0 1;
+                                       rel1 {
+                                               to:"elm.rect.text.title";
+                                       }
+                                       rel2 {
+                                               to:"elm.rect.text.title";
+                                       }
+                                       color_class: QP_ONGOING_EVENT_TITLE_COLOR;
+                                       text {
+                                               font: "Tizen:style=Regular";
+                                               text_class: "tizen";
+                                               size: QP_ONGOING_EVENT_TITLE_FONT_SIZE;
+                                               ellipsis: 0.0;
+                                               align: 0.0 0.5;
+                                       }
+                               }
+                               description {
+                                       state: "selected" 0.0;
+                                       inherit: "default" 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.text.content";
+                               type: TEXTBLOCK;
+                               mouse_events: 0;
+                               multiline: 0;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.0 0.0;
+                                       fixed: 1 1;
+                                       min: 34 34;
+                                       max: -1 30;
+                                       rel1 {
+                                               to: "elm.rect.text.content";
+                                       }
+                                       rel2 {
+                                               to: "elm.rect.text.content";
+                                       }
+                                       text {
+                                               style: "ongoing_event_content_text";
+                                               align: 0.0 0.0;
+                                       }
+                               }
+                               description {
+                                       state: "line1" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: 0 34;
+                                       max: -1 34;
+                               }
+                               description {
+                                       state: "line2" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: 0 68; //68
+                                       max: -1 68;
+                               }
+                               description {
+                                       state: "line3" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: 0 102; //102
+                                       max: -1 102;
+                               }
+                       }
+                       part {
+                               name: "object.layer.touch.background";
+                               mouse_events: 1;
+                               repeat_events: 1;
+                               scale: 1;
+                               type: RECT;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1 {to: "base";}
+                                       rel2 {to: "base";}
+                                       color: 0 0 0 0;
+                               }
+                       }
+                       QUICKPANEL_FOCUS_OBJECT("focus", "base", "base")
+               }
+
+               programs {
+                       program{
+                               name: "listbox.touch.down";
+                               signal: "mouse,clicked,1";
+                               source: "object.layer.touch.background";
+                               action: SIGNAL_EMIT "selected" "edje";
+                       }
+                       program{
+                               name: "effect,mouse,down";
+                               signal: "mouse,down,1";
+                               source: "object.layer.touch.background";
+                               script {
+                                       set_state(PART:"bgcolor", "effect", 0.0);
+                               }
+                       }
+                       program{
+                               name: "effect,mouse,up";
+                               signal: "mouse,up,1";
+                               source: "object.layer.touch.background";
+                               action: STATE_SET "default" 0.0;
+                               transition: ACCELERATE 0.20;
+                               target: "bgcolor";
+                       }
+                       program{
+                               name: "line1.set";
+                               signal: "line1.set";
+                               source: "prog";
+                               action: STATE_SET "line1" 0.0;
+                               target: "background";
+                               target: "base";
+                               target: "elm.padding.top.icon";
+                               target: "elm.padding.top.text";
+                               target: "elm.padding.bottom.text";
+                               target: "elm.text.content";
+                       }
+                       program{
+                               name: "line2.set";
+                               signal: "line2.set";
+                               source: "prog";
+                               action: STATE_SET "line2" 0.0;
+                               target: "background";
+                               target: "base";
+                               target: "elm.padding.top.icon";
+                               target: "elm.padding.top.text";
+                               target: "elm.padding.bottom.text";
+                               target: "elm.text.content";
+                       }
+                       program{
+                               name: "line3.set";
+                               signal: "line3.set";
+                               source: "prog";
+                               action: STATE_SET "line3" 0.0;
+                               target: "background";
+                               target: "base";
+                               target: "elm.padding.top.icon";
+                               target: "elm.padding.top.text";
+                               target: "elm.padding.bottom.text";
+                               target: "elm.text.content";
+                       }
+                       program {
+                               name: "title.move.center";
+                               signal: "title.move.center";
+                               source: "prog";
+                               action: STATE_SET "move.center" 0.0;
+                               target: "elm.rect.text.title";
+                       }
+               }
+       }
diff --git a/data/quickpanel_minictrl.edc b/data/quickpanel_minictrl.edc
new file mode 100755 (executable)
index 0000000..737a9ba
--- /dev/null
@@ -0,0 +1,226 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+//#define DEBUG
+//#define DEBUG_TEXT
+
+       group {
+               name: "quickpanel/minictrl/default";
+               data.item: "bgcolor" QP_THEME_BANDED_COLOR;
+               parts {
+                       part {
+                               name: "base";
+                               type: SPACER;
+                               repeat_events: 1;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 480 QP_THEME_LIST_ITEM_MINICONTRL_HEIGHT + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT;
+                                       fixed: 0 1;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                       }
+                                       rel2 {
+                                               relative: 1.0 1.0;
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.top";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 20 + QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT;
+                                       fixed: 0 1;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 1.0 0.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.left.bg";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 0;
+                                       fixed: 1 0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 0.0 1.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.right.bg";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 0;
+                                       fixed: 1 0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 1.0 0.0;
+                                       rel2.relative: 1.0 1.0;
+                                       align: 1.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.top.bg";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 QP_THEME_LIST_ITEM_SEPERATOR_HEIGHT;
+                                       fixed: 0 1;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 1.0 0.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.content.bg";
+                               type: RECT;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1 {
+                                               to_x:"elm.padding.left.bg";
+                                               to_y:"elm.padding.top.bg";
+                                               relative: 1.0 1.0;
+                                       }
+                                       rel2 {
+                                               to_x:"elm.padding.right.bg";
+                                               to_y:"elm.padding.bottom";
+                                               relative: 0.0 1.0;
+                                       }
+                                       align: 0.0 0.0;
+                                       visible: 1;
+                                       color: 255 255 255 235;
+                                       color_class: QP_THEME_ITEM_BG_COLOR;
+                               }
+                               description {
+                                       state: "show" 0.0;
+                                       inherit: "default" 0.0;
+                               }
+                               description {
+                                       state: "hide" 0.0;
+                                       inherit: "default" 0.0;
+                                       color: 0 0 0 0;
+                               }
+                       }
+                       part {
+                               name: "bgcolor";
+                               type: "RECT";
+                               mouse_events: 0;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       color_class: QP_THEME_BANDED_COLOR;
+                                       visible: 1;
+                               }
+                       }
+                       QUICKPANEL_FOCUS_OBJECT("focus", "elm.content.bg", "elm.content.bg")
+                       part {
+                               name: "elm.padding.left";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 18 0;
+                                       fixed: 1 0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 0.0 1.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.right";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 12 0;
+                                       fixed: 1 0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 1.0 0.0;
+                                       rel2.relative: 1.0 1.0;
+                                       align: 1.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.icon";
+                               type: SWALLOW;
+                               mouse_events: 1;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.0 0.0;
+                                       min: 480 140;
+                                       rel1 {
+                                               to: "elm.content.bg";
+                                       }
+                                       rel2 {
+                                               to_x: "elm.content.bg";
+                                               to_y: "elm.padding.bottom";
+                                               relative: 1.0 0.0;
+                                       }
+                               }
+                       }
+                       part {
+                               name: "elm.padding.bottom";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 0;
+                                       fixed: 1 0;
+                                       rel1.relative: 0.0 1.0;
+                                       rel2.relative: 1.0 1.0;
+                                       align: 0.0 1.0;
+                               }
+                       }
+               }
+               programs {
+                       program{
+                               name: "bg.show";
+                               signal: "bg.show";
+                               source: "prog";
+                               action: STATE_SET "show" 0.0;
+                               target: "elm.content.bg";
+                       }
+                       program{
+                               name: "bg.hide";
+                               signal: "bg.hide";
+                               source: "prog";
+                               action: STATE_SET "hide" 0.0;
+                               target: "elm.content.bg";
+                       }
+               }
+       }
diff --git a/data/quickpanel_noti_section.edc b/data/quickpanel_noti_section.edc
new file mode 100755 (executable)
index 0000000..92b9637
--- /dev/null
@@ -0,0 +1,746 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+//#define DEBUG
+//#define DEBUG_TEXT
+
+//Default part description. It is not changed by us
+#define QP_THEME_LIST_TITLE_FONT_NAME                  "Tizen:style=Bold"
+#define QP_THEME_LIST_TITLE_FONT_COLOR                 "ATO005"
+#define QP_THEME_LIST_TITLE_FONT_SIZE                  27
+
+#define QP_THEME_LIST_OPTION_FONT_COLOR                        "ATO006"
+#define QP_THEME_LIST_OPTION_PRESS_FONT_COLOR  "ATO006P"
+#define QP_THEME_LIST_OPTION_FONT_SIZE                 27
+#define QP_THEME_LIST_OPTION_ICON_PRESS_COLOR "AO005"
+
+//size of clear all item
+#define QP_CLEAR_ALL_ITEM_H    51
+#define QP_CLEAR_ALL_ITEM_W    480
+
+//Properties of "notifications (x) label in clear all notifications item"
+#define QP_CLEAR_ALL_NOTIFICATIONS_LABEL_FONT_NAME             "Tizen:style=Regular"
+//#define QP_CLEAR_ALL_NOTIFICATIONS_LABEL_FONT_COLOR  "T023"
+#define QP_CLEAR_ALL_NOTIFICATIONS_LABEL_FONT_COLOR    "A03O003L1"
+#define QP_CLEAR_ALL_NOTIFICATIONS_LABEL_FONT_SIZE             27
+#define QP_CLEAR_ALL_NOTIFICATIONS_STR_X_OFFSET 17 //x offset of "notifications(x)" string
+#define QP_CLEAR_ALL_BASE_BG_COLOR                     "AO021"
+
+//Properties of clear all button
+#define QP_CLEAR_ALL_CLEAR_ALL_BTN_TEXT_FONT_NAME              "Tizen:style=Regular"
+#define QP_CLEAR_ALL_CLEAR_ALL_BTN_FONT_COLOR                  "T112"
+#define QP_CLEAR_ALL_CLEAR_ALL_BTN_FONT_COLOR_PRESSED          "ATO006P"
+#define QP_CLEAR_ALL_CLEAR_ALL_BTN_FONT_COLOR_DIM              "ATO006D"
+#define QP_CLEAR_ALL_CLEAR_ALL_BTN_FONT_SIZE                   20
+#define QP_CLEAR_ALL_CLEAR_ALL_BTN_BG_COLOR                    "A03O003L1"
+#define QP_CLEAR_ALL_CLEAR_ALL_BTN_BG_COLOR_PRESSED            "B0517P"
+
+//Properties of separator betwen notifiactions label and clear all button
+#define QP_NOTIFICATIONS_SEP_X_OFFSET -235 //separator between "notification(x) | Clear all" button
+#define QP_NOTIFICATIONS_SEP_Y_OFFSET 17
+#define QP_NOTIFICATIONS_SEP_COLOR_CLASS "W021L2"
+
+       images {
+               image: "icon_arrow_up.png" COMP;
+               image: "icon_arrow_down.png" COMP;
+               image: "core_icon_badge_container.#.png" COMP;
+       }
+
+       group {
+               name: "quickpanel/notisection/default";
+               parts {
+                       part {
+                               name: "base";
+                               type: RECT;
+                               repeat_events: 1;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 QP_THEME_LIST_ITEM_NOTI_SECTION_HEIGHT;
+                                       max: 9999 QP_THEME_LIST_ITEM_NOTI_SECTION_HEIGHT;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                       }
+                                       rel2 {
+                                               relative: 1.0 1.0;
+                                       }
+                                       align: 0.0 0.0;
+                                       color_class: QP_THEME_BG_COLOR;
+                                       visible: QP_THEME_BG_VISIBILITY;
+                               }
+                       }
+                       QUICKPANEL_FOCUS_OBJECT("focus.label", "base", "base")
+                       part {
+                               name: "elm.padding.left";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 17 0;
+                                       fixed: 1 0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 0.0 1.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.right";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 8 0;
+                                       fixed: 1 0;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 1.0 0.0;
+                                       rel2.relative: 1.0 0.0;
+                                       align: 1.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.top";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 22;
+                                       fixed: 0 1;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 1.0 0.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.bottom";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 5;
+                                       fixed: 0 1;
+                                       rel1.to:"base";
+                                       rel2.to:"base";
+                                       rel1.relative: 0.0 1.0;
+                                       rel2.relative: 1.0 1.0;
+                                       align: 0.0 1.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.top.button";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 14;
+                                       fixed: 0 1;
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 1.0 0.0;
+                                       align: 0.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "elm.padding.bottom.button";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 3;
+                                       fixed: 0 1;
+                                       rel1.relative: 0.0 1.0;
+                                       rel2.relative: 1.0 1.0;
+                                       align: 0.0 1.0;
+                               }
+                       }
+                       part {
+                               name: "elm.rect.text";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 343 32;
+                                       fixed: 1 0;
+                                       rel1 {
+                                               to_x: "elm.padding.left";
+                                               to_y: "elm.padding.bottom";
+                                               relative: 1.0 0.0;
+                                       }
+                                       rel2 {
+                                               to_x: "elm.padding.left";
+                                               to_y: "elm.padding.bottom";
+                                               relative: 1.0 0.0;
+                                       }
+                                       align: 0.0 1.0;
+                               }
+                       }
+                       part {
+                               name: "elm.text.text";
+                               type: TEXT;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 343 35;
+                                       rel1 {
+                                               to: "elm.rect.text";
+                                       }
+                                       rel2 {
+                                               to: "elm.rect.text";
+                                       }
+                                       color: 0 0 0 255;
+                                       text {
+                                               font: QP_THEME_LIST_TITLE_FONT_NAME;
+                                               text_class: "tizen";
+                                               size: QP_THEME_LIST_TITLE_FONT_SIZE;
+                                               align: 0.0 0.5;
+                                               min: 1 0;
+                                       }
+                               }
+                       }
+                       part {
+                               name: "elm.text.text.debug";
+                               type: RECT;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1.relative: 0.0 0.0;
+                                       rel2.relative: 1.0 1.0;
+                                       rel1.to: "elm.text.text";
+                                       rel2.to: "elm.text.text";
+                                       color: 255 0 0 150;
+                               }
+               }
+
+                       part {
+                               name: "elm.rect.icon";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 106 36;
+                                       fixed: 1 1;
+                                       rel1 {
+                                               to_x: "elm.padding.right";
+                                               to_y: "base";
+                                               relative: 0.0 0.5;
+                                       }
+                                       rel2 {
+                                               to_x: "elm.padding.right";
+                                               to_y: "base";
+                                               relative: 0.0 0.5;
+                                       }
+                                       align: 1.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "text.clear.right.padding";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: (18) 0;
+                                       rel1 {
+                                               relative : 1.0 0.0;
+                                               to: "base";
+                                       }
+                                       rel2 {
+                                               relative : 1.0 1.0;
+                                               to: "base";
+                                       }
+                                       align: 1.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "text.clear";
+                               type: TEXT;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 30;
+                                       rel1 {
+                                               to_x: "text.clear.right.padding";
+                                               to_y: "elm.text.text";
+                                               relative : 0.0 0.5;
+                                       }
+                                       rel2 {
+                                               to_x: "text.clear.right.padding";
+                                               to_y: "elm.text.text";
+                                               relative: 0.0 0.5;
+                                       }
+                                       color_class: QP_THEME_LIST_OPTION_FONT_COLOR;
+                                       text {
+                                               font: QP_THEME_LIST_TITLE_FONT_NAME;
+                                               text_class: "tizen";
+                                               size: QP_THEME_LIST_OPTION_FONT_SIZE;
+                                               align: 0.0 0.5;
+                                               min: 1 0;
+                                       }
+                                       align: 1.0 0.5;
+                               }
+                               description {
+                                       state: "pressed" 0.0;
+                                       inherit: "default" 0.0;
+                                       color_class: QP_THEME_LIST_OPTION_PRESS_FONT_COLOR;
+                               }
+                       }
+                       part {
+                               name: "divider.right.padding";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: (13) 0;
+                                       rel1 {
+                                               relative : 0.0 0.0;
+                                               to: "text.clear";
+                                       }
+                                       rel2 {
+                                               relative : 0.0 1.0;
+                                               to: "text.clear";
+                                       }
+                                       align: 1.0 0.0;
+                               }
+                       }
+                       part {
+                               name: "obj.divider";
+                               type: RECT;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 2 30;
+                                       rel1 {
+                                               relative : 0.0 0.5;
+                                               to_x: "divider.right.padding";
+                                               to_y: "text.clear";
+                                       }
+                                       rel2 {
+                                               relative : 0.0 0.5;
+                                               to_x: "divider.right.padding";
+                                               to_y: "text.clear";
+                                       }
+                                       align: 1.0 0.5;
+                                       color_class: QP_THEME_SECTION_ICON_DIVIDER_COLOR;
+                                       visible: 1;
+                               }
+                       }
+                       part {
+                               name: "rect.text.touch";
+                               type: RECT;
+                               scale: 1;
+                               mouse_events: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 1 1;
+                                       rel1 {
+                                               to: "text.clear";
+                                               offset: -10 -20;
+                                       }
+                                       rel2 {
+                                               to: "text.clear";
+                                               offset: +10 +20;
+                                       }
+                                       align: 0.0 0.0;
+                                       visible: 1;
+                                       color: 0 0 0 0;
+                               }
+                       }
+               }
+
+               programs {
+                       program{
+                               name: "button.down";
+                               signal: "mouse,down,1";
+                               source: "rect.text.touch";
+                               action: STATE_SET "pressed" 0.0;
+                               target: "text.clear";
+                       }
+                       program{
+                               name: "button.up";
+                               signal: "mouse,up,1";
+                               source: "rect.text.touch";
+                               action: STATE_SET "default" 0.0;
+                               target: "text.clear";
+                       }
+                       program{
+                               name: "button.clicked";
+                               signal: "mouse,clicked,1";
+                               source: "rect.text.touch";
+                               action: SIGNAL_EMIT "button.clicked" "prog";
+                       }
+               }
+       }
+
+       group {
+
+               /**
+                * GROUP STRUCTURE
+                * base - it is the background rectangle. This part is a relative for all other parts and define background color.
+                * noti.clear.all.separator - is the line between "notification(X)" and clear all button
+                */
+
+               name: "quickpanel/notisection/clear_all";
+               parts {
+                       part {
+                               name: "base";
+                               type: RECT;
+                               scale: 1;
+                               description
+                               {
+                                       state: "default" 0.0;
+                                       min: 0 QP_CLEAR_ALL_ITEM_H;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                       }
+                                       rel2 {
+                                               relative: 1.0 1.0;
+                                       }
+                                       align: 0.0 0.0;
+                                       color_class: QP_CLEAR_ALL_BASE_BG_COLOR;
+                                       visible: 1;
+                               }
+                       }
+                       part {
+                               name: "notisection.padding.left";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 17 0;
+                                       fixed: 1 0;
+                                       align: 0.0 0.0;
+                                       rel1 {
+                                               to: "base";
+                                               relative: 0.0 0.0;
+                                       }
+                                       rel2 {
+                                               to: "base";
+                                               relative: 0.0 1.0;
+                                       }
+                               }
+                       }
+                       part {
+                               name: "notisection.padding.right";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 17 0;
+                                       fixed: 1 0;
+                                       align: 1.0 0.0;
+                                       rel1 {
+                                               to: "base";
+                                               relative: 1.0 0.0;
+                                       }
+                                       rel2 {
+                                               to: "base";
+                                               relative: 1.0 1.0;
+                                       }
+                               }
+                       }
+
+                       part {
+                               name: "underline";
+                               type: RECT;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 1;
+                                       fixed: 0 1;
+                                       rel1 {
+                                               to: "base";
+                                               relative: 0.0 1.0;
+                                       }
+                                       rel2 {
+                                               to: "base";
+                                               relative: 1.0 1.0;
+                                       }
+                                       align: 0.0 1.0;
+                                       color_class: QP_NOTIFICATIONS_SEP_COLOR_CLASS;
+                               }
+                       }
+
+                       part {
+                               name: "noti.clear.all.separator";
+                               type: RECT;
+                               scale: 1;
+                               description {
+                                       state: "default";
+                                       min: 1 36;
+                                       max: 1 36;
+                                       fixed: 1 1;
+                                       color_class: QP_NOTIFICATIONS_SEP_COLOR_CLASS;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to_x: "clear_all.padding.left";
+                                               to_y: "base";
+                                       }
+                                       rel2 {
+                                               relative: 0.0 1.0;
+                                               to_x: "clear_all.padding.left";
+                                               to_y: "base";
+                                       }
+
+                                       align: 1.0 0.5;
+                                       visible: 0;
+                               }
+                               description
+                               {
+                                       state: "hide" 0.0;
+                                       inherit: "default";
+                                       visible: 0;
+                               }
+
+                       }
+                       part {
+                               name: "separator.padding.left";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 17 0;
+                                       fixed: 1 0;
+                                       align: 1.0 0.0;
+                                       rel1 {
+                                               to: "noti.clear.all.separator";
+                                               relative: 0.0 0.0;
+                                       }
+                                       rel2 {
+                                               to: "noti.clear.all.separator";
+                                               relative: 0.0 1.0;
+                                       }
+                               }
+                       }
+
+                       part {
+                               name: "elm.text.notifications_number";
+                               type: TEXT;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 36;
+                                       align: 0.0 0.5;
+                                       rel1 {
+                                               to: "notisection.padding.left";
+                                               relative: 1.0 0.0;
+                                       }
+                                       rel2
+                                       {
+                                               relative: 0.0 1.0;
+                                               to_x: "separator.padding.left";
+                                               to_y: "base";
+                                       }
+
+                                       color_class: QP_CLEAR_ALL_NOTIFICATIONS_LABEL_FONT_COLOR;
+                                       text {
+                                               font: QP_CLEAR_ALL_NOTIFICATIONS_LABEL_FONT_NAME;
+                                               size: QP_CLEAR_ALL_NOTIFICATIONS_LABEL_FONT_SIZE;
+                                               text_class: "tizen";
+                                               align: 0.0 0.5;
+                                               ellipsis: 0.0;
+                                       }
+                               }
+                       }
+                       part {
+                               name: "rect.button.clear_all";
+                               type: IMAGE;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 75 36;
+                                       max: 130 36;
+                                       fixed: 1 1;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                       }
+                                       rel2 {
+                                               to_x: "notisection.padding.right";
+                                               to_y: "underline";
+                                               relative: 0.0 0.0;
+                                       }
+
+                                       image {
+                                               normal:"core_icon_badge_container.#.png";
+                                       }
+                                       color_class: QP_CLEAR_ALL_CLEAR_ALL_BTN_BG_COLOR;
+                                       align: 1.0 0.5;
+                                       visible: 1;
+                               }
+                               description
+                               {
+                                       state: "pressed" 0.0;
+                                       inherit: "default" 0.0;
+                                       color_class: QP_CLEAR_ALL_CLEAR_ALL_BTN_BG_COLOR_PRESSED;
+                               }
+
+                               description
+                               {
+                                       state: "hide" 0.0;
+                                       inherit: "default";
+                                       visible: 0;
+                               }
+                       }
+
+                       part {
+                               name: "text.button.clear_all";
+                               type: TEXT;
+                               scale: 1;
+                               description
+                               {
+                                       state: "default" 0.0;
+                                       min: 75 36;
+                                       max: 130 36;
+                                       fixed: 0 1;
+                                       align: 0.5 0.0;
+                                       rel1 {
+                                               to: "rect.button.clear_all";
+                                               relative: 0.0 0.0;
+                                       }
+                                       rel2 {
+                                               to: "notisection.padding.right";
+                                               relative: 0.0 1.0;
+                                       }
+                                       color_class: QP_CLEAR_ALL_CLEAR_ALL_BTN_FONT_COLOR;
+                                       text {
+                                               font: QP_CLEAR_ALL_CLEAR_ALL_BTN_TEXT_FONT_NAME;
+                                               size: QP_CLEAR_ALL_CLEAR_ALL_BTN_FONT_SIZE;
+                                               text_class: "tizen";
+                                               align: 0.5 0.5;
+                                               max: 1 0;
+                                       }
+                                       visible: 1;
+                               }
+                               description
+                               {
+                                       state: "pressed";
+                                       inherit: "default";
+                                       color_class: QP_CLEAR_ALL_CLEAR_ALL_BTN_FONT_COLOR_PRESSED;
+                               }
+                               description
+                               {
+                                       state: "dim";
+                                       inherit: "default";
+                                       color_class: QP_CLEAR_ALL_CLEAR_ALL_BTN_FONT_COLOR_DIM;
+                               }
+
+                               description
+                               {
+                                       state: "hide" 0.0;
+                                       inherit: "default";
+                                       visible: 0;
+                               }
+                       }
+                       part {
+                               name: "clear_all.padding.left";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 17 0;
+                                       fixed: 1 0;
+                                       align: 1.0 0.0;
+                                       rel1 {
+                                               to_x: "text.button.clear_all";
+                                               to_y: "base";
+                                               relative: 0.0 0.0;
+                                       }
+                                       rel2 {
+                                               to_x: "text.button.clear_all";
+                                               to_y: "base";
+                                               relative: 0.0 1.0;
+                                       }
+                               }
+                       }
+                       QUICKPANEL_FOCUS_OBJECT("focus", "rect.button.clear_all", "rect.button.clear_all")
+               }
+               programs
+               {
+
+                       program
+                       {
+                               name: "clear_all.button.pressed";
+                               signal: "mouse,down,1";
+                               source: "focus";
+
+                               action: STATE_SET "pressed" 0.0;
+                               target: "rect.button.clear_all";
+                               target: "text.button.clear_all";
+                       }
+                       program
+                       {
+                               name: "clear_all.button.released";
+                               signal: "mouse,up,1";
+                               source: "focus";
+
+                               action: STATE_SET "default" 0.0;
+                               target: "rect.button.clear_all";
+                               target: "text.button.clear_all";
+                       }
+                       program
+                       {
+                               name: "clear_all,show";
+                               signal: "notifaction,section,clear_all,show";
+                               source: "base";
+
+                               action: STATE_SET "default" 0.0;
+                               target: "rect.button.clear_all";
+                               target: "text.button.clear_all";
+                               target: "noti.clear.all.separator";
+                               target: "focus";
+                       }
+
+                       program
+                       {
+                               name: "clear_all,hide";
+                               signal: "notifaction,section,clear_all,hide";
+                               source: "base";
+
+                               action: STATE_SET "hide" 0.0;
+                               target: "rect.button.clear_all";
+                               target: "text.button.clear_all";
+                               target: "noti.clear.all.separator";
+                               target: "focus";
+                       }
+               }
+       }
+
+       group {
+               name: "quickpanel/seperator/default";
+               parts {
+                       part { name: "base";
+                               type: RECT;
+                               repeat_events: 1;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 1;
+                                       max: 9999 1;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                       }
+                                       rel2 {
+                                               relative: 1.0 0.0;
+                                       }
+                                       align: 0.0 0.0;
+                                       color: 255 0 0 100;
+                                       visible: 1;
+                               }
+                       }
+               }
+       }
diff --git a/data/quickpanel_page_setting_all.edc b/data/quickpanel_page_setting_all.edc
new file mode 100755 (executable)
index 0000000..1d99df9
--- /dev/null
@@ -0,0 +1,163 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#include "quickpanel_def.h"
+#include "color_classes.edc"
+
+#define SETTING_ALL_BG_COLOR "AO001"
+#define SETTING_ALL_SECTION_TEXT_COLOR "ATO006"
+
+       group {
+               name: "quickpanel/page_setting_all_base";
+               parts {
+                       part {
+                               name: "background";
+                               type: SPACER;
+                               scale: 1;
+                               mouse_events: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: QP_WIN_W (QP_WIN_H - QP_DATE_H - QP_HANDLE_H);
+                               }
+                               description {
+                                       state: "portrait" 0.0;
+                                       inherit: "default" 0.0;
+                               }
+                               description {
+                                       state: "landscape" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: QP_WIN_H (QP_WIN_W - QP_DATE_H - QP_HANDLE_H);
+                               }
+                       }
+                       part{
+                               name: "object.layout";
+                               type:SWALLOW;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 0 0;
+                                       rel1 {to: "background";}
+                                       rel2 {to: "background";}
+                                       align: 0.0 0.0;
+                                       visible:1;
+                               }
+                       }
+               }
+               programs {
+                       program{
+                               name: "portrait";
+                               signal: "portrait";
+                               source: "prog";
+                               action: STATE_SET "portrait" 0.0;
+                               target: "background";
+                       }
+                       program{
+                               name: "landscape";
+                               signal: "landscape";
+                               source: "prog";
+                               action: STATE_SET "landscape" 0.0;
+                               target: "background";
+                       }
+               }
+       }
+       group {
+               name: "quickpanel/page_setting_all";
+               parts {
+                       part {
+                               name: "background";
+                               type: RECT;
+                               scale: 1;
+                               mouse_events: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: QP_WIN_W (QP_WIN_H - QP_DATE_H - QP_HANDLE_H);
+                                       visible: 1;
+                                       color_class: SETTING_ALL_BG_COLOR;
+                               }
+                               description {
+                                       state: "portrait" 0.0;
+                                       inherit: "default" 0.0;
+                               }
+                               description {
+                                       state: "landscape" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: QP_WIN_H (QP_WIN_W - QP_DATE_H - QP_HANDLE_H);
+                               }
+                       }
+                       part {
+                               name: "rect.active.buttons";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 356;
+                                       rel1 {
+                                               relative: 0.0 0.0;
+                                               to_x: "background";
+                                               to_y: "background";
+                                       }
+                                       rel2 {
+                                               relative: 1.0 0.0;
+                                               to_x: "background";
+                                               to_y: "background";
+                                       }
+                                       align: 0.0 0.0;
+                               }
+                               description {
+                                       state: "portrait" 0.0;
+                                       inherit: "default" 0.0;
+                               }
+                               description {
+                                       state: "landscape" 0.0;
+                                       inherit: "default" 0.0;
+                                       min: 0 183;
+                               }
+                       }
+                       part{
+                               name: "object.active.buttons";
+                               type:SWALLOW;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       fixed: 0 0;
+                                       rel1 {to: "rect.active.buttons";}
+                                       rel2 {to: "rect.active.buttons";}
+                                       visible:1;
+                               }
+                       }
+               }
+
+               programs {
+                       program{
+                               name: "portrait";
+                               signal: "portrait";
+                               source: "prog";
+                               action: STATE_SET "portrait" 0.0;
+                               target: "background";
+                               target: "rect.active.buttons";
+                       }
+                       program{
+                               name: "landscape";
+                               signal: "landscape";
+                               source: "prog";
+                               action: STATE_SET "landscape" 0.0;
+                               target: "background";
+                               target: "rect.active.buttons";
+                       }
+               }
+       }
diff --git a/data/quickpanel_setting.edc b/data/quickpanel_setting.edc
new file mode 100755 (executable)
index 0000000..94bfcc9
--- /dev/null
@@ -0,0 +1,768 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+images {
+       image: "quick_menu_divide.png" COMP;
+       image: "quick_menu_touch.png" COMP;
+       image: "quick_button_each_bg.png" COMP;
+       image: "quick_button_each_bg_land.png" COMP;
+       image: "quick_button_each_ef.png" COMP;
+       image: "quick_button_each_ef_land.png" COMP;
+       image: "quick_btn_del_nor.png" COMP;
+       image: "quick_btn_del_press.png" COMP;
+       image: "quick_button_over_land.png" COMP;
+       image: "quick_button_over.png" COMP;
+       image: "quick_menu_divide_highlight.png" COMP;
+       image: "quick_button_icon_bg.png" COMP;
+}
+
+#define ENABLE_COLOR_CLIP
+
+#define QP_SETTINGS_HEIGHT     221
+
+styles
+{
+       style
+       {
+               name: "icon_text_style";
+               base: "font=Tizen:style=Regular font_size=19 text_class=tizen align=center color=#FFFFFF color_class=ATO017 ellipsis=1.0 wrap=mixed";
+       }
+}
+
+group {
+       name: "quickpanel/setting_container_wvga";
+
+       parts {
+               part {
+                       name: "background";
+                       type: RECT;
+                       scale: 1;
+                       description
+                       {
+                               state: "default" 0.0;
+                               min: 0 QP_SETTINGS_HEIGHT;
+                               max: -1 QP_SETTINGS_HEIGHT;
+
+                               align: 0.0 0.0;
+                               visible: 0;
+                       }
+                       description {
+                               state: "landscape" 0.0;
+                               inherit: "default" 0.0;
+                       }
+               }
+               part {
+                       name: "setting.margin.left";
+                       type: SPACER;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 0 0;
+                               fixed: 1 0;
+                               rel1 {
+                                       relative: 0.0 0.0;
+                                       to: "background";
+                               }
+                               rel2 {
+                                       relative: 0.0 1.0;
+                                       to: "background";
+                               }
+                               align: 0.0 0.0;
+                       }
+                       description {
+                               state: "portrait" 0.0;
+                               inherit: "default" 0.0;
+                       }
+                       description {
+                               state: "landscape" 0.0;
+                               inherit: "default" 0.0;
+                               min: 0 0;
+                       }
+               }
+               part {
+                       name: "setting.margin.right";
+                       type: SPACER;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 0 0;
+                               fixed: 1 0;
+                               rel1 {
+                                       relative: 1.0 0.0;
+                                       to: "background";
+                               }
+                               rel2 {
+                                       relative: 1.0 1.0;
+                                       to: "background";
+                               }
+                               align: 1.0 0.0;
+                       }
+                       description {
+                               state: "portrait" 0.0;
+                               inherit: "default" 0.0;
+                       }
+                       description {
+                               state: "landscape" 0.0;
+                               inherit: "default" 0.0;
+                               min: 0 0;
+                       }
+               }
+               part{
+                       name: "setting.container.swallow.wvga";
+                       type:SWALLOW;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 0 QP_SETTING_BG_H;
+                               fixed: 0 1;
+                               rel1 {
+                                       to: "background";
+                                       relative: 0.0 0.0;
+                               }
+                               rel2 {
+                                       to: "background";
+                                       relative: 1.0 0.0;
+                               }
+                               align: 0.5 0.0;
+                       }
+               }
+               part {
+                       name: "brightness.container.swallow.wvga";
+                       type: SWALLOW;
+                       scale:1;
+                       description {
+                               state: "default" 0.0;
+                               min: 0 QP_THEME_LIST_ITEM_BRIGHTNESS_HEIGHT;
+                               fixed: 0 1;
+                               rel1 {
+                                       to: "background";
+                                       relative: 0.0 1.0;
+
+                               }
+                               rel2 {
+                                       to: "background";
+                                       relative: 1.0 1.0;
+                               }
+
+                               align: 0.5 1.0;
+                       }
+               }
+       }
+
+       programs {
+               program{
+                       name: "container.portrait";
+                       signal: "portrait";
+                       source: "background";
+                       action: STATE_SET "portrait" 0.0;
+                       target: "setting.margin.left";
+                       target: "setting.margin.right";
+                       target: "setting.container.swallow.wvga";
+                       after: "background.default";
+               }
+               program {
+                       name : "background.default";
+                       action: STATE_SET "default" 0.0;
+                       target: "background";
+               }
+               program{
+                       name: "container.landscape";
+                       signal: "landscape";
+                       source: "background";
+                       action: STATE_SET "landscape" 0.0;
+                       target: "setting.margin.left";
+                       target: "setting.margin.right";
+                       target: "setting.container.swallow.wvga";
+                       target: "background";
+               }
+       }
+}
+
+group {
+       name: "quickpanel/setting_icon_divider_wvga";
+
+       script {
+               public g_is_hided;
+       }
+
+       parts {
+               part {
+                       name: "background";
+                       type: RECT;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: QP_SETTING_DIVIDER_W_P QP_SETTING_ICON_MIN_WH_WVGA;
+                               fixed: 1 1;
+                               align: 0.0 0.0;
+                               color_class: QP_BACKGROUND_COLOR;
+                               visible: 1;
+                       }
+                       description {
+                               state: "normal" 0.0;
+                               inherit: "default" 0.0;
+                       }
+                       description {
+                               state: "blank" 0.0;
+                               inherit: "default" 0.0;
+                               color_class: QP_BACKGROUND_COLOR;
+                       }
+                       description {
+                               state: "hide" 0.0;
+                               inherit: "default" 0.0;
+                               visible: 0;
+                       }
+                       description {
+                               state: "show" 0.0;
+                               inherit: "default" 0.0;
+                       }
+               }
+               part {
+                       name: "object.image.divider";
+                       type:IMAGE;
+                       scale:1;
+                       description {
+                               state: "default" 0.0;
+                               fixed: 1 1;
+                               min: QP_SETTING_DIVIDER_W_P 99;
+                               rel1 {
+                                       to: "background";
+                                       relative:0.0 0.5;
+                               }
+                               rel2 {
+                                       to: "background";
+                                       relative:1.0 0.5;
+                               }
+                               image {
+                                       normal:"quick_menu_divide.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                               align:0.0 0.5;
+                               visible: 0;
+                       }
+                       description {
+                               state: "highlight.show" 0.0;
+                               inherit: "default" 0.0;
+                               image {
+                                       normal:"quick_menu_divide_highlight.png";
+                                       border: 0 0 0 0;
+                                       border_scale: 1;
+                               }
+                               visible: 1;
+                       }
+                       description {
+                               state: "highlight.hide" 0.0;
+                               inherit: "default" 0.0;
+                       }
+                       description {
+                               state: "hide" 0.0;
+                               inherit: "default" 0.0;
+                               visible: 0;
+                       }
+                       description {
+                               state: "show" 0.0;
+                               inherit: "default" 0.0;
+                               visible: 0;
+                       }
+               }
+       }
+
+       programs {
+               program {
+                       name: "init_divider";
+                       signal: "load";
+                       script{
+                               set_int(g_is_hided, 0);
+                       }
+               }
+               program{
+                       name: "divider.highlight.show";
+                       signal: "highlight.show";
+                       source: "quickpanl.prog";
+                       script {
+                               if (get_int(g_is_hided) == 0) {
+                                       set_state(PART:"object.image.divider", "highlight.show", 0.0);
+                               }
+                       }
+               }
+               program{
+                       name: "divider.highlight.hide";
+                       signal: "highlight.hide";
+                       source: "quickpanl.prog";
+                       script {
+                               if (get_int(g_is_hided) == 0) {
+                                       set_state(PART:"object.image.divider", "highlight.hide", 0.0);
+                               }
+                       }
+               }
+               program{
+                       name: "blank.mode.enable";
+                       signal: "blank.enable";
+                       source: "quickpanl.prog";
+                       script {
+                               set_state(PART:"background", "blank", 0.0);
+                               set_state(PART:"object.image.divider", "show", 0.0);
+                               set_int(g_is_hided, 0);
+                       }
+               }
+               program{
+                       name: "blank.mode.disable";
+                       signal: "blank.disable";
+                       source: "quickpanl.prog";
+                       script {
+                               set_state(PART:"background", "normal", 0.0);
+                               set_state(PART:"object.image.divider", "show", 0.0);
+                               set_int(g_is_hided, 0);
+                       }
+               }
+               program{
+                       name: "divider.hide";
+                       signal: "divider.hide";
+                       source: "quickpanl.prog";
+                       script {
+                               set_state(PART:"background", "hide", 0.0);
+                               set_state(PART:"object.image.divider", "hide", 0.0);
+                               set_int(g_is_hided, 1);
+                       }
+               }
+       }
+}
+
+#define QP_SETTING_ICON_COLOR_ON "AO002"
+#define QP_SETTING_ICON_COLOR_OFF "AO003"
+#define QP_SETTING_ICON_COLOR_DIM "AO003D"
+#define QP_SETTING_ICON_COLOR_LOADING "AO003E1"
+
+group {
+       name: "quickpanel/setting_icon_wvga";
+
+       parts {
+               part {
+                       name: "background.super";
+                       type: RECT;
+                       scale: 1;
+                       mouse_events: 1;
+                       description {
+                               state: "default" 0.0;
+                               min : QP_SETTING_ICON_BG_MIN_W_P_WVGA QP_SETTING_BG_H;
+                               color: 0 0 0 0;
+                       }
+                       description {
+                               state: "portrait" 0.0;
+                               inherit: "default" 0.0;
+                       }
+                       description {
+                               state: "landscape" 0.0;
+                               inherit: "default" 0.0;
+                               min : QP_SETTING_ICON_BG_MIN_W_L_WVGA QP_SETTING_BG_H;
+                       }
+                       description {
+                               state: "dragging" 0.0;
+                               inherit: "default" 0.0;
+                               min : QP_SETTING_ICON_DRAGGING_BG_MIN_W_WVGA QP_SETTING_ICON_DRAGGING_BG_MIN_H;
+                       }
+               }
+               part {
+                       name: "padding.top";
+                       type: SPACER;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 0 17;
+                               fixed: 0 1;
+                               align: 0.5 0.0;
+                               rel1 {
+                                       relative: 0.0 0.0;
+                                       to: "background.super";
+                               }
+                               rel2 {
+                                       relative: 1.0 0.0;
+                                       to: "background.super";
+                               }
+                       }
+               }
+               part {
+                       name: "background";
+                       type: SPACER;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min : QP_SETTING_ICON_BG_MIN_W_P_WVGA QP_SETTING_ICON_MIN_WH_WVGA;
+                               max : QP_SETTING_ICON_BG_MIN_W_P_WVGA QP_SETTING_ICON_MIN_WH_WVGA;
+                               rel1 {
+                                       relative : 0.0 1.0;
+                                       to: "padding.top";
+                               }
+                               rel2 {
+                                       relative : 1.0 1.0;
+                                       to: "padding.top";
+                               }
+                               align: 0.5 0.0;
+                       }
+                       description {
+                               state: "portrait" 0.0;
+                               inherit: "default" 0.0;
+                       }
+                       description {
+                               state: "landscape" 0.0;
+                               inherit: "default" 0.0;
+                               min : QP_SETTING_ICON_BG_MIN_W_L_WVGA QP_SETTING_ICON_MIN_WH_WVGA;
+                               max : QP_SETTING_ICON_BG_MIN_W_L_WVGA QP_SETTING_ICON_MIN_WH_WVGA;
+                       }
+               }
+
+               part {
+                       name: "bg.image";
+                       type : IMAGE;
+                       scale : 1;
+                       repeat_events: 1;
+                       description     {
+                               state: "default" 0.0;
+
+                               min: QP_SETTING_ICON_MIN_WH_WVGA QP_SETTING_ICON_MIN_WH_WVGA;
+                               max: QP_SETTING_ICON_MIN_WH_WVGA QP_SETTING_ICON_MIN_WH_WVGA;
+
+                               image {
+                                       normal:"quick_button_icon_bg.png";
+                               }
+
+                               rel1 {
+                                       relative : 0.5 0.5;
+                                       to: "background";
+                               }
+                               rel2 {
+                                       relative : 0.5 0.5;
+                                       to: "background";
+                               }
+                               color_class: "AO001L1";
+                       }
+                       description {
+                               state: "pressed" 0.0;
+                               inherit: "default" 0.0;
+                               color_class: "AO001L1P";
+                       }
+                       description {
+                               state: "dimmed" 0.0;
+                               inherit: "default" 0.0;
+                               color_class: "AO001L1D";
+                       }
+               }
+
+               part {
+                       name: "pad.top";
+                       type: SPACER;
+                       scale : 1;
+                       mouse_events: 0;
+                       description {
+                               state: "default" 0.0;
+                               min: 0 0;
+                               max: 0 0;
+                               rel1 {
+                                       relative: 0.0 0.0;
+                                       to: "background";
+                               }
+                               rel2 {
+                                       relative: 1.0 0.0;
+                                       to: "background";
+                               }
+                               align: 0.0 0.0;
+                       }
+               }
+               part {
+                       name: "icon.bg";
+                       type: SPACER;
+                       scale: 1;
+                       mouse_events: 0;
+                       description {
+                               state: "default" 0.0;
+                               min: 66 66;
+                               fixed: 0 1;
+                               rel1 {
+                                       relative: 0.0 1.0;
+                                       to_x: "background.super";
+                                       to_y: "pad.top";
+                               }
+                               rel2 {
+                                       relative: 1.0 1.0;
+                                       to_x: "background.super";
+                                       to_y: "pad.top";
+                               }
+                               align: 0.0 0.0;
+                       }
+               }
+#ifdef ENABLE_COLOR_CLIP
+               part {
+                       name : "color_clip";
+                       type : RECT;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 66 66;
+                               rel1 {
+                                       relative: 0.5 0.5;
+                                       to: "icon.bg";
+                               }
+                               rel2 {
+                                       relative: 0.5 0.5;
+                                       to: "icon.bg";
+                               }
+                               align: 0.5 0.5;
+                               color: 255 255 255 255;
+                               color_class: QP_SETTING_ICON_COLOR_OFF;
+                       }
+                       description {
+                               state: "on" 0.0;
+                               inherit: "default" 0.0;
+                               color: 255 255 255 255;
+                               color_class: QP_SETTING_ICON_COLOR_ON;
+                       }
+                       description {
+                               state: "off" 0.0;
+                               inherit: "default" 0.0;
+                               color: 255 255 255 255;
+                               color_class: QP_SETTING_ICON_COLOR_OFF;
+                       }
+                       description {
+                               state: "dim" 0.0;
+                               inherit: "default" 0.0;
+                               color: 255 255 255 255;
+                               color_class: QP_SETTING_ICON_COLOR_DIM;
+                       }
+                       description {
+                               state: "loading" 0.0;
+                               inherit: "default" 0.0;
+                               color: 255 255 255 255;
+                               color_class: QP_SETTING_ICON_COLOR_LOADING;
+                       }
+               }
+#endif
+               part {
+                       name: "icon.swallow.wvga";
+                       type: SWALLOW;
+                       scale: 1;
+                       mouse_events: 0;
+#ifdef ENABLE_COLOR_CLIP
+                       clip_to: "color_clip";
+#endif
+                       description {
+                               state: "default" 0.0;
+                               min: 46 46;
+                               max: 46 46;
+                               fixed: 1 1;
+                               rel1 {
+                                       relative: 0.5 0.5;
+                                       to: "background";
+                               }
+                               rel2 {
+                                       relative: 0.5 0.5;
+                                       to: "background";
+                               }
+                               align: 0.5 0.5;
+                               visible: 1;
+                       }
+               }
+
+               part {
+                       name: "spacer.text";
+                       type: SPACER;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: (96 - 10) (24 + 2 + 24);
+                               max: (96 - 10) (24 + 2 + 24);
+                               fixed: 1 1;
+                               align: 0.5 0.0;
+                               rel1 {
+                                       relative: 0.0 1.0;
+                                       to: "background";
+                                       offset: 0 3;
+                               }
+                               rel2 {
+                                       relative: 1.0 1.0;
+                                       to: "background";
+                               }
+                       }
+               }
+
+               part
+               {
+                       name: "icon.text";
+                       type: TEXTBLOCK;
+                       scale: 1;
+                       mouse_events: 0;
+                       multiline: 1;
+
+                       description {
+                               state: "default" 0.0;
+                               rel1 {
+                                       relative: 0.0 0.0;
+                                       to: "spacer.text";
+                               }
+                               rel2 {
+                                       relative: 1.0 1.0;
+                                       to: "spacer.text";
+                               }
+                               align: 0.5 0.0;
+                               text
+                               {
+                                       style: "icon_text_style";
+                                       align: 0.5 0.0;
+                                       max: 0 1;
+                               }
+                       }
+               }
+
+               QUICKPANEL_FOCUS_OBJECT("focus", "background.super", "background.super")
+       }
+       script {
+               public icon_rotation;
+               public icon_state;
+               public icon_text_state;
+       }
+       programs {
+               program{
+                       name: "icon.portrait";
+                       signal: "icon.portrait";
+                       source: "quickpanl.prog";
+                       script {
+                               set_int(icon_rotation, 0);
+                               set_state(PART:"background.super", "portrait", 0.0);
+                               set_state(PART:"background", "portrait", 0.0);
+                       }
+               }
+               program{
+                       name: "icon.landscape";
+                       signal: "icon.landscape";
+                       source: "quickpanl.prog";
+                       script {
+                               set_int(icon_rotation, 1);
+                               set_state(PART:"background.super", "landscape", 0.0);
+                               set_state(PART:"background", "landscape", 0.0);
+                       }
+               }
+               program{
+                       name: "icon.dragging.on";
+                       signal: "dragging.on";
+                       source: "quickpanl.prog";
+                       script {
+                               set_state(PART:"background.super", "dragging", 0.0);
+                               if (get_int(icon_rotation) == 0) {
+                               } else {
+                               }
+                       }
+               }
+               program{
+                       name: "icon.dragging.off";
+                       signal: "dragging.off";
+                       source: "quickpanl.prog";
+                       script {
+                               if (get_int(icon_rotation) == 0) {
+                                       set_state(PART:"background.super", "portrait", 0.0);
+                               } else {
+                                       set_state(PART:"background.super", "landscape", 0.0);
+                               }
+                       }
+               }
+               program {
+                       name: "color.progress";
+                       signal: "icon.progress";
+                       source: "quickpanl.prog";
+                       script{
+#ifdef ENABLE_COLOR_CLIP
+                               set_state(PART:"color_clip", "loading", 0.0);
+#endif
+                       }
+
+               }
+               program {
+                       name: "color.off";
+                       signal: "icon.off";
+                       source: "quickpanl.prog";
+                       script{
+                               set_int(icon_state, 0);
+#ifdef ENABLE_COLOR_CLIP
+                               set_state(PART:"color_clip", "off", 0.0);
+#endif
+                       }
+
+               }
+               program {
+                       name: "color.on";
+                       signal: "icon.on";
+                       source: "quickpanl.prog";
+                       script{
+                               set_int(icon_state, 1);
+#ifdef ENABLE_COLOR_CLIP
+                               set_state(PART:"color_clip", "on", 0.0);
+#endif
+                       }
+               }
+               program {
+                       name: "color.dim";
+                       signal: "icon.dim";
+                       source: "quickpanl.prog";
+                       script{
+                               set_int(icon_state, 2);
+#ifdef ENABLE_COLOR_CLIP
+                               set_state(PART:"color_clip", "dim", 0.0);
+#endif
+                       }
+               }
+
+               program {
+                       name: "color.release";
+                       action: STATE_SET "press" 0.0;
+                       signal: "mouse,up,1";
+                       source: "background.super";
+                       script{
+                               if (get_int(icon_state) == 1) {
+                                       set_state(PART:"bg.image", "default", 0.0);
+#ifdef ENABLE_COLOR_CLIP
+                                       set_state(PART:"color_clip", "on", 0.0);
+#endif
+                               } else if (get_int(icon_state) == 2) {
+                                       set_state(PART:"bg.image", "dimmed", 0.0);
+#ifdef ENABLE_COLOR_CLIP
+                                       set_state(PART:"color_clip", "dim", 0.0);
+#endif
+                               } else {
+                                       set_state(PART:"bg.image", "default", 0.0);
+#ifdef ENABLE_COLOR_CLIP
+                                       set_state(PART:"color_clip", "off", 0.0);
+#endif
+                               }
+                       }
+               }
+
+               program{
+                       name: "bg.image.press";
+                       signal: "mouse,down,1";
+                       source: "background.super";
+                       action: STATE_SET "pressed" 0.0;
+                       target: "bg.image";
+               }
+               program{
+                       name: "bg.image.release";
+                       signal: "mouse,up,1";
+                       source: "background.super";
+                       action: STATE_SET "default" 0.0;
+                       target: "bg.image";
+               }
+       }
+}
diff --git a/data/quickpanel_theme.edc b/data/quickpanel_theme.edc
new file mode 100755 (executable)
index 0000000..7521496
--- /dev/null
@@ -0,0 +1,30 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#include "quickpanel_def.h"
+
+collections {
+       base_scale: 1.8;
+
+#define PROCESS_MEDIUM_IMAGE_WIDTH_INC 36
+#define PROCESS_MEDIUM_IMAGE_HEIGHT_INC 36
+#define PROCESS_MEDIUM_IMAGE_COLOR     "AO008"
+
+#include "quickpanel_theme_progressbar.edc"
+#include "quickpanel_theme_slider.edc"
+}
diff --git a/data/quickpanel_theme_progressbar.edc b/data/quickpanel_theme_progressbar.edc
new file mode 100755 (executable)
index 0000000..d2441f3
--- /dev/null
@@ -0,0 +1,145 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+
+group {
+       name: "elm/progressbar/horizontal/quickpanel_style";
+
+       images {
+               image: "core_activity_Indicator_medium_00.png" COMP;
+               image: "core_activity_Indicator_medium_01.png" COMP;
+               image: "core_activity_Indicator_medium_02.png" COMP;
+               image: "core_activity_Indicator_medium_03.png" COMP;
+               image: "core_activity_Indicator_medium_04.png" COMP;
+               image: "core_activity_Indicator_medium_05.png" COMP;
+               image: "core_activity_Indicator_medium_06.png" COMP;
+               image: "core_activity_Indicator_medium_07.png" COMP;
+               image: "core_activity_Indicator_medium_08.png" COMP;
+               image: "core_activity_Indicator_medium_09.png" COMP;
+               image: "core_activity_Indicator_medium_10.png" COMP;
+               image: "core_activity_Indicator_medium_11.png" COMP;
+               image: "core_activity_Indicator_medium_12.png" COMP;
+               image: "core_activity_Indicator_medium_13.png" COMP;
+               image: "core_activity_Indicator_medium_14.png" COMP;
+               image: "core_activity_Indicator_medium_15.png" COMP;
+               image: "core_activity_Indicator_medium_16.png" COMP;
+               image: "core_activity_Indicator_medium_17.png" COMP;
+               image: "core_activity_Indicator_medium_18.png" COMP;
+               image: "core_activity_Indicator_medium_19.png" COMP;
+               image: "core_activity_Indicator_medium_20.png" COMP;
+               image: "core_activity_Indicator_medium_21.png" COMP;
+               image: "core_activity_Indicator_medium_22.png" COMP;
+               image: "core_activity_Indicator_medium_23.png" COMP;
+               image: "core_activity_Indicator_medium_24.png" COMP;
+               image: "core_activity_Indicator_medium_25.png" COMP;
+               image: "core_activity_Indicator_medium_26.png" COMP;
+               image: "core_activity_Indicator_medium_27.png" COMP;
+               image: "core_activity_Indicator_medium_28.png" COMP;
+               image: "core_activity_Indicator_medium_29.png" COMP;
+       }
+
+       parts {
+               part {
+                       name: "access";
+                       type: RECT;
+                       description {
+                               state: "default" 0.0;
+                               fixed: 1 1;
+                               color: 0 0 0 0;
+                       }
+               }
+               part {
+                       name: "elm.background.progressbar";
+                       type: RECT;
+                       mouse_events: 0;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                       }
+               }
+               part {
+                       name: "background";
+                       mouse_events: 0;
+                       scale: 1;
+                       clip_to: "elm.background.progressbar";
+                       description {
+                               state: "default" 0.0;
+                               min: PROCESS_MEDIUM_IMAGE_WIDTH_INC PROCESS_MEDIUM_IMAGE_HEIGHT_INC;
+                               max: PROCESS_MEDIUM_IMAGE_WIDTH_INC PROCESS_MEDIUM_IMAGE_HEIGHT_INC;
+                               aspect: 1.0 1.0;
+                               aspect_preference: BOTH;
+                               color_class: PROCESS_MEDIUM_IMAGE_COLOR;
+                               image.normal: "core_activity_Indicator_medium_00.png";
+                               image.tween: "core_activity_Indicator_medium_01.png";
+                               image.tween: "core_activity_Indicator_medium_02.png";
+                               image.tween: "core_activity_Indicator_medium_03.png";
+                               image.tween: "core_activity_Indicator_medium_04.png";
+                               image.tween: "core_activity_Indicator_medium_05.png";
+                               image.tween: "core_activity_Indicator_medium_06.png";
+                               image.tween: "core_activity_Indicator_medium_07.png";
+                               image.tween: "core_activity_Indicator_medium_08.png";
+                               image.tween: "core_activity_Indicator_medium_09.png";
+                               image.tween: "core_activity_Indicator_medium_10.png";
+                               image.tween: "core_activity_Indicator_medium_11.png";
+                               image.tween: "core_activity_Indicator_medium_12.png";
+                               image.tween: "core_activity_Indicator_medium_13.png";
+                               image.tween: "core_activity_Indicator_medium_14.png";
+                               image.tween: "core_activity_Indicator_medium_15.png";
+                               image.tween: "core_activity_Indicator_medium_16.png";
+                               image.tween: "core_activity_Indicator_medium_17.png";
+                               image.tween: "core_activity_Indicator_medium_18.png";
+                               image.tween: "core_activity_Indicator_medium_19.png";
+                               image.tween: "core_activity_Indicator_medium_20.png";
+                               image.tween: "core_activity_Indicator_medium_21.png";
+                               image.tween: "core_activity_Indicator_medium_22.png";
+                               image.tween: "core_activity_Indicator_medium_23.png";
+                               image.tween: "core_activity_Indicator_medium_24.png";
+                               image.tween: "core_activity_Indicator_medium_25.png";
+                               image.tween: "core_activity_Indicator_medium_26.png";
+                               image.tween: "core_activity_Indicator_medium_27.png";
+                               image.tween: "core_activity_Indicator_medium_28.png";
+                               image.tween: "core_activity_Indicator_medium_29.png";
+                       }
+               }
+       }
+
+       programs {
+               program {
+                       name: "start_pulse";
+                       signal: "elm,state,pulse,start";
+                       source: "elm";
+                       action: STATE_SET "default" 0.0;
+                       target: "background";
+                       transition: LINEAR 1.8;
+                       after: "start_pulse";
+               }
+               program {
+                       name: "stop_pulse";
+                       signal: "elm,state,pulse,stop";
+                       source: "elm";
+                       action: ACTION_STOP;
+                       target: "start_pulse";
+                       after: "init_pulse";
+               }
+               program {
+                       name: "init_pulse";
+                       action: STATE_SET "default" 0.0;
+                       target: "background";
+               }
+       }
+}
diff --git a/data/quickpanel_theme_slider.edc b/data/quickpanel_theme_slider.edc
new file mode 100755 (executable)
index 0000000..88af2e2
--- /dev/null
@@ -0,0 +1,694 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include "color_classes.edc"
+
+#define SLIDER_BASE_HEIGHT_INC  6
+#define SLIDER_INDICATOR_SIZE_INC 42
+#define SLIDER_SWALLOWBAR_HEIGHT_INC  42
+#define SLIDER_LEFT_RIGHT_PADDING_SIZE_INC 20 0
+#define SLIDER_ICON_PADDING_SIZE_INC 5 0
+#define SLIDER_CENTER_POINT_SIZE_INC 10 24
+
+#define SLIDER_POPUP_WIDTH_INC 80
+#define SLIDER_POPUP_HEIGHT_INC 92
+
+group {
+       name: "elm/slider/horizontal/indicator/quickpanel_style";
+       images {
+               image: "core_slider_handle_normal.png" COMP;
+               image: "core_slider_handle_press.png" COMP;
+       }
+       parts {
+               part {
+                       name: "access";
+                       type: RECT;
+                       description { state: "default" 0.0;
+                               fixed: 1 1;
+                               color: 0 0 0 0;
+                       }
+               }
+               part {
+                       name: "button_events";
+                       type: RECT;
+                       mouse_events: 1;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               fixed: 1 1;
+                               min: 2*SLIDER_INDICATOR_SIZE_INC 1.5*SLIDER_INDICATOR_SIZE_INC;
+                               aspect: 1.0 1.0;
+                               aspect_preference: VERTICAL;
+                               color: 0 0 0 0;
+                       }
+                       description {
+                               state: "disabled" 0.0;
+                               inherit: "default" 0.0;
+                               visible: 0;
+                       }
+               }
+               part {
+                       name: "button0";
+                       mouse_events: 0;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               fixed: 1 1;
+                               min: SLIDER_INDICATOR_SIZE_INC SLIDER_INDICATOR_SIZE_INC;
+                               max: SLIDER_INDICATOR_SIZE_INC SLIDER_INDICATOR_SIZE_INC;
+                               image {
+                                       normal: "core_slider_handle_normal.png";
+                               }
+                               color_class: "AO005L3";
+                       }
+                       description {
+                               state: "disabled" 0.0;
+                               inherit: "default" 0.0;
+                               color_class: "AO004D";
+                               visible: 1;
+                       }
+               }
+               part {
+                       name: "button0_press";
+                       mouse_events: 0;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               fixed: 1 1;
+                               min: SLIDER_INDICATOR_SIZE_INC SLIDER_INDICATOR_SIZE_INC;
+                               max: SLIDER_INDICATOR_SIZE_INC SLIDER_INDICATOR_SIZE_INC;
+                               image {
+                                       normal: "core_slider_handle_press.png";
+                               }
+                               color_class: "AO005L4";
+                               visible: 0;
+                               }
+                       description {
+                               state: "pressed" 0.0;
+                               inherit: "default" 0.0;
+                               visible: 1;
+                       }
+               }
+       }
+       programs {
+               program { name: "mouse_down";
+                       signal: "mouse,down,*";
+                       source: "button_events";
+                       action:  STATE_SET "pressed" 0.0;
+                       target: "button0_press";
+               }
+               program { name: "mouse_up";
+                       signal: "mouse,up,*";
+                       source: "button_events";
+                       action:  STATE_SET "default" 0.0;
+                       target: "button0_press";
+               }
+               program { name: "slider_disable";
+                       signal: "elm,state,disabled";
+                       source: "elm";
+                       action:  STATE_SET "disabled" 0.0;
+                       target: "button0";
+                       target: "button_events";
+               }
+               program { name: "slider_enable";
+                       signal: "elm,state,enabled";
+                       source: "elm";
+                       action:  STATE_SET "default" 0.0;
+                       target: "button0";
+                       target: "button_events";
+               }
+       }
+}
+
+group {
+       name: "elm/slider/horizontal/quickpanel_style";
+               images {
+                       image: "core_progressbar_bg.#.png" COMP;
+                       image: "core_progress_bar.#.png" COMP;
+                       image: "core_slider_center_point_bg.png" COMP;
+               }
+               script {
+                       public invert_on = 0;
+                       public popup_show = 1;
+                       public show = 0;
+                       public set_popup_show() {
+                               set_int(popup_show, 1);
+                       }
+                       public set_popup_hide() {
+                               set_int(popup_show, 0);
+                       }
+                       public set_invert_on() {
+                               set_state(PART:"level", "inverted", 0.0);
+                               set_state(PART:"level2", "inverted", 0.0);
+                               set_int(invert_on, 1);
+                       }
+                       public set_invert_off() {
+                               set_state(PART:"level", "default", 0.0);
+                               set_state(PART:"level2", "default", 0.0);
+                               set_int(invert_on, 0);
+                       }
+                       public thumb_down() {
+                               if (get_int(invert_on) == 0) {
+                                       set_state(PART:"level", "pressed", 0.0);
+                                       set_state(PART:"level2", "pressed", 0.0);
+                               }
+                               if (get_int(popup_show) == 1) {
+                                       emit("popup,show", "elm");
+                               }
+                       }
+                       public thumb_up() {
+                               if (get_int(invert_on) == 0) {
+                                       set_state(PART:"level", "default", 0.0);
+                                       set_state(PART:"level2", "default", 0.0);
+                               }
+                               if (get_int(popup_show) == 1) {
+                                       emit("popup,hide", "elm");
+                               }
+                       }
+                       public drag_state() {
+                               new Float:dx, Float:dy;
+                               get_drag(PART:"elm.dragable.slider", dx, dy);
+                               if (dx > 0.5) {
+                                       set_state(PART:"level", "default", 0.0);
+                                       set_state(PART:"level2", "default", 0.0);
+                                       set_int(invert_on, 0);
+                               }
+                               else {
+                                       set_state(PART:"level", "inverted", 0.0);
+                                       set_state(PART:"level2", "inverted", 0.0);
+                                       set_int(invert_on, 1);
+                               }
+                       }
+                       public message(Msg_Type:type, id, ...) {
+                               if (type == MSG_FLOAT_SET) {
+                                       new Float:ratio;
+                                       ratio = getfarg(2);
+                                       if (id == 1) {
+                                               custom_state(PART:"left_restrict", "default", 0.0);
+                                               set_state_val(PART:"left_restrict", STATE_REL2, ratio, 0.0);
+                                               set_state(PART:"left_restrict", "custom", 0.0);
+                                       } else if (id == 2) {
+                                               custom_state(PART:"right_restrict", "default", 0.0);
+                                               set_state_val(PART:"right_restrict", STATE_REL1, 1.0 - ratio, 0.0);
+                                               set_state(PART:"right_restrict", "custom", 0.0);
+                                       }
+                               }
+                       }
+               }
+       parts {
+               part {
+                       name: "access";
+                       type: RECT;
+                       description {
+                               state: "default" 0.0;
+                               fixed: 1 1;
+                               color: 0 0 0 0;
+                       }
+               }
+               part {
+                       name: "bg";
+                       type: SPACER;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 0 SLIDER_SWALLOWBAR_HEIGHT_INC;
+                       }
+               }
+               part {
+                       name: "elm.swallow.icon";
+                       type: SWALLOW;
+                       clip_to: "icon_clipper";
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               visible: 0;
+                               align: 0.0 0.5;
+                               max: SLIDER_SWALLOWBAR_HEIGHT_INC SLIDER_SWALLOWBAR_HEIGHT_INC;
+                               rel1 {
+                                       relative: 0.0 0.0;
+                                       to: "bg";
+                               }
+                               rel2 {
+                                       relative: 0.0 1.0;
+                                       to: "bg";
+                               }
+                       }
+                       description {
+                               state: "visible" 0.0;
+                               inherit: "default" 0.0;
+                               visible: 1;
+                       }
+               }
+               part {
+                       name: "bar_icon_right_padding_1";
+                       type: SPACER;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               align: 0.0 0.5;
+                               min: 0 0;
+                               max: 0 0;
+                               rel1 {
+                                       relative: 1.0  0.0;
+                                       to: "elm.swallow.icon";
+                               }
+                               rel2 {
+                                       relative: 1.0  1.0;
+                                       to: "elm.swallow.icon";
+                               }
+                               fixed: 1 1;
+                       }
+                       description { state: "visible";
+                               inherit: "default" 0.0;
+                               min: SLIDER_ICON_PADDING_SIZE_INC;
+                               max: SLIDER_ICON_PADDING_SIZE_INC;
+                       }
+               }
+               part {
+                       name: "bar_icon_right_padding_2";
+                       type: SPACER;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               align: 0.0 0.5;
+                               min: SLIDER_LEFT_RIGHT_PADDING_SIZE_INC;
+                               max: SLIDER_LEFT_RIGHT_PADDING_SIZE_INC;
+                               rel1 {
+                               relative: 1.0  0.0;
+                                       to: "bar_icon_right_padding_1";
+                               }
+                               rel2 {
+                                       relative: 1.0  1.0;
+                                       to: "bar_icon_right_padding_1";
+                               }
+                               fixed: 1 1;
+                       }
+               }
+               part {
+                       name: "left_restrict";
+                       type: RECT;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 0 SLIDER_BASE_HEIGHT_INC;
+                               max: -1 SLIDER_BASE_HEIGHT_INC;
+                               fixed: 1 1;
+                               rel1 {
+                                       to: "base";
+                                       relative: 0.0 0.0;
+                               }
+                               rel2 {
+                                       to: "base";
+                                       relative: 0.0 1.0;
+                               }
+                               align: 0.0 0.5;
+                       }
+               }
+               part {
+                       name: "right_restrict";
+                       type: RECT;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 0 SLIDER_BASE_HEIGHT_INC;
+                               max: -1 SLIDER_BASE_HEIGHT_INC;
+                               rel1 {
+                                       to: "base";
+                                       relative: 1.0 0.0;
+                               }
+                               rel2 {
+                                       to: "base";
+                                       relative: 1.0 1.0;
+                               }
+                       }
+               }
+               part {
+                       name: "base";
+                       mouse_events: 0;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 0 SLIDER_BASE_HEIGHT_INC;
+                               max: -1 SLIDER_BASE_HEIGHT_INC;
+                               rel1 {
+                                       to: "bar_icon_right_padding_2";
+                                       relative: 1.0 0.0;
+                               }
+                               rel2 {
+                                       to: "bar_image_right_padding";
+                                       relative: 0.0 1.0;
+                               }
+                               fixed: 0 1;
+                               image.normal: "core_progressbar_bg.#.png";
+                               color: 255 255 255 255;
+                               color_class: "AO005L1";
+                       }
+                       description {
+                               state: "disabled" 0.0;
+                               inherit: "default" 0.0;
+                               color_class: "AO005L1D";
+                       }
+               }
+               part {
+                       name: "drag_base";
+                       type: "SPACER";
+                       description {
+                               state: "default" 0.0;
+                               min: 0 SLIDER_SWALLOWBAR_HEIGHT_INC;
+                               rel1 {
+                                       to_x: "left_restrict";
+                                       to_y: "bg";
+                                       relative: 1.0 0.0;
+                                       offset: -SLIDER_LEFT_RIGHT_PADDING_SIZE_INC;
+                               }
+                               rel2 {
+                                       to_x: "right_restrict";
+                                       to_y: "bg";
+                                       relative: 0.0 1.0;
+                                       offset: SLIDER_LEFT_RIGHT_PADDING_SIZE_INC;
+                               }
+                               fixed: 1 1;
+                       }
+               }
+               part {
+                       name: "level";
+                       mouse_events: 0;
+                       scale: 1;
+                       clip_to: "clipper";
+                       description {
+                               state: "default" 0.0;
+                               rel1 {
+                                       to_x: "bar_icon_right_padding_2";
+                                       relative: 1.0 0.0;
+                               }
+                               rel2 {
+                                       to_x: "elm.dragable.slider";
+                                       relative: 0.5 1.0;
+                               }
+                               fixed: 1 1;
+                               min: 0 SLIDER_BASE_HEIGHT_INC;
+                               max: -1 SLIDER_BASE_HEIGHT_INC;
+                               image.normal: "core_progressbar_bg.#.png";
+                       }
+                       description {
+                               state: "inverted" 0.0;
+                               inherit: "default" 0.0;
+                               visible: 0;
+                       }
+               }
+               part { 
+                       name: "level2";
+                       mouse_events: 0;
+                       scale: 1;
+                       clip_to: "clipper";
+                       description {
+                               state: "default" 0.0;
+                               fixed: 1 1;
+                               visible: 0;
+                               rel1 {
+                                       to_y: "base";
+                                       to_x: "elm.dragable.slider";
+                                       relative: 0.5 0.0;
+                               }
+                               rel2.to: "base";
+                                       image.normal: "core_progressbar_bg.#.png";
+                               }
+                               description {
+                                       state: "inverted" 0.0;
+                                       inherit: "default" 0.0;
+                                       visible: 1;
+                       }
+               }
+               part {
+                       name: "bar_image_right_padding";
+                       type: SPACER;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: SLIDER_LEFT_RIGHT_PADDING_SIZE_INC;
+                               max: SLIDER_LEFT_RIGHT_PADDING_SIZE_INC;
+                               fixed: 1 0;
+                               rel1 {
+                                       relative: 1.0  0.0;
+                                       to: "bg";
+                               }
+                               rel2 {
+                                       relative: 1.0  1.0;
+                                       to: "bg";
+                               }
+                               align: 1.0 0.5;
+                       }
+               }
+               part { name: "icon_clipper";
+                       scale: 1;
+                       type: RECT;
+                       description {
+                               state: "default" 0.0;
+                               color_class: "W0661";
+                       }
+                       description {
+                               state: "disabled" 0.0;
+                               color_class: "W0661D";
+                       }
+               }
+               part {
+                       name: "elm.swallow.bar";
+                       type: SWALLOW;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 0  SLIDER_SWALLOWBAR_HEIGHT_INC;
+                               max: -1 SLIDER_SWALLOWBAR_HEIGHT_INC;
+                               fixed: 0 1;
+                               rel1 {
+                                       to: "bar_icon_right_padding_2";
+                                       relative: 1.0 0.0;
+                               }
+                               rel2 {
+                                       to: "bar_image_right_padding";
+                                       relative: 0.0 1.0;
+                               }
+                       }
+               }
+               part {
+                       name:"center_point";
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: SLIDER_CENTER_POINT_SIZE_INC;
+                               max: SLIDER_CENTER_POINT_SIZE_INC;
+                               visible: 0;
+                               image.normal: "core_slider_center_point_bg.png";
+                               rel1.to: "base";
+                               rel2.to: "base";
+                               fixed: 0 1;
+                               color_class: "W062L1";
+                       }
+                       description {
+                               state: "visible" 0.0;
+                               inherit: "default" 0.0;
+                               visible: 1;
+                       }
+                       description {
+                               state: "disabled" 0.0;
+                               inherit: "default" 0.0;
+                               visible: 1;
+                               color_class: "W062L1D";
+                       }
+               }
+               part {
+                       name: "elm.track.slider";
+                       type: SWALLOW;
+                       mouse_events: 0;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               min: 0 SLIDER_POPUP_HEIGHT_INC;
+                               max: -1 SLIDER_POPUP_HEIGHT_INC;
+                               align: 0.5 1.0;
+                               fixed: 0 1;
+                               rel1.to: "elm.dragable.slider";
+                               rel1.offset: 0 8;
+                               rel2 {
+                                       relative: 1.0 0.0;
+                                       to: "elm.dragable.slider";
+                                       offset: 0 8;
+                               }
+                       }
+               }
+               part {
+                       name: "elm.dragable.slider";
+                       type: GROUP;
+                       source: "elm/slider/horizontal/indicator/quickpanel_style";
+                       mouse_events: 1;
+                       scale: 1;
+                       dragable {
+                               x: 1 1 0;
+                               y: 0 0 0;
+                               confine: "drag_base";
+                       }
+                       description {
+                               state: "default" 0.0;
+                               min: SLIDER_INDICATOR_SIZE_INC SLIDER_INDICATOR_SIZE_INC;
+                               fixed: 1 1;
+                               align: 0.5 0.5;
+                               rel1.to: "drag_base";
+                               rel1.relative: 0.5 0.5;
+                               rel2.to: "drag_base";
+                               rel2.relative: 0.5 0.5;
+                               color: 0 0 0 0;
+                       }
+               }
+               part {
+                       name: "disabler";
+                       type: RECT;
+                       mouse_events: 1;
+                       repeat_events: 0;
+                       scale: 1;
+                       description {
+                               state: "default" 0.0;
+                               visible: 0;
+                               color: 0 0 0 0;
+                       }
+                       description {
+                               state: "disabled" 0.0;
+                               inherit: "default" 0.0;
+                               visible: 1;
+                       }
+               }
+               part {
+                       name: "clipper";
+                       type: RECT;
+                       description {
+                               state: "default" 0.0;
+                                       color_class: "AO005L2";
+                               }
+                               description {
+                                       state: "pressed" 0.0;
+                                       color_class: "AO005L2";
+                               }
+                               description {
+                                       state: "disabled" 0.0;
+                                       color_class: "AO004D";
+                               }
+                       }
+               }
+               programs {
+                       program {
+                       name: "invert_on";
+                       signal: "elm,state,inverted,on";
+                       source: "elm";
+                       script {
+                               set_invert_on();
+                       }
+               }
+               program {
+                       name: "invert_off";
+                       signal: "elm,state,inverted,off";
+                       source: "elm";
+                       script {
+                               set_invert_off();
+                       }
+               }
+               program {
+                       name: "val_show";
+                       signal: "mouse,down,*";
+                       source: "elm.dragable.slider";
+                       script {
+                               thumb_down();
+                       }
+               }
+               program {
+                       name: "val_hide";
+                       signal: "mouse,up,*";
+                       source: "elm.dragable.slider";
+                       script {
+                               thumb_up();
+                       }
+               }
+               program {
+                       name: "popup_show";
+                       signal: "elm,state,val,show";
+                       source: "elm";
+                       script {
+                               set_popup_show();
+                       }
+               }
+               program {
+                       name: "popup_hide";
+                       signal: "elm,state,val,hide";
+                       source: "elm";
+                       script {
+                               set_popup_hide();
+                       }
+               }
+               program {
+                       name: "icon_show";
+                       signal: "elm,state,icon,visible";
+                       source: "elm";
+                       action:  STATE_SET "visible" 0.0;
+                       target: "elm.swallow.icon";
+                       target: "bar_icon_right_padding_1";
+               }
+               program {
+                       name: "center_point_enable";
+                       signal: "slider,center,point,show";
+                       source: "elm";
+                       script {
+                               set_state(PART:"center_point", "visible", 0.0);
+                               set_int(show, 1);
+                       }
+               }
+               program {
+                       name: "center_point_disable";
+                       signal: "slider,center,point,hide";
+                       source: "elm";
+                       script {
+                               set_state(PART:"center_point", "default", 0.0);
+                               set_int(show, 0);
+                       }
+               }
+               program {
+                       name: "slider_disable";
+                       signal: "elm,state,disabled";
+                       source: "elm";
+                       script {
+                               if (get_int(show)) {
+                                       set_state(PART:"center_point", "disabled", 0.0);
+                               }
+                               set_state(PART:"disabler", "disabled", 0.0);
+                               set_state(PART:"icon_clipper", "disabled", 0.0);
+                               set_state(PART:"clipper", "disabled", 0.0);
+                               set_state(PART:"base", "disabled", 0.0);
+                       }
+               }
+               program {
+                       name: "slider_enable";
+                       signal: "elm,state,enabled";
+                       source: "elm";
+                       script {
+                               if (get_int(show)) {
+                                       set_state(PART:"center_point", "default", 0.0);
+                               }
+                               set_state(PART:"disabler", "default", 0.0);
+                               set_state(PART:"icon_clipper", "default", 0.0);
+                               set_state(PART:"clipper", "default", 0.0);
+                               set_state(PART:"base", "default", 0.0);
+                       }
+               }
+       }
+}
diff --git a/data/quickpanel_voice_control.edc b/data/quickpanel_voice_control.edc
new file mode 100755 (executable)
index 0000000..e403b7f
--- /dev/null
@@ -0,0 +1,151 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+#include "color_classes.edc"
+#include "quickpanel_def.h"
+
+#define QP_THEME_VOICE_CONTOL_BG_COLOR "B0211"
+#define QP_VOICE_CONTOL_HEIGHT 80
+
+images
+{
+       image: "voice_control_icon_mic.png" COMP;
+       image: "core_list_button_bg.#.png" COMP;
+}
+
+collections
+{
+       base_scale: 1.8;
+
+       group {
+               name: "quickpanel/voice_control/default";
+               data.item: "bgcolor" QP_THEME_VOICE_CONTOL_BG_COLOR;
+
+               parts {
+                       part {
+                               name: "base";
+                               type: SPACER;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       min: 0 QP_VOICE_CONTOL_HEIGHT;
+                                       max: -1 QP_VOICE_CONTOL_HEIGHT;
+                               }
+                       }
+                       part {
+                               name: "bgcolor";
+                               type: RECT;
+                               scale: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       rel1 {
+                                               to: "base";
+                                               relative: 0.0 0.0;
+                                       }
+                                       rel2 {
+                                               to: "base";
+                                               relative: 1.0 1.0;
+                                       }
+                                       color_class: QP_THEME_VOICE_CONTOL_BG_COLOR;
+                                       visible: 0;
+                               }
+                       }
+                       part {
+                               name: "button_bg";
+                               type: IMAGE;
+                               mouse_events: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       align: 0.5 0.5;
+                                       rel1 {
+                                               to: "base";
+                                               relative: 0.2 0.1;
+                                       }
+                                       rel2 {
+                                               to: "base";
+                                               relative: 0.8 0.9;
+                                       }
+                                       image {
+                                               normal: "core_list_button_bg.#.png";
+                                       }
+                                       color: 52 123 135 255;
+                               }
+                               description
+                               {
+                                       state: "pressed" 0.0;
+                                       inherit: "default" 0.0;
+                                       color_class: "AO001L1P";
+                               }
+                       }
+                       part {
+                               name: "button_img";
+                               type: IMAGE;
+                               mouse_events: 1;
+                               description {
+                                       state: "default" 0.0;
+                                       max: 50 50;
+                                       align: 0.5 0.5;
+                                       rel1 {
+                                               to: "button_bg";
+                                       }
+                                       rel2 {
+                                               to: "button_bg";
+                                       }
+                                       image {
+                                               normal: "voice_control_icon_mic.png";
+                                       }
+                               }
+                       }
+               }
+
+               programs {
+
+                       program {
+                               name: "pressed_button";
+                               signal: "mouse,clicked,1";
+                               source: "button_bg";
+                               action: SIGNAL_EMIT "button_clicked" "";
+                       }
+
+                       program {
+                               name: "pressed_button_img";
+                               signal: "mouse,clicked,1";
+                               source: "button_img";
+                               action: SIGNAL_EMIT "button_clicked" "";
+                       }
+
+                       program {
+                               name: "pressed_button_bg";
+                               signal: "mouse,down,1";
+                               source: "button_bg";
+                               action: STATE_SET "pressed" 0.0;
+                               target: "button_bg";
+                       }
+
+                       program {
+                               name: "released_button_bg";
+                               signal: "mouse,up,1";
+                               source: "button_bg";
+                               action: STATE_SET "default" 0.0;
+                               target: "button_bg";
+                       }
+               }
+       }
+}
+
+
+
diff --git a/packaging/org.tizen.quickpanel.manifest b/packaging/org.tizen.quickpanel.manifest
new file mode 100755 (executable)
index 0000000..7438319
--- /dev/null
@@ -0,0 +1,8 @@
+<manifest>
+       <request>
+               <domain name="_" />
+       </request>
+       <assign>
+               <filesystem path="/usr/apps/org.tizen.quickpanel/bin/quickpanel" exec_label="User::App::org.tizen.quickpanel" />
+       </assign>
+</manifest>
diff --git a/packaging/org.tizen.quickpanel.spec b/packaging/org.tizen.quickpanel.spec
new file mode 100755 (executable)
index 0000000..411fbb7
--- /dev/null
@@ -0,0 +1,106 @@
+%bcond_with wayland
+%define __usrdir /usr/lib/systemd/user
+
+Name: org.tizen.quickpanel
+Summary: Quick access panel for the notifications and various kinds of services.
+Version: 0.8.0
+Release: 1
+Group: Applications/Core Applications
+License: Apache-2.0
+Source0: %{name}-%{version}.tar.gz
+Source103: org.tizen.quickpanel.manifest
+
+%if "%{?profile}" == "wearable"
+ExcludeArch: %{arm} %ix86 x86_64
+%endif
+
+%if "%{?profile}"=="tv"
+ExcludeArch: %{arm} %ix86 x86_64
+%endif
+
+BuildRequires: pkgconfig(capi-appfw-application)
+BuildRequires: pkgconfig(capi-system-runtime-info)
+BuildRequires: pkgconfig(capi-system-info)
+BuildRequires: pkgconfig(capi-system-device)
+BuildRequires: pkgconfig(capi-location-manager)
+BuildRequires: pkgconfig(capi-network-wifi)
+BuildRequires: pkgconfig(capi-network-bluetooth)
+BuildRequires: pkgconfig(capi-network-tethering)
+BuildRequires: pkgconfig(capi-network-connection)
+BuildRequires: pkgconfig(capi-media-player)
+BuildRequires: pkgconfig(capi-media-sound-manager)
+BuildRequires: pkgconfig(capi-media-metadata-extractor)
+BuildRequires: pkgconfig(capi-system-system-settings)
+BuildRequires: pkgconfig(capi-base-utils-i18n)
+BuildRequires: pkgconfig(capi-ui-efl-util)
+BuildRequires: pkgconfig(tapi)
+BuildRequires: pkgconfig(feedback)
+BuildRequires: pkgconfig(notification)
+BuildRequires: pkgconfig(badge)
+BuildRequires: pkgconfig(vconf)
+BuildRequires: pkgconfig(edbus)
+BuildRequires: pkgconfig(evas)
+BuildRequires: pkgconfig(ecore)
+BuildRequires: pkgconfig(edje)
+BuildRequires: pkgconfig(icu-i18n)
+BuildRequires: pkgconfig(dlog)
+BuildRequires: pkgconfig(syspopup-caller)
+BuildRequires: pkgconfig(bundle)
+BuildRequires: pkgconfig(elementary)
+BuildRequires: pkgconfig(syspopup-caller)
+BuildRequires: pkgconfig(minicontrol-viewer)
+BuildRequires: pkgconfig(minicontrol-monitor)
+BuildRequires: pkgconfig(iniparser)
+BuildRequires: pkgconfig(capi-appfw-package-manager)
+BuildRequires: pkgconfig(alarm-service)
+BuildRequires: pkgconfig(ecore-wayland)
+BuildRequires: pkgconfig(voice-control-setting)
+BuildRequires: pkgconfig(tzsh-quickpanel-service)
+BuildRequires: gettext-tools
+BuildRequires: cmake
+BuildRequires: edje-tools
+Requires(post): /usr/bin/vconftool
+
+%description
+Quick Panel
+
+%prep
+%setup -q
+
+cp %SOURCE103 %{name}.manifest
+
+%build
+%if 0%{?tizen_build_binary_release_type_eng}
+export CFLAGS="$CFLAGS -DTIZEN_ENGINEER_MODE"
+export CXXFLAGS="$CXXFLAGS -DTIZEN_ENGINEER_MODE"
+export FFLAGS="$FFLAGS -DTIZEN_ENGINEER_MODE"
+%endif
+%if 0%{?sec_build_binary_debug_enable}
+export CFLAGS="$CFLAGS -DTIZEN_DEBUG_ENABLE"
+export CXXFLAGS="$CXXFLAGS -DTIZEN_DEBUG_ENABLE"
+export FFLAGS="$FFLAGS -DTIZEN_DEBUG_ENABLE"
+%endif
+
+LDFLAGS+="-Wl,--rpath=%{name}/lib -Wl,--as-needed";
+export LDFLAGS
+export WINSYS="wayland"
+export WAYLAND_SUPPORT=On
+export X11_SUPPORT=Off
+
+%cmake . -DPKGNAME=%{name} -DWINSYS=${WINSYS}
+
+make %{?jobs:-j%jobs}
+
+%install
+rm -rf %{buildroot}
+%make_install
+
+%post
+
+%files
+%manifest %{name}.manifest
+%defattr(-,root,root,-)
+%attr(755,-,-) %{_sysconfdir}/init.d/quickpanel
+%{_prefix}/apps/%{name}
+%{_prefix}/share/packages/%{name}.xml
+%{_prefix}/share/license/%{name}
diff --git a/po/CMakeLists.txt b/po/CMakeLists.txt
new file mode 100755 (executable)
index 0000000..eeee6ac
--- /dev/null
@@ -0,0 +1,25 @@
+# for i18n
+
+SET(POFILES ar.po az.po bg.po ca.po cs.po da.po de.po el_GR.po en_PH.po en.po en_US.po es_ES.po es_US.po et.po eu.po fi.po fr_CA.po fr.po ga.po gl.po hi.po hr.po hu.po hy.po is.po it_IT.po ja_JP.po ka.po 
+kk.po ko_KR.po lt.po lv.po mk.po nb.po nl.po pl.po pt_BR.po pt_PT.po ro.po ru_RU.po sk.po sl.po sr.po sv.po tr_TR.po uk.po uz.po zh_CN.po zh_HK.po zh_TW.po)
+
+SET(MSGFMT "/usr/bin/msgfmt")
+
+FOREACH(pofile ${POFILES})
+       SET(pofile ${CMAKE_CURRENT_SOURCE_DIR}/${pofile})
+       MESSAGE("PO: ${pofile}")
+       GET_FILENAME_COMPONENT(absPofile ${pofile} ABSOLUTE)
+       GET_FILENAME_COMPONENT(lang ${absPofile} NAME_WE)
+       SET(moFile ${CMAKE_CURRENT_BINARY_DIR}/${lang}.mo)
+       ADD_CUSTOM_COMMAND(
+                       OUTPUT ${moFile}
+                       COMMAND ${MSGFMT} -o ${moFile} ${absPofile}
+                       DEPENDS ${absPofile}
+       )
+       INSTALL(FILES ${moFile}
+                       DESTINATION ${LOCALEDIR}/${lang}/LC_MESSAGES RENAME ${PROJECT_NAME}.mo)
+       SET(moFiles ${moFiles} ${moFile})
+ENDFOREACH(pofile)
+
+MESSAGE(".mo files: ${moFiles}")
+ADD_CUSTOM_TARGET(po ALL DEPENDS ${moFiles})
diff --git a/po/ar.po b/po/ar.po
new file mode 100755 (executable)
index 0000000..446a52d
--- /dev/null
+++ b/po/ar.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "لا يمكن تنشيط كل من Wi-Fi وMobile AP في الوقت نفسه. هل تريد إلغاء تنشيط Mobile AP؟"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "مسح الكل"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "انقر هنا لإلغاء تفعيل الوضع الآمن."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "يتعذر بدء %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "مكالمات الطوارئ فقط"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "قيد البحث"
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "لا توجد SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "لا توجد خدمة"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "بطاقة غير صالحة."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "مكالمات طوارئ فقط."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "بالخارج"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "تم تفعيل الوضع الآمن"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "الإشعارات (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "مسح الكل"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "إشعار"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "السؤال دائماً"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "اهتزاز"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "توفير فائق\nللطاقة"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "تقييد"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "الصوت"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "صوت"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "الوضع الخاص"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "توفير\nالطاقة"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "كتم"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "بيانات\nالهاتف"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "الموقع"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "وضع\nالطيران"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "البلوتوث"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "تدوير تلقائي"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "الضوء\nالمساعد"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "م"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "إشعارات"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "ص"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "يتعذر إجراء المكالمات الصوتية ومكالمات الفيديو وإرسال الرسائل النصية باستخدام %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "حدد بطاقة SIM للمكالمات الصوتية ومكالمات الفيديو والرسائل النصية الصادرة."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "سيتم إجراء مكالمات صوتية ومكالمات فيديو ورسائل نصية صادرة باستخدام بطاقة SIM‏ %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "موافق"
+
+msgid "IDS_ST_SK_NO"
+msgstr "لا"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "لايمكن زيادة الاضاءة بسبب زيادة حرارة الهاتف."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "ما من خدمة"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "مكالمات الطوارئ فقط"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "في الخارج"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "تقييد\n‏Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "الكشاف"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "توفير\nالطاقة"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "بيانات\nالهاتف المحمول"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "وضع\nالطيران"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "البلوتوث"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "التدوير\nالتلقائي"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "بطاقة SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "بطاقة SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "جارٍ المسح بحثاً عن شبكة هاتف محمول..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "قم بإدخال البطاقة للنفاذ إلى خدمات الشبكة."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "السؤال دائما"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "يتعذر الاتصال بشبكات المحمول عندما يكون وضع الطيران مُفعّلًا. اتصل بشبكة Wi-Fi بدلاً من ذلك، أو قم بإلغاء تفعيل وضع الطيران وحاول مرة أخرى."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "البحث"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "يتعذر فتح %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "وضع الخارج"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "الوضع\nالخاص"
+
diff --git a/po/az.po b/po/az.po
new file mode 100755 (executable)
index 0000000..930ed38
--- /dev/null
+++ b/po/az.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Wi-Fi və Mobile AP eyni zamanda aktivləşdirilə bilməz. Mobile AP qeyri-aktiv edilsin?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Hamısını sil"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Təhl rej q-akt et ü bur vur."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "%s-ə başlamaq mümkün deyildir."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Yalnız fövqəladə zənglər"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Axtarır..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "SIM yoxdur"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Servis yoxdur"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Yanlış SIM kart."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Yalnız fövqəladə zənglər üçün."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Açq hava"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Təhlük rej akt edil"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Bildirişlər (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Hamını sil"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Bildiriş"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Həmişə soruş"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Titrəyiş"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "U. enerj\nqənaət"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Bağlanma"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Səs"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Səs"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Şəxsi rejim"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Enerji\nqrnmsı"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Səssiz"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mobil\nməlumatlr"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Yer"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Uçuş\nrejimi"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Avto-fırlat"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Köməkçi\nişıq"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Bildirişlər"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "%s ilə səsli zənglər, video zənglər etmək və mətn mesajları göndərmək olmadı."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Gedən səsli zənglər, video zənglər və mətni mesajlar üçün SIM kart seçin."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Gedən səs zəngləri, video zənglər və mətn mesajları %s SIM kartı ilə ediləcək."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Xeyr"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Telefon qızdığından parlaqlığı daha da artırmaq mümkün deyil."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Xidmət yoxdur"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Yalnız fövqəladə zənglər"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Açıq havada"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\nbağlantı"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Fənər"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Enerjiyə\nqənaət"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobil\nməlumat"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Uçuş\nrejimi"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Avto\nfırlat"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Mobil şəbəkə axtarılır..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Şəbəkə xidmətlərinə daxil olmaq üçün SİM kartı daxil edin."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Həmişə soruş"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Uçuş rejimi aktiv olduqda mobil şəbəkələrə qoşulmaq mümkün deyil. Əvəzinə Wi-Fi şəbəkəsinə qoşulun və ya Uçuş rejimini qeyri-aktiv edin və yenidən cəhd edin."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Axtarılır"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "%s açmaq mümkün deyil."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Açq hava"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Şəxsi\nrejim"
+
diff --git a/po/bg.po b/po/bg.po
new file mode 100755 (executable)
index 0000000..1750c86
--- /dev/null
+++ b/po/bg.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Wi-Fi и Mobile AP не могат да бъдат активирани едновременно.. Деактивиране на Mobile AP?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Изтр. всч"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Чукн. тук за деакт. Безоп. реж."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Не може да се стартира %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Само спешни повиквания"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Търсене..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Няма SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Няма услуга"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Невалидна SIM карта."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Само спешни повиквания."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Навън"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Безоп. режим е активиран"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Уведомления (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Изч.всички"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Уведом."
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Питай винаги"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Вибрация"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Ултра\nпест. ен."
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Привързване"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Звук"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Звук"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Личен режим"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Пест. на\nенерг."
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Спиране на звука"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Мобилни\nданни"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Място"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Режим\nполет"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Автомат. завъртане"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Помощна\nсветл."
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Уведомления"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Не може да се извършват гласови повиквания, видеоповиквания и да се изпращат текстови съобщения чрез %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Изберете SIM карта за изходящи гласови повиквания, видеоповиквания и текстови съобщения."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Изходящи гласови повиквания, видеоповиквания и текстови съобщения ще се извършват чрез SIM карта %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Не"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Яркостта не може да се увеличи повече поради прегряване на телефона."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Няма услуга"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Само спешни повиквания"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "На открито"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\nтетъринг"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Фенерче"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Пестене\nенергия"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Мобилни\nданни"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Режим\nполет"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Авто\nвъртене"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Сканиране за мобилна мрежа..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Поставете SIM картата, за да получите достъп до услуги на мрежата."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Винаги питай"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Не може да се свърже към мобилни мрежи, когато е активиран режим Полет. Вместо това се свържете към Wi-Fi мрежа или деактивирайте режим Полет и опитайте отново."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Търсене"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Не може да се отвори %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "На откр."
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Личен\nрежим"
+
diff --git a/po/ca.po b/po/ca.po
new file mode 100755 (executable)
index 0000000..7fec3e5
--- /dev/null
+++ b/po/ca.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "No es poden activar els punt d'accés Wi-Fi i mòbil al mateix temps. Desactivar al punt d'accés mòbil?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Esbor tot"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Toqui per sortir de mode Segur."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "No es pot iniciar %s"
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Només trucades emergència"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Cercant..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Sense SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Sense servei"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Targeta SIM no vàlida"
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Només trucades d'emergència"
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Exterior"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Mode Segur activat"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Notificacions (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Esbor tot"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Notificac"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Preguntar sempre"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibrar"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Estalvi\nultra"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Ancoratge a xarxa"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "So"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "So"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Mode Privat"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Estalvi\nenergia"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Silenci"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Dades\nmòbils"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Ubicació"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Mode\nVol"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Rotació auto"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Llum \nassist"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Notificacions"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "No es poden fer trucades de veu ni videotrucades, ni enviar missatges de text amb %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Seleccioni una targeta SIM per a trucades de veu de sortida, videotrucades i missatges de text."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Les trucades de veu de sortida, les videotrucades i els missatges de text es realitzaran amb la targeta SIM %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "Acceptar"
+
+msgid "IDS_ST_SK_NO"
+msgstr "No"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "No es pot incrementar més la brillantor a causa d'un sobreescalfament del telèfon"
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Sense servei"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Només trucades d'emergència"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "A l'aire lliure"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Ancorat\nWi-Fi"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Llan-\nterna"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Estalvi\nenergia"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Dades\nmòbils"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Mode\nVol"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Rotació\nauto"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Cercant xarxa mòbil..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Insereixi la targeta SIM per a accedir als serveis de xarxa"
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Preguntar sempre"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "No es pot connectar a xarxes mòbils mentre el mode Vol està habilitat. Connecti's a una xarxa Wi-Fi en el seu lloc, o deshabiliti el mode Vol i torni-ho a intentar."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "S'està cercant"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "No es pot obrir %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Exterior"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Mode\nPrivat"
+
diff --git a/po/cs.po b/po/cs.po
new file mode 100755 (executable)
index 0000000..c78d34b
--- /dev/null
+++ b/po/cs.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Wi-Fi a mobilní přístupový bod nelze aktivovat současně. Chcete deaktivovat mobilní přístupový bod?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Smazat vše"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Klepnutím vypnete Bezp. režim."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Nelze spustit %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Pouze tísňová volání"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Hledání..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Žádná SIM karta"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Žádné služby"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Chybná SIM karta."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Pouze tísňová volání."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Venku"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Bezpečný režim zapnut"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Oznámení (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Smazat vše"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Oznámení"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Vždy se dotázat"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibrace"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Ultra ús.\nrežim"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Sdílení připojení"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Zvuk"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Zvuk"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Soukromý režim"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Úsporný\nrežim"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Ztlumit"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mobilní\ndata"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Umístění"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Režim\nLetadlo"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Automat. otočení"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Pomocné\nosvětl."
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "od"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Oznámení"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "do"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Pomocí %s nelze uskutečňovat hlasové hovory, videohovory a odesílat textové zprávy."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Vyberte SIM kartu pro odchozí hlasové hovory, videohovory a textové zprávy."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Odchozí hlasové hovory, videohovory a textové zprávy budou uskutečňovány pomocí SIM karty %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Ne"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Nelze více zvýšit jas z důvodu přehřívání telefonu."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Žádné služby"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Pouze tísňová volání"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Venku"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Sd. př.\nWi-Fi"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Baterka"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Úsporný\nrežim"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobilní\ndata"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Režim\nLetadlo"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Autom.\notočení"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Hledání mobilní sítě..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Chcete-li používat síťové služby, vložte SIM kartu."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Vždy se dotázat"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "V režimu Letadlo není možné se připojit k mobilním sítím. Připojte se pomocí sítě Wi-Fi, nebo vypněte režim Letadlo a opakujte akci."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Vyhledávání"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "%s nelze spustit."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Venku"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Soukromý\nrežim"
+
diff --git a/po/da.po b/po/da.po
new file mode 100755 (executable)
index 0000000..775d307
--- /dev/null
+++ b/po/da.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Både Wi-Fi og mobilt adgangspunkt kan ikke være aktiveret på samme tid. Deaktivér mobilt adgangspunkt?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Slet alle"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Tryk for at deakt. sik. tilst."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Kunne ikke starte %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Kun nødopkald"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Søger ..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Intet SIM-kort"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Ingen dækning"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Ugyldigt SIM-kort."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Kun nødopkald."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Udendørs"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Sikker tilstand aktiveret"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Meddelelser (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Ryd alle"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Besked"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Spørg altid"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibrer"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "U.strøm\nbespar."
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Internetdeling"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Lyd"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Lyd"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Privat tilstand"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Strøm-\nbespar."
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Lydløs"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mobile\ndata"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Placer."
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Fly-\ntilstand"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Roter automatisk"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Hjælpe-\nlys"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Meddelelser"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Kan ikke foretage stemmeopkald, videoopkald og sende sms-beskeder med %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Vælg et SIM-kort til udgående stemmeopkald, videoopkald og sms-beskeder."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Udgående stemmeopkald, videoopkald og sms-beskeder vil blive foretaget med %s-SIM-kortet."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Nej"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Det er ikke muligt at øge lysstyrken yderligere, fordi telefonen kan overophedes."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Ingen dækning"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Kun nødopkald"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Udendørs"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi-\ndeling"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Lommelygte"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Strøm-\nbespar."
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobile\ndata"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Fly-\ntilstand"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Auto-\nroter"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Søger efter mobilt netværk ..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Indsæt SIM-kortet for at få adgang til netværkstjenesterne."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Spørg altid"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Kan ikke oprette forbindelse til mobile netværk, da Flytilstand er aktiveret. Opret forbindelse til et Wi-Fi-netværk i stedet, eller deaktiver Flytilstand, og prøv igen."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Søger"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Kunne ikke åbne: %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Udendørs"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Privat\ntilstand"
+
diff --git a/po/de.po b/po/de.po
new file mode 100644 (file)
index 0000000..49174fe
--- /dev/null
+++ b/po/de.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "WLAN und Mobile AP können nicht zur gleichen Zeit aktiviert werden. Mobile AP deaktivieren?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Alle löschen"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Tipp., um sich. Mod. zu deakt."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "%s kann nicht gestartet werden"
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Nur Notrufe"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Suche läuft..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Keine SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Kein Netz"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Ungültige SIM-Karte"
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Nur Notrufe möglich"
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Outdoor"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Sicherer Modus aktiviert."
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Benachrichtig. (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Löschen"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Benachr."
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Immer fragen"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "WLAN"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibrieren"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Ultra-\nsparen"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Tethering"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Ton"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Ton"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Privater Modus"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Energie\nsparen"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Stumm"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mobile\nDaten"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "GPS"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Offline-\nModus"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Auto-Rotation"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Assistenz-\nlicht"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Benachricht."
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Mit %s sind keine Sprachanrufe, Videoanrufe und Textnachrichten möglich."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Wählen Sie eine SIM-Karte für ausgehende Sprachanrufe, Videoanrufe und Textnachrichten aus."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Für ausgehende Sprachanrufe, Videoanrufe und Textnachrichten wird die SIM-Karte „%s“ verwendet."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Nein"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Helligkeit kann wegen Überhitzen des Geräts nicht weiter angehoben werden"
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Kein Netz"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Nur Notrufe"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Im Freien"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "WLAN-\nTethering"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "WLAN"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Taschen-\nlampe"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Energie-\nsparen"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobile\nDaten"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Offline-\nModus"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Auto-\nRotation"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Mobile Netze werden gesucht..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "SIM-Karte einsetzen, um auf Netzdienste zuzugreifen"
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Immer fragen"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Bei aktiviertem Offline-Modus kann keine Verbindung mit mobilen Netzwerken hergestellt werden. Stellen Sie stattdessen eine WLAN-Verbindung her oder deaktivieren Sie den Offline-Modus und versuchen Sie es erneut."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Suche"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "%s kann nicht geöffnet werden."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Im Freien"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Privater\nModus"
+
diff --git a/po/el_GR.po b/po/el_GR.po
new file mode 100755 (executable)
index 0000000..e140e7f
--- /dev/null
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Τόσο το Wi-Fi όσο και το AP για κινητά δεν μπορούν να ενεργοποιηθούν ταυτόχρονα. Απενεργοποίηση AP για κινητά;"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Διαγραφή όλων"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Πατ. εδώ για απεν. ασφαλ. λειτ."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Αδύνατη η εκκίνηση του %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Μόνο κλήσεις έκτ. ανάγκης"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Αναζήτηση..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Δεν βρέθηκε SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Μη διαθέσιμη υπηρεσία"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Μη έγκυρη κάρτα SIM."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Μόνο επείγουσες κλήσεις."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Υπαίθρια"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Ασφ. λειτουργία ενεργή"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Ειδοποιήσεις (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Διαγ. όλων"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Ειδοποίηση"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Ερώτηση πάντα"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Δόνηση"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Εξ.ενέργ.\nUltra"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Tethering"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Ήχος"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Ήχος"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Απόρρητη λειτ."
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Εξοικ.\nενέργ."
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Σίγαση"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Δεδομ.\nκινητού"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Τοποθεσία"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Λειτ.\nπτήσης"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Αυτόματη περιστροφή"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Βοηθητ.\nφως"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "ΜΜ"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Ειδοποιήσεις"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "ΠΜ"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Δεν είναι δυνατή η πραγματοποίηση φωνητικών κλήσεων, κλήσεων βίντεο και η αποστολή μηνυμάτων κειμένου χρησιμοποιώντας το %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Επιλέξτε μια κάρτα SIM για εξερχόμενες φωνητικές κλήσεις, κλήσεις βίντεο και μηνυμάτων κειμένου."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Οι εξερχόμενες φωνητικές κλήσεις, κλήσεις βίντεο και τα μηνύματα κειμένου θα πραγματοποιούνται με την κάρτα SIM %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Όχι"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Αδυναμία περαιτέρω αύξησης της φωτεινότητας λόγω υπερθέρμανσης της συσκευής."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Εκτός δικτύου"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Μόνο κλήσεις έκτακτης ανάγκης"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Εξωτερικοί χώροι"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\ntethering"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Φακός"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Εξοικ.\nενέργ."
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Δεδομ.\nκιν.τηλ."
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Λειτουρ.\nπτήσης"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Αυτόμ.\nπεριστρ."
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Σάρωση για δίκτυα κινητής τηλεφωνίας..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Εισάγετε την κάρτα SIM για παροχή πρόσβασης στις υπηρεσίες δικτύου."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Ερώτηση πάντα"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Δεν είναι δυνατή η σύνδεση σε δίκτυα κινητής τηλεφωνίας όσο είναι ενεργοποιημένη η λειτουργία πτήσης. Συνδεθείτε σε ένα δίκτυο Wi-Fi ή απενεργοποιήστε τη λειτουργία πτήσης και δοκιμάστε ξανά."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Αναζήτηση"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Δεν είναι δυνατό το άνοιγμα του %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Υπαίθρια"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Απόρρητη\nλειτ."
+
diff --git a/po/en.po b/po/en.po
new file mode 100755 (executable)
index 0000000..3ee2739
--- /dev/null
+++ b/po/en.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Both Wi-Fi and mobile AP cannot be activated at the same time. Deactivate mobile AP?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Clear all"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Tap here to disable Safe mode."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Unable to launch %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Emergency calls only"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Searching..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "No SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "No service"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Invalid SIM card."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Emergency calls only."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Outdoors"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Safe mode enabled"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Notifications (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Clear all"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Notification"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Always ask"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibrate"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "U. power\nsaving"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Tethering"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Sound"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Sound"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Private mode"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Power\nsaving"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Mute"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mobile\ndata"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Location"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Flight\nmode"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Auto rotate"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Assistive\nlight"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Notifications"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Unable to make voice calls, video calls, and send text messages using %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Select SIM card for outgoing voice calls, video calls, and text messages."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Outgoing voice calls, video calls, and text messages will be made using the %s SIM card."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "No"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Unable to increase brightness further because of phone overheating."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "No service"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Emergency calls only"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Outdoor"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\ntethering"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Torch"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Power\nsaving"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobile\ndata"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Flight\nmode"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Auto\nrotate"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Scanning for mobile network..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Insert SIM card to access network services."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Always ask"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Unable to connect to mobile networks while Flight mode is enabled. Connect to a Wi-Fi network instead, or disable Flight mode and try again."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Searching"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Unable to open %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Outdoors"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Private\nmode"
+
diff --git a/po/en_PH.po b/po/en_PH.po
new file mode 100755 (executable)
index 0000000..4591e56
--- /dev/null
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Both Wi-Fi and Mobile AP cannot be activated at the same time. Deactivate Mobile AP?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Clear all"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Tap here to disable Safe mode."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Unable to launch %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Emergency calls only"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Searching..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "No SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "No service"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Invalid SIM card."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Emergency calls only."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Outdoors"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Safe mode enabled"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Notifications (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Clear all"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Notification"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Always ask"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibrate"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "U. power\nsaving"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Tethering"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Sound"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Sound"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Private mode"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Power\nsaving"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Mute"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mobile\ndata"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Location"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Flight\nmode"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Auto rotate"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Assistive\nlight"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Notifications"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Unable to make voice calls, video calls and send text messages using %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Select SIM card for outgoing voice calls, video calls and text messages."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Outgoing voice calls, video calls and text messages will be made using the %s SIM card."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "No"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Unable to increase brightness further because of phone overheating."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "No service"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Emergency calls only"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Outdoor"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\ntethering"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Torch"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Power\nsaving"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobile\ndata"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Flight\nmode"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Auto\nrotate"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Scanning for mobile network..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Insert SIM card to access network services."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Always ask"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Unable to connect to mobile networks while Flight mode is enabled. Connect to a Wi-Fi network instead, or disable Flight mode and try again."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Searching"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Unable to open %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Outdoors"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Private\nmode"
+
diff --git a/po/en_US.po b/po/en_US.po
new file mode 100755 (executable)
index 0000000..6a892f3
--- /dev/null
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Both Wi-Fi and Mobile AP cannot be activated at the same time. Deactivate Mobile AP?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Clear all"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Tap here to disable Safe mode."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Unable to launch %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Emergency calls only"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Searching..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "No SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "No service"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Invalid SIM card."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Emergency calls only"
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Outdoors"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Safe mode enabled"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Notifications (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Clear all"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Notification"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Always ask"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibrate"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "U. power\nsaving"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Tethering"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Sound"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Sound"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Private mode"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Power\nsaving"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Mute"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mobile\ndata"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Location"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Airplane\nmode"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Auto rotate"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Assistive\nlight"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Notifications"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Unable to make voice and video calls or send text messages using %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Select SIM card for outgoing voice calls, video calls, and text messages."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Outgoing voice calls, video calls, and text messages will be made using the %s SIM card."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "No"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Unable to increase brightness further because of phone overheating."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "No service"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Emergency calls only"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Outdoor"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\ntethering"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Flashlight"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Power\nsaving"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobile\ndata"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Airplane\nmode"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Auto\nrotate"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Scanning for mobile network..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Insert SIM card to access network services."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Always ask"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Unable to connect to mobile networks while Airplane mode is on. Connect to a Wi-Fi network instead, or turn off Airplane mode, and try again."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Searching"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Unable to open %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Outdoors"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Private\nmode"
+
diff --git a/po/es_ES.po b/po/es_ES.po
new file mode 100755 (executable)
index 0000000..a8b43be
--- /dev/null
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Las conexiones Wi-Fi y Mobile AP no se pueden activar al mismo tiempo. ¿Desactivar Mobile AP?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Borrar todo"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Pulse para desact modo seguro."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "No se puede iniciar %s"
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Solo llamadas emergencia"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Buscando..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "No hay SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Sin servicio"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Tarjeta SIM no válida"
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Sólo llamadas de emergencia"
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Exterior"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Modo seguro activado"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Notificaciones (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Elim todo"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Notificac"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Preg siempre"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibrar"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Ultra\nahorro"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Anclaje a red"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Sonido"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Sonido"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Modo Privado"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Ahorro\nenergía"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Silencio"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Datos\nmóviles"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Ubicación"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Modo\navión"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Rotación automática"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Luz de\nasisten"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Notificación"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "No se pueden hacer llamadas de voz, videollamadas ni enviar mensajes de texto con %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Seleccione una tarjeta SIM para las llamadas de voz, las videollamadas y los mensajes de texto salientes."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Las llamadas de voz salientes, las videollamadas y los mensajes de texto se realizarán con la tarjeta SIM %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "Aceptar"
+
+msgid "IDS_ST_SK_NO"
+msgstr "No"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "No se puede incrementar más el brillo debido a un sobrecalentamiento del teléfono"
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Sin servicio"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Solo llamadas de emergencia"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Exterior"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Anclaje\na Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Linterna"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Ahorro\nenergía"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Datos\nmóviles"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Modo\nAvión"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Giro\nauto"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Buscando red móvil..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Inserte la tarjeta SIM para acceder a los servicios de red."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Preguntar siempre"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "No es posible conectar a las redes móviles mientras el modo Avión esté activado. Conéctese a una red Wi-Fi o desactive el modo Avión e inténtelo de nuevo."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Buscando"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "No se puede abrir %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Exterior"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Modo\nPrivado"
+
diff --git a/po/es_US.po b/po/es_US.po
new file mode 100644 (file)
index 0000000..732597f
--- /dev/null
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Las conexiones Wi-Fi y Mobile AP no se pueden activar al mismo tiempo. ¿Desactivar Mobile AP?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Eliminar todo"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Pulse para desact modo seguro."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "No es posible iniciar %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Llamadas de emergencia"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Buscando..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "No hay tarjeta SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Sin servicio"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Tarjeta SIM no válida."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Sólo llamadas de emergencia."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Exterior"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Modo seguro activado"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Notificaciones (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Elim. todo"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Notific."
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Pregunt. siempre"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibrar"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Ultra a.\nenergía"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Anclaje a red"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Sonido"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Sonido"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Modo privado"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Ahorro de\nenergía"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Silencio"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Móvil\ny datos"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Ubica-\nción"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Fuera de\n línea"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Girar automátic."
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Luz de\nasisten."
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Notific."
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "No es posible realizar llamadas de voz y videollamadas, y enviar mensajes de texto usando %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Seleccione una tarjeta SIM para las llamadas de voz, las videollamadas y los mensajes de texto salientes."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Las llamadas de voz, las videollamadas y los mensajes de texto salientes utilizarán la tarjeta SIM %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "Aceptar"
+
+msgid "IDS_ST_SK_NO"
+msgstr "No"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "No se puede aumentar más el brillo para evitar sobrecalentamiento del dispositivo."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Sin servicio"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Solo llamadas de emergencia"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Exterior"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\nanc. red"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Linterna"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Ahorro\nenergía"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Datos\nmóviles"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Fuera de\nlínea"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Giro\nautom."
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "Tarjeta SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "Tarjeta SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Buscando redes móviles..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Inserte tarjeta SIM para acceder a los servicios de red"
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Preguntar siempre"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "No es posible conectar a las redes móviles mientras que el perfil Fuera de línea está activo. Conéctese a una red Wi-Fi en su lugar o desactive el perfil Fuera de línea e inténtelo de nuevo."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Buscando"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "No se puede abrir %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Exterior"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Modo\nPrivado"
+
diff --git a/po/et.po b/po/et.po
new file mode 100755 (executable)
index 0000000..79ac33a
--- /dev/null
+++ b/po/et.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Wi-Fit ja Mobile AP-d ei saa aktiveerida samaaegselt. Kas desaktiveerida Mobile AP?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Tühjenda kõik"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Tok. siia, et desak. turv. rež."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Üksust %s ei saa käivitada."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Ainult hädaabikõned"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Otsimine..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "SIM-i pole"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Teenus puudub"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Vigane SIM-kaart."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Ainult hädaabikõned."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Väljas"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Turv. režiim aktiveeritud"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Teavitused (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Kust. kõik"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Teavitus"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Küsi alati"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Värin"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Ülim\nen.sääst"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Modem"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Heli"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Heli"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Priv.-\nrežiim"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Energia-\nsääst"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Vaigista"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mobiiliandmes."
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Asukoht"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Lennu-\nrežiim"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Automaatne pööramine"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Abi-\nvalgus"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PL"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Teavitused"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "EL"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Hääl- ja videokõnesid ei saa teha ning tekstsõnumeid ei saa saata üksusega %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Valige väljuvate hääl- ja videokõnede ning tekstsõnumite jaoks SIM-kaart."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Väljuvate häälkõnede ja videokõnede ning tekstsõnumite korral kasutatakse SIM-kaarti %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Ei"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Ei ole võimalik heledust suurendada telefoni ülekuumenemise tõttu."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Teenus puudub"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Ainult hädaabikõned"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Välitingimused"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\nmodem"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Tasku-\nlamp"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Energia\nsäästm."
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobiili\nandmed"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Lennu-\nrežiim"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Autom.\npööram."
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Mobiilsidevõrgu otsimine..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Sisestage SIM-kaart, et paaseda ligi vorguteenustele."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Küsi alati"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Mobiilsidevõrkudega ei saa ühendust luua, kui lennurežiim on aktiveeritud. Looge ühendus hoopis Wi-Fi võrguga või desaktiveerige lennurežiim ja proovige uuesti."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Otsimine"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Rakendust %s ei saa avada."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Väljas"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Priv.-\nrežiim"
+
diff --git a/po/eu.po b/po/eu.po
new file mode 100755 (executable)
index 0000000..ff4e8c1
--- /dev/null
+++ b/po/eu.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Wi-Fi eta Mobile AP ezin dira aldi berean aktibatu. Desaktibatu Mobile AP?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Garbitu guztiak"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Uk. hemen Seg. mod. ezgaitzeko."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Ezin da %s abiatu"
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Larrialdi deiak soilik"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Bilatzen"
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Ez dago SIM txartelik"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Zerbitzurik gabe"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "SIM txartel baliogabea"
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Larrialdi deiak bakarrik"
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Kanpoan"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Segurua modua gaituta"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Jakinarazpenak (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Garb. dena"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Jakinaraz."
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Galdetu beti"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Bibratu"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Bat.aurr.\nultram."
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Ainguraketa"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Soinua"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Soinua"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Modu pribatua"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Bateria\naurrez."
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Mututu"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Datu\nmugik."
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Kokapena"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Hegaldia\nmodua"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Biratu automatikoki"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Laguntza\nargia"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Jakinarazpenak"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Ezin dira ahots deiak eta bideo deiak egin eta testu mezuak bidali %s erabiliz."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Hautatu irteera ahots deietarako, bideo deietarako eta testu mezuetarako SIM txartela."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Irteera ahots deiak, bideo deiak eta testu mezuak %s SIM txartela erabiliz egingo dira."
+
+msgid "IDS_ST_SK_OK"
+msgstr "Ados"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Ez"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Ezin da argitasuna areagotu, telefonoa gehiegi berotuko baita"
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Ez dago zerbitzurik"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Larrialdi deiak soilik"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Kanpoan"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\naingur."
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Linterna"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Bateria\naurrez."
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Datu\nmugik."
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Hegaldi\nmodua"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Biratu\nautom."
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Sare mugikorrak bilatzen..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Sartu SIM txartela sare zerbitzuetan sartzeko."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Galdetu beti"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Ezin da sare mugikorretara konektatu Hegaldi modua gaituta badago. Konektatu Wi-Fi sarera bestela, edo ezgaitu Hegaldi modua eta saiatu berriz."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Bilatzen"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Ezin da %s ireki."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Kanpoan"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Modu\npribatua"
+
diff --git a/po/fi.po b/po/fi.po
new file mode 100755 (executable)
index 0000000..750f276
--- /dev/null
+++ b/po/fi.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Wi-Fiä ja mobiilitukiasemaa ei voi ottaa käyttöön samaan aikaan. Haluatko poistaa mobiilitukiaseman käytöstä?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Tyhj. kaikki"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Poista turvallisuustila k. tällä."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Sovellusta %s ei voi käynnistää."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Vain hätäpuhelut"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Etsitään..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Ei SIM-korttia"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Ei palvelua"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Virheellinen SIM-kortti"
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Vain hätäpuhelut"
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Ulkona"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Turvallisuustila käytössä"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Ilmoitukset (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Poista kaikki"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Ilmoitus"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Kysy aina"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Värinä"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Er. teh.\nvirrans."
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Yhteys"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Ääni"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Ääni"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Yksit. tila"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Virran-\nsäästö"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Mykistä"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mobiilidata"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Sijainti"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Lento-\ntila"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Automaattinen kierto"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Apuvalo"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "IP"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Ilmoitukset"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AP"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Äänipuheluita ja videopuheluita ei voi soittaa eikä tekstiviestejä voi lähettää kortilta %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Valitse SIM-kortti lähteviä äänipuheluita, videopuheluita ja tekstiviestejä varten."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Lähteviin äänipuheluihin, videopuheluihin ja tekstiviesteihin käytetään SIM-korttia %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Ei"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Kirkkautta ei voi lisätä puhelimen ylikuumenemisen vuoksi."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Ei palvelua"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Vain hätäpuhelut"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Ulkotila"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Jaettu\nWi-Fi"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Tasku-\nlamppu"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Virran-\nsäästö"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobiili-\ndata"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Lento-\ntila"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Autom.\nkierto"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Haetaan matkapuhelinverkkoa..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Pääset verkkopalveluihin asettamalla SIM-kortin paikalleen."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Kysy aina"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Matkapuhelinverkkoihin ei voi yhdistää, kun lentotila on käytössä. Muodosta sen sijaan yhteys Wi-Fi-verkon kautta tai poista lentotila käytöstä ja yritä uudelleen."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Haetaan"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Sovellusta %s ei voi avata."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Ulkona"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Yksit.\ntila"
+
diff --git a/po/fr.po b/po/fr.po
new file mode 100644 (file)
index 0000000..264a14a
--- /dev/null
+++ b/po/fr.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Activation simultanée du Wi-Fi et du point d'accès mobile impossible. Désactiver le point d'accès mobile ?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Effacer tout"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "App. pr désact. mode Sécurisé."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Impossible de lancer %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Appels urgence uniquement"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Recherche..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Pas de carte SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Aucun service"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Carte SIM non valide"
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Appels d'urgence uniquement"
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Extér."
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Mode Sécurisé activé"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Notifications (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Eff. tout"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Notific."
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Tjrs demander"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibreur"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Ultra éco\nénergie"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Modem"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Son"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Son"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Mode Privé"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Éco.\nénergie"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Muet"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Données\nmobiles"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Position"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Mode\nHors-ligne"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Rotation auto"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Lampe\nde poche"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Notifications"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Impossible d'effectuer des appels vocaux ou visio, ni d'envoyer des SMS via %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Sélectionnez la carte SIM pour les appels vocaux et visio sortants, ainsi que les SMS."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Les appels vocaux et visio, ainsi que les SMS sortants seront effectués avec la carte SIM %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Non"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Impossible d'augmenter la luminosité en raison d'une surchauffe de l'appareil."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Aucun service"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Appels d'urgence uniquement"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Extérieur"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Modem\nWi-Fi"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Lampe"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Économ.\nénergie"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Données\nmobiles"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Mode\nHs ligne"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Rotation\nauto"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Recherche de réseau mobile..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Insérez une carte SIM pour accéder aux services réseau."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Toujours demander"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Impossible de se connecter aux réseaux mobiles lorsque le mode Hors-ligne est activé. Connectez-vous plutôt à un réseau Wi-Fi ou désactivez le mode Hors-ligne, puis réessayez."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Recherche"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Impossible d'ouvrir %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Extér."
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Mode\nPrivé"
+
diff --git a/po/fr_CA.po b/po/fr_CA.po
new file mode 100755 (executable)
index 0000000..779955f
--- /dev/null
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Activation simultanée de wifi et du point d'accès mobile impossible. Désactiver le point d'accès mobile ?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Effacer tout"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "App. pr désact. mode Sécurisé."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Impossible de lancer %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Appels urgence uniquement"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Recherche..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Pas de carte SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Aucun service"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Carte SIM non valide."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Appels d'urgence uniquement."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Extér."
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Mode Sécurisé activé"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Notifications (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Eff. tout"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Notific."
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Tjrs demander"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wifi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibreur"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Ultra éco\nénergie"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Modem"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Son"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Son"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Mode Privé"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Écon.\nd'énergie"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Muet"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Données\nmobiles"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Position"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Mode\nHors-ligne"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Rotation auto"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Lampe\nde poche"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Notifications"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Impossible d'effectuer des appels vocaux ou vidéos ni d'envoyer des SMS via %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Sélectionnez la carte SIM pour les appels vocaux et vidéos sortants, ainsi que les SMS."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Les appels vocaux et visio, ainsi que les SMS sortants seront effectués avec la carte SIM %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Non"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Impossible d'augmenter la luminosité en raison d'une surchauffe de l'appareil."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Aucun service"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Appels d'urgence uniquement"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Extérieur"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Modem\nWifi"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wifi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Lampe"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Écon.\nd'énergie"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Données\nmobiles"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Mode\nHors-ligne"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Rotation\nauto"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Recherche de réseau mobile..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Insérez une carte SIM pour accéder aux services réseau."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Toujours demander"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Impossible de se connecter aux réseaux mobiles lorsque le mode Hors-ligne est activé. Connectez-vous plutôt à un réseau Wifi ou désactivez le mode Hors-ligne, puis réessayez."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Recherche"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Impossible d'ouvrir %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Extér."
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Mode\nPrivé"
+
diff --git a/po/ga.po b/po/ga.po
new file mode 100755 (executable)
index 0000000..4fe6e07
--- /dev/null
+++ b/po/ga.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Ní féidir Wi-Fi agus AP Móibíleach a chur i ngníomh ag an am céanna. Díghníomhachtaigh AP Móibíleach?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Glan gach"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Tap. anseo le Mód Sábh. a dhíchumasú"
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Ní féidir %s a lainseáil."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Glaonna éigeandála amháin"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Ag cuardach..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Níl SIM ann"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Níl seirbhís ann"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Cárta SIM neamhbhailí."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Glaonna éigeandála amháin."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Lasmuigh"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Mód sábháilte cumasaithe"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Fógraí (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Glan gach"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Fógra"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Iarr i gcónaí"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Crith"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "U.coigilt\ncumhachta"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Nascaireacht"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Fuaim"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Fuaim"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Mód príobh."
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Coigilt\nchumh."
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Balbhaigh"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Sonraí\nmóibíl."
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Suíomh"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Mód\neitilte"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Uathrothlaigh"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Solas\ncúnta"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "IN"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Fógraí"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "RN"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Ní féidir glaonna gutha ná glaonna físe a chur ná teachtaireachtaí téacs a sheoladh le %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Roghnaigh cárta SIM le haghaidh glaonna gutha, glaonna físe agus teachtaireachtaí téacs amach."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Cuirfear glaonna gutha agus físe amach agus seolfar teachtaireachtaí amach le cárta SIM %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Ná déan é"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Ní féidir gile a mhéadú tuilleadh de bharr róthéimh."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Níl seirbhís ann"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Glaonna éigeandála amháin"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Lasmuigh"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Nascair.\nWi-Fi"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Tóirse"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Coigilt\nchumh."
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Sonraí\nmóibíl."
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Mód\neitilte"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Uath\nrothlú"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Scanadh le haghaidh líonra móibíleach..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Ionsáigh cárta SIM le seirbhísí líonra a rochtain"
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Fiafraigh i gcónaí"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Ní féidir nascadh le líonraí móibíleacha fad is atá Mód eitilte cumasaithe. Nasc le líonra Wi-Fi ina ionad, nó díchumasaigh an Mód eitilte agus triail arís é."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Ag cuardach"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Ní féidir %s a oscailt."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Amuigh"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Mód\npríobh."
+
diff --git a/po/gl.po b/po/gl.po
new file mode 100755 (executable)
index 0000000..909b852
--- /dev/null
+++ b/po/gl.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "O Wi-Fi e AP Móbil non poden activarse ao mesmo tempo. Desactivar AP Móbil?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Borrar todo"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Toca aqu.para desac.mod.Seguro."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Non se pode iniciar %s"
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Só chamadas de urxencia"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Buscando..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Non hai SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Sen servizo"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Tarxeta SIM non válida"
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Só chamadas de urxencia"
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Exterior"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Modo Seguro activado"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Notificacións (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Borr. todo"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Notific."
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Preguntar sempre"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibrar"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Aforro\nenerx. u."
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Ancoraxe á rede"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Son"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Son"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Modo Privado"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Aforro\nenerxía"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Silen-\nciar"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Datos\nmóbiles"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Localiz."
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Modo\navión"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Rotación automática"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Luz de\nasisten."
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Notificacións"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Non se poden realizar chamadas de voz, videochamadas nin enviar mensaxes de texto con %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Selecciona a tarxeta SIM para as chamadas de voz saíntes, as videochamadas e as mensaxes de texto."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "As chamadas de voz saíntes, as videochamadas e as mensaxes de texto realizaranse coa tarxeta SIM %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "Aceptar"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Non"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Non se pode aumentar máis o brillo debido ao sobrequecemento do teléfono"
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Non hai servizo"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Só chamadas de urxencia"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Exterior"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Ancoraxe\nWi-Fi"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Lanterna"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Aforro\nenerxía"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Datos\nmóbiles"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Modo\nAvión"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Rotación\nauto."
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Buscando rede móbil..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Insira a tarxeta SIM para acceder aos servizos de rede."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Preguntar sempre"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Non se pode conectar con redes móbiles co modo Avión activado. Conéctate a unha rede Wi-Fi no seu lugar ou desactiva o modo Avión e téntao de novo."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Buscando"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Non se pode abrir %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Exterio."
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Modo\nPrivado"
+
diff --git a/po/hi.po b/po/hi.po
new file mode 100755 (executable)
index 0000000..8b35da1
--- /dev/null
+++ b/po/hi.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "एक ही समय में Wi-Fi और मोबाइल AP सक्रिय नहीं कर सकते हैं। मोबाइल AP निष्क्रिय करें?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "सभी साफ करें"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "सुरक्षित मोड अक्षम हेतु यहाँ टैप करें।"
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "%s प्रारंभ करने में अक्षम।"
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "केवल आपातकालीन कॉल्स"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "खोज रहा है..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "कोई SIM नहीं"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "कोई सेवा नहीं"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "अमान्य SIM कार्ड।"
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "केवल आपातकालीन कॉलें।"
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "बाह्य"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "सुरक्षित मोड सक्षम है"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "अधिसूचनाएँ (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "सभी साफ"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "अधिसूचना"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "हमेशा पूछें"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "कंपन"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "अल्ट्रा पॉवर\nबचत"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "टेथरिंग"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "ध्वनि"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "ध्वनि"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "निजी मोड"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "पॉवर\nबचत"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "मूक"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "मोबाइल\nडाटा"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "स्थान"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "फ्लाइट\nमोड"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "ब्लूटूथ"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "स्वत: घुमाएँ"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "सहायक\nप्रकाश"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "अधिसूचनाएँ"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "%s उपयोग करके वॉइस कॉल्स, वीडियो कॉल्स करने और टेक्स्ट सन्देश भेजने में असमर्थ।"
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "जानेवाली वॉइस कॉल्स, वीडियो कॉल्स और टेक्स्ट सन्देशों हेतु SIM कार्ड चुनें।"
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "%s SIM कार्ड का उपयोग करके जानेवाली वॉइस कॉल्स, वीडियो कॉल्स और टेक्स्ट सन्देश किए जाएँगे।"
+
+msgid "IDS_ST_SK_OK"
+msgstr "ओके"
+
+msgid "IDS_ST_SK_NO"
+msgstr "नहीं"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "उपकरण अधिक गर्म होने के कारण चमक बढ़ाने में अक्षम"
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "कोई सेवा नहीं"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "केवल आपातकालीन कॉल्स"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "बाह्य"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\nटेथरिंग"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "टॉर्च"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "पॉवर\nबचत"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "मोबाइल\nडाटा"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "फ्लाइट\nमोड"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "ब्लूटूथ"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "स्वतः\nघुमाएँ"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "मोबाइल नेटवर्क हेतु स्कैन कर रहा है..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "नेटवर्क सेवाएँ एक्सेस करने के लिए SIM कार्ड इंसर्ट करें।"
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "हमेशा पूछें"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "फ्लाइट मोड सक्षम होने के दौरान मोबाइल नेटवर्क्स से कनेक्ट करने में असमर्थ। इसके बजाय Wi-Fi नेटवर्क से कनेक्ट करें या फ्लाइट मोड अक्षम करें और फिर से प्रयास करें।"
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "खोज रहा है"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "%s खोलने में असमर्थ।"
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "बाह्य"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "निजी\nमोड"
+
diff --git a/po/hr.po b/po/hr.po
new file mode 100755 (executable)
index 0000000..e2fdb64
--- /dev/null
+++ b/po/hr.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Istodobno ne možete uključiti Wi-Fi i Mobile AP. Isključiti Mobilnu pristupnu točku?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Obriši sve"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Isključenje Sigurnog načina."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Nemoguće pokrenuti %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Samo SOS pozivi"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Pretraživanje..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Nema SIM-a"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Nema usluge"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Neispravna SIM kartica."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Samo SOS pozivi."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Vani"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Sigurni način uključen"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Obavijesti (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Izbr. sve"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Obavijest"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Uvijek pitaj"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibrac."
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Maks. št.\nbater."
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Dijeljenje veze"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Zvuk"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Zvuk"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Privatni način"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Štednja\nbaterije"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Bešumno"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mobilni\npodaci"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Lokacija"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Profil\nBez mr."
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Automatski rotiraj"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Pomoćno\nsvjetlo"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Obavijesti"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Nije moguće uspostavljati glasovne pozive, videopozive i slati tekstualne poruke pomoću %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Odaberite SIM karticu za odlazne glasovne pozive, videopozive i tekstualne poruke."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Odlazni glasovni pozivi, videopozivi i tekstualne poruke uspostavit će se pomoću %s SIM kartice."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Ne"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Nemoguće daljnje pojačavanje svjetline jer bi se telefon mogao pregrijati."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Nema usluge"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Samo hitni pozivi"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Vani"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\ndijelj."
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Svjet."
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Ušteda\nbaterije"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobilni\npodaci"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Profil\nBez mr."
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Autom.\nzakreni"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Traženje mobilne mreže..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Umetnite SIM karticu za pristup mrežnim uslugama."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Uvijek pitaj"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Nije moguće spojiti se na mobilne mreže dok je uključen profil Bez mreže. Umjesto toga spojite se na Wi-Fi mrežu ili isključite profil Bez mreže i pokušajte ponovno."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Traženje"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Nemoguće otvoriti %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Vani"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Privatni\nnačin"
+
diff --git a/po/hu.po b/po/hu.po
new file mode 100755 (executable)
index 0000000..3579a1d
--- /dev/null
+++ b/po/hu.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "A Wi-Fi és a Mobil AP-nem lehet egyszerre aktív. Kikapcsolja a Mobil AP-t?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Össz. Törlése"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Érintve letiltható a Bizt. mód."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "A(z) %s nem indítható el."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Csak segélyhívás lehetséges."
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Keresés..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Nincs SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Nincs szolgáltatás"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Érvénytelen SIM-kártya"
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Csak segélyhívás indítható."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Utca"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Bizt. mód engedélyezve"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Értesítések (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Ö. törlése"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Értesítés"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Rákérdez"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Rezgés"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Ultra-\ntakarékos"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Internet megosztás"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Hang"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Hang"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Privát mód"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Energia-\ntakarék."
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Némítás"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mobil\nint.kap."
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Hely"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Repülő\nüzemmód"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Aut. elforgatás"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Segéd-\nfény"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "du"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Értesítések"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "de"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "A(z) %s segítségével nem indítható hang- vagy videohívás és nem küldhető szöveges üzenet."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Válasszon SIM kártyát a kimenő hanghívásokhoz, videohívásokhoz és szöveges üzenetekhez."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "A(z) %s SIM kártyát fogja használni a kimenő hanghívásokhoz, videohívásokhoz és szöveges üzenetekhez."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Nem"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "A fényerő nem növelhető tovább, a készülék túlmelegedésének elkerülése miatt."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Nincs szolgáltatás"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Csak segélyhívás"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Utcai"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\nint.mego."
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Elem-\nlámpa"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Energia-\ntakarék."
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobil\nint.kap."
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Repülő\nüzemmód"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Aut. el-\nforgatás"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "2. SIM"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "1. SIM"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Mobilhálózat keresése..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Hálózati szolgáltatások eléréséhez helyezze be a SIM kártyát."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Rákérdez"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Amíg a Repülő üzemmód be van kapcsolva, nem lehet a mobilhálózathoz kapcsolódni. Kapcsolódjon Wi-Fi hálózathoz, vagy kapcsolja ki a Repülő üzemmódot, és próbálja újra."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Keresés"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "A(z) %s nem nyitható meg."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Utcai"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Privát\nüzemmód"
+
diff --git a/po/hy.po b/po/hy.po
new file mode 100755 (executable)
index 0000000..13c4bbd
--- /dev/null
+++ b/po/hy.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Wi-Fi-ն ու Mobile AP-ն չեն կարող միաժամանակ ակտիվացվել: Ապաակտիվացնե՞լ Mobile AP-ն:"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Մաքրել բոլորը"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Թակ. այստեղ՝ Անվտ. ռժմ կսց. հր:"
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Հնարավոր չէ գործարկել %s-ը:"
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Միայն արտ. իրավիճ. զանգեր"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Որոնում է..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "SIM չկա"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Ծառայություն չկա"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Անվավեր SIM քարտ:"
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Միայն հրատապ կանչեր:"
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Դրսում"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Անվտանգ ռեժիմ"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Ծանուցումներ (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Մաքրել բլր"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Ծանուցում"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Միշտ հարցնել"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Թրթռալ"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Էներգիայի\nգերխնայ."
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Տեղակապում"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Հնչյուն"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Ձայն"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Գաղտնի ռեժիմ"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Էներգ.\nsխնայում"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Խլացնել"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Շարժ.\nտվյալներ"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Տեղը"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Թռիչքային\nռեժիմ"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Ինքնապտտում"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Օժանդակ\nլույս"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "ԿՀ"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Ծանուցումներ"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "ԿԱ"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Անհնար է ձայնականչեր, տեսականչեր կատարել և տեքստային հաղորդագրություններ ուղարկել %s-ով:"
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "SIM քարտ ընտրեք ելից ձայնականչերի, տեսականչերի և տեքստային հաղորդագրությունների համար:"
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Ելից ձայնականչերը, տեսականչերը և տեքստային հաղորդագրությունները կկատարվեն %s SIM քարտով:"
+
+msgid "IDS_ST_SK_OK"
+msgstr "Ընդունել"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Ոչ"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Հնարավոր չէ ավելցնել հեռախոսի էկրանի պայծառությունը հեռախոսի գեր տաքանալու պատճառով:"
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Ծառայություն չկա"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Միայն արտակարգ իրավիճակի կանչեր"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Դրսում"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\nտեղակապ."
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Լապտեր"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Էներգ.\nխնայում"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Շարժական\nտվյալներ"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Թռիչք.\nռեժիմ"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Ինքնա-\nպտտում"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Տեսածրվում է շարժական կապի ցանցի առկայություն..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Տեղադրեք SIM քարտը՝ ցանցային ծառայություններ մտնելու համար:"
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Միշտ հարցնել"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Անհնար է միանալ շարժական կապի ցանցերին, երբ Թռիչքային ռեժիմն ընձեռված է: Փոխարենը միացեք Wi-Fi ցանցին կամ կասեցրեք Թռիչքային ռեժիմն ու նորից փորձեք:"
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Որոնում"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Անհնար է բացել %s-ը:"
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Դրսում"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Գաղտ. կապի\nռեժիմ"
+
diff --git a/po/is.po b/po/is.po
new file mode 100755 (executable)
index 0000000..9af931e
--- /dev/null
+++ b/po/is.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Það er ekki hægt að nota Wi-Fi og farsímaaðgangsstað á sama tíma. Viltu loka farsímaaðgangsstaðnum?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Hreinsa allt"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Slökkva á öryggisstillingu."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Mistókst að opna %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Aðeins neyðarsímtöl"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Verið er að leita..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Ekkert SIM-kort"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Engin þjónusta"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Ógilt SIM-kort."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Aðeins neyðarhringingar."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Utandyra"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Örugg stilling á"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Tilkynningar (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Hreinsa"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Tilkynning"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Spyrja alltaf"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Titra"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Ofur-\nsparnaður"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Tjóðrun"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Hljóð"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Hljóð"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Einka-\nstilling"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Orku-\nsparn."
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Hljóð-\nlaust"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Farsíma-\ngögn"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Staður"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Flug-\nstilling"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Sjálfv. snúningur"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Hjálpar-\nljós"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "eh"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Tilkynningar"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "fh"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Ekki er hægt að hringja símtöl, myndsímtöl og senda SMS með %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Veldu SIM-kort fyrir hringd símtöl, myndsímtöl og SMS."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "SIM-kort %s verður notað fyrir hringd símtöl og myndsímtöl og send textaskilaboð."
+
+msgid "IDS_ST_SK_OK"
+msgstr "Í lagi"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Nei"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Ekki hægt að auka birtastigið meir vegna ofhitnunar í síma."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Engin þjónusta"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Aðeins neyðarsímtöl"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Utandyra"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\ntjóðrun"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Vasaljós"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Orku-\nsparn."
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Farsíma-\ngögn"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Flug-\nstilling"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Sjálfv.\nsnún."
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Leita að farsímakerfi..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Setjið SIM kort í til að fá aðgang að netþjónustu."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Spyrja alltaf"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Ekki er hægt að tengjast farsímakerfum þegar kveikt er á flugstillingu. Tengstu Wi-Fi neti í staðinn eða slökktu á flugstillingu og reyndu aftur."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Leita"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Ekki er hægt að opna %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Utandyra"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Einka-\nstilling"
+
diff --git a/po/it_IT.po b/po/it_IT.po
new file mode 100755 (executable)
index 0000000..c30bdd4
--- /dev/null
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Impossibile attivare contemporaneamente sia Wi-Fi che Router Wi-Fi. Disattivare Router Wi-Fi?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Cancella tutto"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Tocca per disatt. mod. emerg."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Impossibile avviare %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Solo emergenza"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Ricerca..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Nessuna SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Nessun servizio"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Scheda SIM non valida."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Solo chiamate di emergenza"
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Esterno"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Modalità provv. abilitata"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Notifiche (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Canc. tutto"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Notifica"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Chiedi sempre"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibraz."
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Risp. en.\navanzato"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Tethering"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Suono"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Suono"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Modalità privata"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Risparmio\nenergia"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Silenz."
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Conn.\ndati"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Posizione"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Modalità\noffline"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Rotazione automatica"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Torcia"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Notifiche"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Impossibile effettuare chiamate vocali, video chiamate e inviare messaggi di testo con %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Selezionate la scheda SIM per le chiamate vocali, le video chiamate e i messaggi di testo in uscita."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Per le chiamate vocali, le video chiamate e i messaggi di testo in uscita verrà utilizzata la scheda SIM %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "No"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Impossibile aumentare la luminosità a causa del surriscaldamento del dispositivo."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Nessun servizio"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Solo chiamate di emergenza"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "All'aperto"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Tethering\nWi-Fi"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Torcia"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Rispar.\nen. av."
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Conness.\ndati"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Modal.\noffline"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Rotaz.\nauto"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Ricerca di reti mobili in corso..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Inserite una scheda SIM per accedere ai servizi di rete."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Chiedi sempre"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Impossibile connettersi alle reti mobili se la Modalità offline è attivata. Connettetevi alla rete Wi-Fi o disattivate la Modalità offline e riprovate."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Ricerca"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Impossibile aprire %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "All'aperto"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Modalità\nprivata"
+
diff --git a/po/ja_JP.po b/po/ja_JP.po
new file mode 100755 (executable)
index 0000000..70f10da
--- /dev/null
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Wi-FiとWi-Fiテザリング両方は同時起動できません。Wi-Fiテザリングを無効にしますか?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "全て消去"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "セーフモードを無効にするには、ここをタップ"
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "%sを起動できません。"
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "緊急通報のみ発信可能"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "検索中..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "SIM未挿入"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "サービスが利用できません。"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "無効なSIMカードです。"
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "緊急通報のみ​発信可能です。"
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "アウトドア"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "セーフモードが有効"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "通知(%d件)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "全て消去"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "通知"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "毎回確認"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "バイブ"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "ウルトラ\n省電力モード"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "テザリング"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "サウンド"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "サウンド"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "プライベートモード"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "省電力\nモード"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "消音"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "モバイル​データ"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "位置情報"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "機内モード"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "自動回転"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "補助\nライト"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "通知"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "%sを使用して音声通話やビデオコールを発信、およびテキストメッセージを送信することはできません。"
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "音声通話とビデオコールの発信、およびテキストメッセージの送信に使用するSIMカードを選択してください。"
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "%s SIMカードを使用して、音声電話やビデオコールの発信、およびテキストメッセージの送信を行います。"
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "いいえ"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "端末が過熱しているため、これ以上明るさを上げることができません。"
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "サービスが利用できません"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "緊急通報のみ発信可能です"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "アウトドアモード"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\nテザリング"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "トーチ"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "省電力\nモード"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "モバイル\nデータ"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "機内\nモード"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "自動\n回転"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "モバイルネットワークをスキャン中..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "ネットワークサービスを利用するにはSIMカードを挿入してください。"
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "毎回確認"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "機内モードが有効な間は、モバイルネットワークに接続できません。Wi-Fiネットワークに接続するか、機内モードを無効にし、再度実行してください。"
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "検索しています。"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "%sを起動できません。"
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "アウトドア"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "プライベート\nモード"
+
diff --git a/po/ka.po b/po/ka.po
new file mode 100755 (executable)
index 0000000..169952a
--- /dev/null
+++ b/po/ka.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Wi-Fi და Mobile AP ვერ გააქტიურდება ერთიდაიმავე დროს. გამოირთოს Mobile AP?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "ყველას წაშლა"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "შეხებით გამორთეთ უსაფრთხო რეჟ."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "ვერ გაიხსნება %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "მხოლოდ საგანგებო ზარები"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "იძებნება..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "SIM არაა"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "მომსახურება არ არის"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "SIM ბარათი უმოქმედოა."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "მხოლოდ გადაუდებელი ზარები."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "გარეთ"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "საგანგებო რეჟიმი ჩართულია"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "შეტყობინებები (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "წაშლა"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "შეტყობინება"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "ყოველთვის მკითხე"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "ვიბრაცია"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "ენერგიის\nდაზოგვა"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "მობილური ინტერნეტი"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "ხმა"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "ხმა"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "პერსონალური რეჟ."
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "დაზოგეთ\nენერგია"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "უხმო"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "მობილ.\nმონაცემ."
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "ლოკაცია"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "ფრენის\nრეჟიმი"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "ავტომატური ბრუნვა"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "დამხმარე\nფანარი"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "შეტყობინებები"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "%s–ის საშუალებით ვერ გაგზავნით ხმოვან ზარებს, ვიდეო ზარებს და.ტექსტურ წერილებს."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "აირჩიეთ SIM ბარათი გამავალი ხმოვანი ზარებისთვის, ვიდეო ზარებისთვის და ტექსტური წერილებისთის."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "გამავალი ხმოვანი ზარები, ვიდეო ზარები და ტექსტური შეტყობინებები განხორციელდება %s SIM ბარათით."
+
+msgid "IDS_ST_SK_OK"
+msgstr "კი"
+
+msgid "IDS_ST_SK_NO"
+msgstr "არა"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "განათებულობას ვეღარ გაზრდით, ტელეფონის გადახურების საშიშროების გამო."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "სერვისი არ არის"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "მხოლოდ გადაუდებელი ზარები"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "გარეთ"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\nწერტილი"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "ფანარი"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "ენერგიის\nდაზოგვა"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "მობილური\nმონაცემ."
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "ფრენის\nრეჟიმი"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "ავტო\nბრუნვა"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "იძებნება მობილური ქსელი..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "ქსელის მომსახურების მისაღებად ჩასვით SIM ბარათი."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "ნებართვით"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "მობილურ ქსელებთან დაკავშირება შეუძლებელია, სანამ აქტიურია ფრენის რეჟიმი. სანაცვლოდ, დაუკავშირდით Wi-Fi ქსელს, ან გამორთეთ ფრენის რეჟიმი და ისევ სცადეთ."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "იძებნება"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "%s ვერ იხსნება."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "გარეთ"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "პირადი\nრეჟიმი"
+
diff --git a/po/kk.po b/po/kk.po
new file mode 100755 (executable)
index 0000000..03b4aa6
--- /dev/null
+++ b/po/kk.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Wi-Fi және Mobile AP екеуін де бір уақытта іске қосу мүмкін емес. Mobile AP мүмкіндігін өшіру керек пе?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Барлығын өшіру"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Қау.реж.өш.ү/н мына жерді түрт."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "%s іске қосу мүмкін емес."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Тек төтенше қоңыраулар"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Іздеуде...."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "SIM жоқ"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Қызмет жоқ"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Жарамсыз SIM карта."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Тек жедел қоңырау  үшін."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Сыртта"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Қауіпсіз реж.іске қосылды"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Хабарландырулар (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Барл.өшіру"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Хабарландыру"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Әрқашан сұрау"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Діріл"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Ул. қуат\nсақталуы"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Шектеу"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Дыбыс"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Дыбыс"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Жеке режим"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Қуат\nүнемдеу"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Дыбысты\nөшіру"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Ұялы\nдеректер"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Орны"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Ұшу\nрежимі"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Авто бұру"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Көмекші\nшам"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "TK"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Хабарландыру"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "ТД"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "%s пайдалану арқылы дауыстық қоңыраулар мен бейне қоңырауларын жасау және мәтіндік хабарларды жібері мүмкін емес."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Шығыс дауыстық қоңыраулары, бейне қоңыраулары және мәтіндік хабарлар үшін SIM картасын таңдаңыз."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Шығыс дауыстық қоңыраулар, бейне қоңыраулар мен мәтіндік хабарлар %s SIM картасын пайдаланып жасалады."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Жоқ"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Жарықтықты одан ары көбейту мүмкін емес, себебі телефон қызып кетті."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Қызмет жоқ"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Тек төтенше қоңыраулар ғана"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Көшеде"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\nбайланыстыру"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Шам"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Қуат\nүнемдеу"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Ұялы\nдеректер"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Ұшу\nрежимі"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Авто\nбұру"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Ұялы желіні қарап шығуда..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Желі қызметтеріне өту үшін SIM картасына салу."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Әрқашан сұрау"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Ұшу режимі қосылғанда, ұялы желілерге қосылу мүмкін емес. Оның орнына Wi-Fi желісіне қосылыңыз немесе ұшу режимін өшіріңіз, сосын әрекетті қайталап көріңіз."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Іздеу"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "%s ашу мүмкін емес."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Сыртта"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Жеке\nрежим"
+
diff --git a/po/ko_KR.po b/po/ko_KR.po
new file mode 100755 (executable)
index 0000000..ff6941c
--- /dev/null
@@ -0,0 +1,174 @@
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "%s을(를) 실행할 수 없습니다."
+
+msgid "IDS_ST_SK_OK"
+msgstr "확인"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "알림"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "알림"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 카드1"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 카드2"
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "항상 묻기"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "디바이스 온도가 높아져 밝기를 더 높일 수 없습니다."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "네트워크 서비스를 이용하려면 SIM 카드를 삽입하세요."
+
+msgid "IDS_ST_SK_NO"
+msgstr "아니요"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "모두 삭제"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "서비스 지역이 아닙니다"
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "긴급전화만 가능합니다."
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "검색 중..."
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "SIM 카드가 바르지 않습니다."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "SIM 카드가 없습니다"
+
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Wi-Fi와 모바일 AP를 동시에 실행할 수 없습니다. 모바일 AP를 해제할까요?"
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "음성통화, 영상통화를 걸고 문자 메시지를 보낼 때 SIM%s 카드를 사용합니다."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "음성통화, 영상통화를 걸고 문자 메시지를 보낼 때 SIM 카드를 선택합니다."
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "%s를 사용하여 음성통화, 영상통화를 걸고 문자 메시지를 보낼 수 없습니다."
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "[비행기 탑승 모드] 실행 중에는 모바일 네트워크에 연결할 수 없습니다. Wi-Fi 네트워크에 연결하거나 [비행기 탑승 모드]를 해제한 후 다시 시도하세요."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "긴급전화만 가능"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "알림(%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "모두 삭제"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "항상 묻기"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "오전"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "오후"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "모바일\n데이터"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "소리"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "보조 조명"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "블루투스"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "절전 모드"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "자동 회전"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "위치"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "테더링"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "비행기\n탑승 모드"
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "서비스를 사용할 수 없습니다"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "긴급전화만 가능합니다"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "모바일 네트워크 찾는 중..."
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "모바일\n데이터"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "손전등"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "블루투스"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "절전\n모드"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "자동\n회전"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\n테더링"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "비행기\n탑승 모드"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "소리"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "진동"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "무음"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "초절전\n모드"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "프라이빗 모드"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "야외 모드"
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "야외"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "안전 모드 실행"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "[안전 모드]를 해제하려면 여기를 누르세요."
+
diff --git a/po/lt.po b/po/lt.po
new file mode 100755 (executable)
index 0000000..a666b4b
--- /dev/null
+++ b/po/lt.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Tuo pat metu negalima suaktyvinti ir „Wi-Fi“, ir „Mobile AP“. Išjungti „Mobile AP“?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Valyti viską"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Bakst. čia išj. saugųjį režimą."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Negalima paleisti %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Tik pagalbos skambučiai"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Ieškoma..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Nėra SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Paslauga neteikiama"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Netinkama SIM kortelė."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Tik pagalbos skambučiai."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Lauke"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Įjungtas saugus režimas"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Pranešimai (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Viską išv."
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Pranešimas"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Visada klausti"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "„Wi-Fi“"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibruoti"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Ypat.en.\ntaupymas"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Siejama"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Garsas"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Garsas"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Asmeninis režim."
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Energ.\ntaupymas"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Tildyti"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mob.\nduomenys"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Vieta"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Skrydžio\nrežim."
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "„Bluetooth“"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Automatinis sukimas"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Pagalb.\nlemputė"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Pranešimai"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Neįmanoma atlikti balso ir vaizdo skambučių bei siųsti teksto žinučių naudojant %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Pasirinkite SIM kortelę išeinantiems balso ir vaizdo skambučiams bei teksto žinutėms."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Išeinantys balso skambučiai, vaizdo skambučiai ir teksto žinutės bus atliekami naudojant %s SIM kortelę."
+
+msgid "IDS_ST_SK_OK"
+msgstr "Gerai"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Ne"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Neįmanoma padidinti šviesumo dėl telefono perkaitimo."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Paslauga neteikiama"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Tik pagalbos skambučiai"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Laukas"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\nsiejimas"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Žibintu-\nvėlis"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Energij.\ntaup."
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobil.\nduom."
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Skryd.\nrežimas"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Autom.\npasukim."
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Ieškoma mobiliojo tinklo..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Įdėkite SIM kortelę, kad galėtumėte  naudotis tinklo paslaugomis."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Visada klausti"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Neįmanoma prisijungti prie mobiliųjų tinklų, kol įjungtas skrydžio režimas. Prisijunkite prie „Wi-Fi“ tinklo arba išjunkite skrydžio režimą ir bandykite dar kartą."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Ieškoma"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Neįmanoma atidaryti %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Lauke"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Asmen.\nrežimas"
+
diff --git a/po/lv.po b/po/lv.po
new file mode 100755 (executable)
index 0000000..8f47d9b
--- /dev/null
+++ b/po/lv.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Vienlaikus nevar aktivizēt Wi-Fi un Mobile AP. Vai deaktivizēt Mobile AP?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Notīrīt visu"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Piesk.šeit, lai izsl.drošo rež."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Nevar palaist %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Tikai ārkārtas zvani"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Meklē..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Nav SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Nav pakalpojuma"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Nederīga SIM karte."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Tikai ārkārtas zvani."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Ārā"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Aktivizēts drošais režīms"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Paziņojumi (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Not. visu"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Paziņojums"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Vienmēr jautāt"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibrēt"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Īp.\nenerģ. taup."
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Piesaiste"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Skaņa"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Skaņa"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Privātais režīms"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Enerģijas\ntaup."
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Izslēgt skaņu"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mobilie\ndati"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Lokācija"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Lidojuma\nrežīms"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Automātiskā pagrieš."
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Pap.\napgaism."
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Paziņojumi"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Balss zvanus, videozvanus un īsziņu nosūtīšanu nevar veikt, izmantojot %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Izvēlieties SIM karti izejošajiem balss zvaniem, videozvaniem un īsziņām."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Izejošie balss zvani un videozvani, kā arī īsziņu sūtīšana tiks veikta, izmantojot SIM karti %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "Labi"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Nē"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Nav iespējams vairāk palielināt spilgtumu dēļ tālruņa pārkaršanas."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Nav pakalpojuma"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Tikai ārkārtas zvani"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Ārā"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\npies."
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Lukturis"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Enerģ.\ntaup."
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobilie\ndati"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Lidojuma\nrežīms"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Autom.\npagriezt"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Meklē mobilo tīklu..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Lai piekļūtu tīkla pakalpojumiem, ievietojiet SIM karti."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Vienmēr jautāt"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Nevar izveidot savienojumu ar mobilajiem tīkliem, kamēr ir aktivizēts lidojuma režīms. Tā vietā izveidojiet savienojumu ar Wi-Fi tīklu vai deaktivizējiet lidojuma režīmu un mēģiniet vēlreiz."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Meklē"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Nevar atvērt programmu %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Ārā"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Priv.\nrežīms"
+
diff --git a/po/mk.po b/po/mk.po
new file mode 100755 (executable)
index 0000000..f99bfdd
--- /dev/null
+++ b/po/mk.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Не може истовремено да се активни и Wi-Fi и мобилна пристапна точка. Да се исклучи мобилната пристапна точка?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Бриши сѐ"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Допр.тука за искл.Безбед.режим."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Не може да се активира %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Само итни повици"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Пребарување..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Нема SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Нема услуга"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Неважечка SIM-картичка."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Само итни повици."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Надвор"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Безбедн. режим е вклучен"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Известувања (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Избриши сѐ"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Извест."
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Прашувај секогаш"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Вибрации"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Улт.штед.\nенергија"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Поврзување"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Звук"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Звук"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Приватен режим"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Штедење\nенергија"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Исклучи звук"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Мобилни\nподатоци"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Локација"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Режим\nза летало"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Автоматско вртење"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Помошно\nсветло"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Известувања"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Не може да се упатуваат говорни повици, видео повици и текстуални пораки со %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Изберете SIM-картичка за појдовните говорни повици, видео повиците и текстуалните пораки."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Појдовните говорни повици, видео повиците и текстуалните пораки ќе се упатуваат со SIM-картичката %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Не"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Не може да се зголеми осветленоста повеќе поради прегревање на телефонот."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Нема услуга"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Само итни повици"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Надвор"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Сподел.\nWi-Fi"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Светилка"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Штед.\nенергија"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Моб.\nподатоци"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Авионски\nрежим"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Автом.\nвртење"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Се скенира за мобилни мрежи..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Вметнете SIM-картичка за да пристапите кон мрежните услуги."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Прашувај секогаш"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Не може да се поврзе со мобилни мрежи додека е вклучен режим за летање. Поврзете се со мрежа Wi-Fi место тоа или исклучете го режимот за летање и обидете се повторно."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Се пребарува"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Не може да се отвори %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Надвор"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Приватен\nрежим"
+
diff --git a/po/nb.po b/po/nb.po
new file mode 100755 (executable)
index 0000000..76ee916
--- /dev/null
+++ b/po/nb.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Både Wi-Fi og mobilt tilgangspunkt kan ikke aktiveres samtidig. Deaktivere mobilt tilgangspunkt?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Tøm alle"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Trykk for deaktiv. Sikkerh.mod."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Kan ikke starte %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Kun nødanrop"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Søker..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Mangler SIM-kort"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Nettverk mangler"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Ugyldig SIM-kort."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Kun nødanrop"
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Utendørs"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Sikkerhetsmodus aktivert"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Varsler (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Slett alt"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Varsel"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Spør alltid"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibrer"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "U. strøm-\nsparing"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Internett-deling"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Lyd"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Lyd"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Privat-\nmodus"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Strøm-\nsparing"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Demp"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mobil-\ndata"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Posisjon"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Fly-\nmodus"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Automatisk rotasjon"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Hjelpe\nlys"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Varsler"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Kan ikke foreta taleanrop, videoanrop og sende tekstmeldinger ved å bruke %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Velg SIM-kort for utgående taleanrop, videoanrop og tekstmeldinger."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Utgående taleanrop, videoanrop og tekstmeldinger blir gjort ved å bruke SIM-kortet for %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Nei"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Kan ikke øke lysstyrken mer på grunn av at telefonen kan overopphetes."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Ingen tjeneste"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Kun nødanrop"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Utendørs"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi-\nInt.deling"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Lomme\n-lykt"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Strøm-\nsparing"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobil-\ndata"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Fly-\nmodus"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Auto.\nrotasjon"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Søker etter mobilnett..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Sett inn SIM-kort for å få tilgang til nettverkstjenester."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Spør alltid"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Kan ikke koble til mobilnett mens Flymodus er aktivert. Koble til et Wi-Fi-nettverk i stedet, eller deaktiver Flymodus, og prøv på nytt."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Søker"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Kan ikke åpne %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Ute"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Privat-\nmodus"
+
diff --git a/po/nl.po b/po/nl.po
new file mode 100644 (file)
index 0000000..1a6baf8
--- /dev/null
+++ b/po/nl.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Wi-Fi en mobiel access point kunnen niet tegelijkertijd zijn geactiveerd. Mobiel access point uitschakelen?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Wis alles"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Tik voor Veilige modus uit."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Kan %s niet starten."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Alleen noodoproepen"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Zoeken..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Geen SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Geen netwerk"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Ongeldige SIM-kaart."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Alleen noodoproepen."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Buiten"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Veilige modus aan"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Meldingen (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Alles wissen"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Melding"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Altijd vragen"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Trillen"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Ext spaar\n-stand"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Tethering"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Geluid"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Melodie"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Privé-\nstand"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Spaar-\nstand"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Dempen"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mobiele\ngegevens"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Locatie"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Vliegtuig-\nstand"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Automatisch draaien"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Hulp-\nlamp"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Meldingen"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Kan geen uitgaande spraakoproepen en video-oproepen doen en geen SMS-berichten verzenden met %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Selecteer SIM-kaart voor uitgaande spraakoproepen, video-oproepen en SMS-berichten."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Uitgaande spraakoproepen, video-oproepen en SMS-berichten worden gemaakt met de SIM-kaart voor %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Nee"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Kan de helderheid niet verder verhogen, omdat de telefoon dan te warm wordt."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Geen netwerk"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Alleen noodoproepen"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Buiten"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\ntethering"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Zaklamp"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Spaar-\nstand"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobiele\ngegevens"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Vliegt.-\nstand"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Autom.\ndraaien"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Zoeken naar mobiel netwerk..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Plaats de SIM-kaart voor netwerkdiensten."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Altijd vragen"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Kan niet verbinden met mobiele netwerken als Vliegtuigstand is ingeschakeld. Maak in plaats daarvan verbinding via een Wi-Fi-netwerk of schakel Vliegtuigstand uit en probeer het opnieuw."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Zoeken"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Kan %s niet openen."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Buiten"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Privé-\nstand"
+
diff --git a/po/pl.po b/po/pl.po
new file mode 100755 (executable)
index 0000000..d5a365f
--- /dev/null
+++ b/po/pl.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Sieć Wi-Fi i Router Wi-Fi nie mogą być uruchomione jednocześnie. Wyłączyć Router Wi-Fi?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Wyczyść wszys."
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Dotk. tutaj, aby wył. tr. bezp."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Nie można uruchomić %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Tylko połączenia alarmowe"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Wyszukiwanie..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Brak karty SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Brak sieci"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Nieprawidłowa karta SIM"
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Tylko połączenia alarmowe."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Na zewn."
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Tryb bezpieczny włączony"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Powiadomienia (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Czysz.wsz."
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Powiadom."
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Zawsze pytaj"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Wibracja"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "B. nisk.\nzuż. en."
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Router"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Dźwięk"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Dźwięk"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Tryb prywatny"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Oszcz.\nenergii"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Wycisz"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Dane\nkomórkowe"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Lokalizacja"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Tryb\nOffline"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Automatyczny obrót"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Lat. dla\nniedow."
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Powiadomienia"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Nie można wykonywać połączeń głosowych, połączeń wideo i wysyłać SMS przy użyciu %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Wybierz kartę SIM dla wychodzących połączeń głosowych, połączeń wideo i SMS."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Dla wychodzących połączeń głosowych, połączeń wideo i SMS będzie używana karta SIM %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Nie"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Nie można zwiększyć jasności z uwagi na możliwość przegrzania urządzenia."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Brak sieci"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Tylko połączenia alarmowe"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Na zewnątrz"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\nrouter"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Latarka"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Oszcz.\nenergii"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Dane\nkomórk."
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Tryb\nOffline"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Obróć\nautom."
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Wyszukiwanie sieci komórkowych..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Włóż kartę SIM, aby uzyskać dostęp do usług sieciowych."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Zawsze pytaj"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Kiedy tryb Offline jest włączony, nie można korzystać z sieci komórkowych. Połącz się z siecią Wi-Fi lub wyłącz tryb Offline i spróbuj ponownie."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Wyszukiwanie"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Nie można otworzyć aplikacji %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Na zewn."
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Tryb\nprywatny"
+
diff --git a/po/pt_BR.po b/po/pt_BR.po
new file mode 100755 (executable)
index 0000000..5aceb97
--- /dev/null
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Impossível utilizar Wi-Fi ou AllShare com o Roteador Wi-Fi simultaneamente. Desativar o Roteador Wi-Fi?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Limpar tudo"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Toque aqui desat. M. Emerg."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Impossível iniciar %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Apenas cham. emergência"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Procurando..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Sem Cartão SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Sem serviço"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Cartão SIM inválido."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Somente chamadas de emergência."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Externo"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Modo de Segurança ativado"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Notificações (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Apag. tudo"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Notific."
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Perguntar sempre"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibrar"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Ultra\neconomia"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Ancoragem"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Som"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Som"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Modo Privado"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Econ. de\nenergia"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Silêncio"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Dados\nmóveis"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Local"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Modo\nOffline"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Rotação automática"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Luz\nauxiliar"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Notificações"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Não é possível realizar chamadas de voz, videochamadas e enviar mensagens de texto usando %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Selecione o chip para chamada de voz realizadas, videochamadas e mensagens de texto."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "As chamada de voz realizadas, videochamadas e mensagens de texto serão feitas usando o cartão SIM %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Não"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Impossível aumentar mais o nível do brilho devido ao superaquecimento do telefone."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Sem serviço"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Somente chamadas de emergência"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Externo"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Roteam.\nWi-Fi"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Lanterna"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Econ.\nenergia"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Dados\nmóveis"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Modo\nOffline"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Rotação\nautom."
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Buscando por rede móvel..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Insira um cartão SIM para acessar serviços de rede."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Perguntar sempre"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Não é possível conectar-se à rede de dados móveis enquanto o Modo Offline estiver ativado. Conecte-se a uma rede Wi-Fi ou desative o Modo Offline e tente novamente."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Procurando"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Não é possível abrir %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Externo"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Modo\nPrivado"
+
diff --git a/po/pt_PT.po b/po/pt_PT.po
new file mode 100755 (executable)
index 0000000..11282e8
--- /dev/null
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Impossível activar Wi-Fi e PA Móvel em simultâneo. Desactivar PA Móvel?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Limpar tudo"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Toq aqui p desact Modo seguro."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Impossível iniciar %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Só chamadas de emergência"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "A procurar..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Sem SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Sem serviço"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Cartão SIM inválido."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Apenas chamadas de emergência."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Exterior"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Modo seguro activado"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Notificações (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Limpar td"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Notificaç"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Perguntar sempre"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibrar"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "U. econ.\nenergia"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Partilha de Internet"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Som"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Som"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Modo privado"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Econ.\nenergia"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Silen\nciar"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Dados\nmóveis"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "GPS"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Modo\nde voo"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Rotação automática"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Luz\nauxiliar"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Notificações"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Impossível fazer chamadas de voz, chamadas de vídeo e enviar mensagens de texto com %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Seleccione um cartão SIM para as chamadas de voz efectuadas, chamadas de vídeo e mensagens de texto."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "As chamadas de voz, as chamadas de vídeo efectuadas e as mensagens de texto a enviar serão feitas com o cartão SIM %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Não"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Impossível aumentar mais o brilho devido ao sobreaquecimento do telefone."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Sem serviço"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Só chamadas de emergência"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Exterior"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Ancorag.\nWi-Fi"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Lanterna"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Economia\nenergia"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Dados\nmóveis"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Modo\nde voo"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Rotação\nauto."
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "A pesquisar rede móvel..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Insira o cartão SIM para aceder aos serviços de rede."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Perguntar sempre"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Impossível ligar às redes móveis enquanto o modo de Voo está activado. Em alternativa, ligue a uma rede Wi-Fi ou desactive o modo de Voo e tente novamente."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "A procurar"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Impossível abrir %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Exterior"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Modo\nprivado"
+
diff --git a/po/ro.po b/po/ro.po
new file mode 100755 (executable)
index 0000000..0cf4e64
--- /dev/null
+++ b/po/ro.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Wi-Fi şi PA mobil nu pot fi activate simultan. Dezactivaţi PA mobil?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Şterg. totală"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "At. aici pt. dez. Mod. sigur."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Imposibil de lansat %s"
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Numai apeluri de urgenţă"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Căutare..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Fără SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Nici un serviciu"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Cartelă SIM incorectă"
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Numai apeluri de urgenţă"
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Exterior"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "S-a activ. Mod. siguranţă"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Notificări (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Şter. tot"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Notificare"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Întreabă mereu"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibraţii"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Ec. max.\nenergie"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Furn. acces internet"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Sunet"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Sunet"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Modul Privat"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Econom.\nenergie"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Silenţ."
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Date\nmobile"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Locaţie"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Mod\nAvion"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Rotire automată"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Lumină\najutor"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "pm"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Notificări"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "am"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Nu se pot efectua apeluri vocale şi video şi nu se pot trimite mesaje text utilizând %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Selectaţi o cartelă SIM pentru apelurile vocale şi video efectuate şi pentru mesajele text."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Se va utiliza cartela SIM %s pentru apelurile vocale şi video de ieşire şi mesajele text trimise."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Nu"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Imposibil de mărit luminozitatea deoarece telefonul este supraîncălzit"
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "În afara ariei de acoperire"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Numai apeluri de urgenţă"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Exterior"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Tethering\nWi-Fi"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Lanternă"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Econom.\nenergie"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Date\nmobile"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Modul\nAvion"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Rotire\nautomată"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Se caută reţeaua mobilă..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Introduceţi cartela SIM pentru a accesa serviciile de reţea."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Solicită întotdeauna"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Imposibil de conectat la reţelele mobile când modul Avion este activat. Conectaţi-vă la reţeaua Wi-Fi sau dezactivaţi modul Avion şi încercaţi din nou."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Se caută"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "%s nu se poate deschide."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Exterior"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Mod\nPrivat"
+
diff --git a/po/ru_RU.po b/po/ru_RU.po
new file mode 100755 (executable)
index 0000000..c00a884
--- /dev/null
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Нельзя активировать одновременно Wi-Fi и Mobile AP. Отключить Mobile AP?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Очистить все"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Наж. для откл. безопас. режима."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Невозможно запустить %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Только экстренные вызовы"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Поиск..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Нет SIM-карты"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Нет сети"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Неправильная SIM-карта."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Только экстренные вызовы."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "На улице"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Безопасный режим включен"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Уведомления (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Очист. все"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Уведомление"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Всегда спраш."
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Вибрация"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Макс.\nэкономия"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Модем"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Звук"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Звук"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Приват. режим"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Экономия\nэнергии"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Откл.\nзвук"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Мобил.\nданные"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Геоданные"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Автономн.\nрежим"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Автоповорот"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Подсвет."
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Уведомления"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Невозможно выполнять голосовые вызовы и видеовызовы, а также отправлять текстовые сообщения с помощью %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Выберите SIM-карту для исходящих голосовых вызовов, видеовызовов и текстовых сообщений."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Для исходящих голосовых вызовов, видеовызовов и текстовых сообщений будет использоваться SIM-карта %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Нет"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Невозможно увеличить яркость из-за перегрева устройства."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Нет сети"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Только экстренные вызовы"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "На улице"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Модем\nWi-Fi"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Фонарик"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Экономия\nэнергии"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Моб.\nданные"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Автон.\nрежим"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Авто-\nповорот"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Поиск мобильной сети..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Вставьте SIM-карту для доступа к услугам сети."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Всегда спрашивать"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Невозможно подключиться к мобильной сети в автономном режиме. Подключитесь к сети Wi-Fi или отключите автономный режим и повторите попытку."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Поиск"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Не удалось открыть %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "На улице"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Приватный\nрежим"
+
diff --git a/po/sk.po b/po/sk.po
new file mode 100755 (executable)
index 0000000..08c9b86
--- /dev/null
+++ b/po/sk.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Wi-Fi a mobilný prístupový bod sa nedajú aktivovať súčasne. Deaktivovať mobilný prístupový bod?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Vymazať všetko"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Ťukn. sem vypn. bezpečný režim."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Nedá sa spustiť %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Iba tiesňové volania"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Hľadanie..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Žiadna SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Žiadna služba"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Neplatná SIM karta."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Len tiesňové volania."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Vonku"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Bezpečný režim je zapnutý"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Oznámenia (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Vymaz. vš."
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Oznámenie"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Vždy sa pýtať"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibrovať"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Extrémne\nšetrenie"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Zdieľanie pripojenia"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Zvuk"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Zvuk"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Súkromný režim"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Šetren.\nenergie"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Stíšiť"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mobilné\ndáta"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "GPS"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Letový\nrežim"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Automat. otáčanie"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Pomocné\nsvetlo"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "pp"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Oznámenia"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "dp"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "%s neumožňuje uskutočňovať hlasové hovory, videohovory a odosielať textové správy."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Vyberte kartu SIM pre odchádzajúce hlasové hovory, videohovory a textové správy."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Odchádzajúce hlasové hovory, videohovory a textové správy sa budú uskutočňovať pomocou karty SIM %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Nie"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Kvôli prehrievaniu zariadenia nemožno teraz ďalej zvyšovať jas displeja."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Žiadna služba"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Iba tiesňové volania"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Vonku"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Zdieľať\nWi-Fi"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Baterka"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Šetrenie\nenergie"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobilné\ndát. pr."
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Letový\nrežim"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Automat.\notáčanie"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Vyhľadáva sa mobilná sieť..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Vložte SIM kartu na prístup k službám siete."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Vždy sa pýtať"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Keď je zapnutý letový režim, nedá sa pripojiť k mobilným sieťam. Pripojte sa namiesto toho k sieti Wi-Fi alebo vypnite letový režim a skúste to znova."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Hľadá sa"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Súbor %s sa nedá otvoriť."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Vonku"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Súkromný\nrežim"
+
diff --git a/po/sl.po b/po/sl.po
new file mode 100755 (executable)
index 0000000..4e2e8bd
--- /dev/null
+++ b/po/sl.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Wi-Fi in mobilna DT ne moreta biti vklopljeni hkrati. Izklopim mobilno DT?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Počisti vse"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Prit. tu, da onem. varni način."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Ni mogoče zagnati %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Samo klici v sili"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Iščem"
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Ni SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Ni storitve"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Neveljavna kartica SIM."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Samo klici v sili."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Zunaj"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Varni način je omogočen"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Obvestila (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Počis. vse"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Obvestilo"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Vedno vprašaj"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibrir-\nanje"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Izr. var.\nz ener."
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Skup. raba interneta"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Zvok"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Zvok"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Zasebni način"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Varč.\nz energ."
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Izklop zvoka"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mobilni\npodatki"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Lokacija"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Način\nletenja"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Samodejno zavrti"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Pomožna\nlučka"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "po"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Obvestila"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "do"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Kartice %s ni mogoče uporabljati za glasovne klice, video klice in pošiljanje besedilnih sporočil."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Izberite kartico SIM za odhodne glasovne klice, video klice in besedilna sporočila."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Za odhodne glasovne klice, video klice in besedilna sporočila bo uporabljena kartica SIM %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "V redu"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Ne"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Svetlosti ni mogoče povečati zaradi morebitnega pregrevanja telefona."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Ni signala"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Samo klici v sili"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Na prostem"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Privez.\nWi-Fi"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Svetilka"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Varč.\nz energ."
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobilni\npodatki"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Način\nletenja"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Samodej.\nzavrti"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "Kartica SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "Kartica SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Iskanje mobilnih omrežij ..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Za dostop do omrežnih storitev vstavite kartico SIM."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Vedno vprašaj"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Ko je omogočen način letenja, povezava z mobilnimi omrežji ni mogoča. Povežite se z omrežjem Wi-Fi ali onemogočite način letenja in poskusite znova."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Iščem"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Aplikacije %s ni mogoče odpreti."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Zunaj"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Zasebni\nnačin"
+
diff --git a/po/sr.po b/po/sr.po
new file mode 100755 (executable)
index 0000000..c54b3ad
--- /dev/null
+++ b/po/sr.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Wi-Fi i mobilna pristupna tačka se ne mogu uključiti istovremeno. Isključi mobilnu pristupnu tačku?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Obriši sve"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Kucni tu za onem. Bezb. režima."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Nemoguće pokrenuti %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Samo poz. u hit. slučaj."
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Pretraga..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Nema SIM kartice"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Nema prijema"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Neispravna SIM kartica."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Samo pozivi u hitnim slučajevima."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Napolju"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Bezbedni režim omogućen"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Obaveštenja (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Obriši sve"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Obavešt."
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Uvek pitaj"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibra-\ncija"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Izu. ušt.\nenerg."
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Vezivanje"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Zvuk"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Zvuk"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Privatni režim"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Ušteda\nenergije"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Isklju-\nčen ton"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mobilni\npodaci"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Lokacija"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Profil\nletenja"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Automatski rotiraj"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Pomoćno\nsvetlo"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Obaveštenja"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Nije moguće uputiti glasovne pozive, video pozive i poslati tekstualne poruke koristeći %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Izaberi SIM karticu za odlazne glasovne pozive, video pozive i tekstualne poruke."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Odlazni glasovni pozivi i video pozivi će biti obavljeni i tekstualne poruke će biti razmenjene korišćenjem %s SIM kartice."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Ne"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Nije moguće povećati osvetljenje, telefon se pregreva."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Nema usluga"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Samo pozivi u hitnim slučajevima"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Napolju"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\nveziva."
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Lampa"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Ušteda\nenergije"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobilni\npodaci"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Avionski\nrežim"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Autom.\nrotiraj"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Traži se mobilna mreža..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Ubaci SIM karticu da bi mogao/la da koristiš mrežne usluge."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Uvek pitaj"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Povezivanje na mobilne mreže nije moguće kada je omogućen Avionski režim. Umesto toga, poveži se na Wi-Fi mrežu ili onemogući Avionski režim i pokušaj ponovo."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Pretraga"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Nije moguće otvoriti %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Napolju"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Privatni\nrežim"
+
diff --git a/po/sv.po b/po/sv.po
new file mode 100755 (executable)
index 0000000..10d8b62
--- /dev/null
+++ b/po/sv.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Det går inte att aktivera både Wi-Fi och Mobile AP samtidigt. Avaktivera Mobile AP?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Rensa allt"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Tryck här = inakt. säkert läge."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Kan inte starta %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Endast nödsamtal"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Söker..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Inget SIM"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Ej service"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Ogiltigt SIM-kort."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Endast nödsamtal."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Utomhus"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Säkert läge aktiverat"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Aviseringar (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Rensa allt"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Meddelande"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Fråga alltid"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibrera"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "U-energi-\nspar."
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Internet-delning"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Ljud"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Ljud"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Sekre-\ntessläge"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Energi-\nsparläge"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Tyst"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mobil-\ndata"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Plats"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Flyg-\nläge"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Autorotera"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Hjälp-\nljus"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "EM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Aviseringar"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "FM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Det går inte att ringa röstsamtal, videosamtal eller skicka SMS med %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Välj ett SIM-kort för utgående röstsamtal, videosamtal och SMS."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Utgående röstsamtal, videosamtal och SMS görs från SIM-kort %s."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Nej"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Det går inte att öka ljusstyrkan mer på grund av risk för överhettning."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Endast nödsamtal"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Endast nödsamtal"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Utomhus"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\nInternetd"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Ficklampa"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "En.-\nsparläge"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobil-\ndata"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Flyg-\nläge"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Auto-\nrotera"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Söker efter mobilnät ..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Sätt in SIM-kort för att få tillgång till nätverkstjänster."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Fråga alltid"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Det går inte att ansluta till mobilnät eftersom Flygläge är aktiverat. Anslut till ett Wi-Fi-nätverk istället eller inaktivera Flygläge och gör ett nytt försök."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Söker"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Kan inte öppna %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Utomhus"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Privat\nläge"
+
diff --git a/po/tr_TR.po b/po/tr_TR.po
new file mode 100755 (executable)
index 0000000..8446c05
--- /dev/null
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Hem Wi-Fi hem de Mobil AP aynı anda etkinleştirilemez. Mobil AP devre dışı bırakılsın mı?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Tümünü sil"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Gvnli mdu kptmk içn brya dknun."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "%s öğesi başlatılamıyor."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Sadece acil aramalar"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Aranıyor..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "SIM yok"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Servis yok"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "SIM kart geçersiz."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Yalnızca acil aramalar."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Açk hava"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Güvenli mod etkin"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Bildirimler (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Tümünü sil"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Bildirim"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Her zaman sor"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Titreşim"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Ultra güç\ntasarrufu"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Bağlantı"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Ses"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Ses"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Özel mod"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Güç\ntasarrufu"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Sessiz"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mobil\nveri"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Konum"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Uçuş\nmodu"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Otomatk döndür"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Yardımcı\nışık"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Bildirimler"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "%s kullanılarak sesli arama, görüntülü arama yapılamıyor ve metin mesajı gönderilemiyor."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Giden sesli aramalar, görüntülü aramalar ve metin mesajları için SIM kart seçin."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Giden sesli aramalar, görüntülü aramalar ve metin mesajları, %s SIM kart kullanılarak yapılacak."
+
+msgid "IDS_ST_SK_OK"
+msgstr "Tamam"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Hayır"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Aşırı ısınmadan dolayı ekran parlaklığı arttırılamaz."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Servis yok"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Yalnızca acil aramalar"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Dış mekan"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\nint. pyl."
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Fener"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Güç\ntasarrufu"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobil\nveri"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Uçuş\nmodu"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Oto.\ndöndür"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Mobil ağ taranıyor..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Şebeke servislerine erişmek için SIM kartını takın."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Her zaman sor"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Uçuş modu etkinken mobil ağlara bağlanılamaz. Bunun yerine bir Wi-Fi ağına bağlanın veya Uçuş modunu devre dışı bırakıp tekrar deneyin."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Aranıyor"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "%s açılamıyor."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Açk hava"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Özel\nmod"
+
diff --git a/po/uk.po b/po/uk.po
new file mode 100755 (executable)
index 0000000..5321f52
--- /dev/null
+++ b/po/uk.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Мережі Wi-Fi та Mobile AP не можна активувати одночасно. Вимкнути Mobile AP?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Очистити все"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Натис.тут, щоб вимк.безпеч.реж."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "Неможливо запустити %s."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Лише екстрені виклики"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Пошук..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "Відсутня SIM-карта"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Немає мережі"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Збій SIM-картки."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Лише екстрені виклики."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "На вул."
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Безпечний режим увімкнено"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Сповіщення (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Очист. всі"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Сповіщення"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Завжд.запитувати"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Вібрація"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "Реж.макс.\nенерг."
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Прив’язка"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Звук"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Звук"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Особист. режим"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Енерго\nзбереження"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Вимкнути\nзвук"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Мобільні\nдані"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Геодані"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Без\nзв’язку"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Автообертання"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Допом.\nпідсвіч."
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Сповіщення"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "Неможливо здійснювати голосові виклики, відеовиклики та надсилати SMS-повідомлення за допомогою %s."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Виберіть SIM-карту для здійснення вихідних голосових викликів, відеовикликів і надсилання SMS-повідомлень."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "За допомогою SIM-карти %s буде здійснено вихідні голосові виклики, відеовиклики та надіслано SMS-повідомлення."
+
+msgid "IDS_ST_SK_OK"
+msgstr "ОК"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Ні"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Неможливо збільшувати яскравість далі через перегрів телефону."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Немає служби"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Лише екстрені виклики"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "На вулиці"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Прив’яз.\nWi-Fi"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Ліхтар"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Енерго-\nзбереж."
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Мобільні\nдані"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Реж. без\nзв’язку"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Автообе-\nртання"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Пошук мобільної мережі..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Щоб отримати доступ до послуг мережі, вставте SIM-карту."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Завжди запитувати"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Неможливо підключитися до мобільних мереж, якщо ввімкнено режим без зв’язку. Підключіться натомість до мережі Wi-Fi або вимкніть режим без зв’язку та спробуйте ще раз."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Пошук"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "Неможливо запустити програму %s."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "На вул."
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Особист.\nрежим"
+
diff --git a/po/uz.po b/po/uz.po
new file mode 100755 (executable)
index 0000000..1725911
--- /dev/null
+++ b/po/uz.po
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Bir vaqtning o‘zida Wi-Fi va Mobile APni faollashtirib bo‘lmaydi. Mobile AP o‘chirilsinmi?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "Barini tozala"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "Xavfsiz rjm o‘ch. u-n teging."
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "%sni ishga tushirib bo‘lmaydi."
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "Faqat favqulodda qo‘ng‘ir"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "Qidirilmoqda..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "SIM-karta yo‘q"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "Xizmat yo‘q"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "Noto‘g‘ri SIM-karta."
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "Faqat favqulodda qo‘ng‘iroqlar."
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "Tashqari"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "Xavfsiz rejim yoqildi"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "Bildir-nomalar (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "Bar. tozal"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "Bildir-noma"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "Doim so‘ralsin"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "Vibra-\ntsiya"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "U. quvvat\ntejash"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "Bog‘lanish"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "Ovoz"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "Ovoz"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "Maxfiy rejim"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "Quvvat\ntejash"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "Ovozni\no‘chir"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "Mobil\ninternet"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "Joylashuv"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "Parvoz\nrejimi"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "Bluetooth"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "Avtomatik aylantir"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "Yordam\nchiroq"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "Bildirishnoma"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "%s yordamida ovozli, video qo‘ng‘iroqlarni amalga oshirib va matnli xabarlarni yuborib bo‘lmaydi."
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "Chiquvchi ovozli, video qo‘ng‘iroqlar va matnli xabarlar uchun SIM-kartani tanlang."
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "Chiquvchi ovozli qo‘ng‘iroqlar, video qo‘ng‘iroqlar va matnli xabarlar %s SIM-karta yordamida amalga oshiriladi."
+
+msgid "IDS_ST_SK_OK"
+msgstr "OK"
+
+msgid "IDS_ST_SK_NO"
+msgstr "Yo‘q"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "Telefon qizib ketgani sababli yorqinlikni ko‘paytirib bo‘lmaydi."
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "Xizmat yo‘q"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "Faqat favqulodda qo‘ng‘iroqlar"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "Tashqari"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\nbog‘lash"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "Fonar"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "Quvvat\ntejash"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "Mobil\nma’lumot"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "Parvoz\nrejimi"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "Bluetooth"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "Avto\naylantir"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "Mobil tarmoq qidirilmoqda..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "Tarmoq xizmatlariga kirish uchun SIM-karta kiriting."
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "Doim so‘ralsin"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "Parvoz rejimi yoqilganda, mobil tarmoqlarga ulanib bo‘lmaydi. Uning o‘rniga Wi-Fi tarmoqqa ulaning yoki Parvoz rejimini o‘chiring va qayta urinib ko‘ring."
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "Qidirilmoqda"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "%sni ochib bo‘lmayapti."
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "Tashqari"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "Maxfiy\nrejim"
+
diff --git a/po/zh_CN.po b/po/zh_CN.po
new file mode 100755 (executable)
index 0000000..352aa70
--- /dev/null
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Wi-Fi和移动接入无法同时启动。取消移动接入?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "全部清除"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "轻敲此处以禁用安全模式"
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "无法启动 %s。"
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "仅限紧急呼叫"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "正在搜索..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "无 SIM 卡"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "无服务"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "SIM 卡无效"
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "仅限紧急呼叫"
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "户外"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "安全模式已启用"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "通知 (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "全部清除"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "通知"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "总是询问"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "Wi-Fi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "振动"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "超级\n省电"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "网络共享"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "声音"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "声音"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "私密模式"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "省电\n模式"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "静音"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "移动\n数据"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "位置"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "飞行\n模式"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "蓝牙"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "自动旋转"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "辅助\n光"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "PM"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "通知"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "AM"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "无法使用 %s 拨打语音通话、视频通话和发送短信"
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "选择用于接收语音通话、视频通话和短信的 SIM 卡"
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "将使用 %s SIM 卡拨出语音通话、视频通话和发送短信。"
+
+msgid "IDS_ST_SK_OK"
+msgstr "确定"
+
+msgid "IDS_ST_SK_NO"
+msgstr "否"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "由于电话过热,无法再增加亮度。"
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "无服务"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "仅限紧急呼叫"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "户外"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\n网络共享"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "手电筒"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "省电"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "移动数据"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "飞行\n模式"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "蓝牙"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "自动旋转"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "正在扫描移动网络..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "插入 SIM 卡以访问网络服务。"
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "总是询问"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "飞行模式启用时无法连接至移动网络。改为连接至 Wi-Fi 网络或禁用飞行模式并重试。"
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "正在搜索"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "无法打开 %s"
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "户外"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "私密\n模式"
+
diff --git a/po/zh_HK.po b/po/zh_HK.po
new file mode 100755 (executable)
index 0000000..696a93d
--- /dev/null
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Wi-Fi和Mobile AP不可同時啟動。關閉Mobile AP嗎?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "全部清除"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "輕觸此處以停用安全模式。"
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "無法啟動 %s。"
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "僅可撥打緊急電話"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "正在搜尋..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "無 SIM 卡"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "無服務"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "SIM 卡無效"
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "只限緊急通話"
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "戶外"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "安全模式已啟用"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "通知 (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "全部清除"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "通知"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "總是詢問"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "WiFi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "震動"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "超級\n省電"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "網絡共享"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "聲音"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "聲音"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "私人模式"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "省電\n模式"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "靜音"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "流動\n數據"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "位置"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "飛行\n模式"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "藍牙"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "自動旋轉"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "輔助\n燈"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "下午"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "通知"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "上午"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "無法使用 %s 撥打語音通話、視像通話及發送文字訊息。"
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "選擇用於撥出語音通話、視像通話與發送文字訊息的 SIM 卡。"
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "將使用 %s SIM 卡撥打語音通話、視像通話及發送文字訊息。"
+
+msgid "IDS_ST_SK_OK"
+msgstr "確定"
+
+msgid "IDS_ST_SK_NO"
+msgstr "否"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "無法進一步提高亮度,因為手機過熱。"
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "無服務"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "僅可撥打緊急電話"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "戶外"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\n網絡共享"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "手電筒"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "省電"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "流動數據"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "飛行\n模式"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "藍牙"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "自動旋轉"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "正在掃描流動網絡..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "插入 SIM 卡以存取網絡服務。"
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "總是詢問"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "飛行模式啟用時無法連接至流動網絡。改為連接至 Wi-Fi 網絡或停用飛行模式並重試。"
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "正在搜尋"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "無法開啟 %s。"
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "戶外"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "私人\n模式"
+
diff --git a/po/zh_TW.po b/po/zh_TW.po
new file mode 100755 (executable)
index 0000000..b4a1d98
--- /dev/null
@@ -0,0 +1,186 @@
+msgid "IDS_WIFI_POP_BOTH_WI_FI_AND_MOBILE_AP_CANNOT_BE_ACTIVATED_AT_THE_SAME_TIME_DEACTIVATE_MOBILE_AP_Q"
+msgstr "Wi - Fi和行動AP不能在同一時間被啟動。停用行動AP?"
+
+msgid "IDS_TASKMGR_BUTTON_CLEAR_ALL"
+msgstr "全部清除"
+
+msgid "IDS_IDLE_SBODY_TAP_HERE_TO_DISABLE_SAFE_MODE_ABB"
+msgstr "輕觸此處以停用安全模式。"
+
+msgid "IDS_IDLE_POP_UNABLE_TO_LAUNCH_PS"
+msgstr "無法啟動 %s。"
+
+msgid "IDS_IDLE_MBODY_EMERGENCY_CALLS_ONLY"
+msgstr "僅可撥打緊急電話"
+
+msgid "IDS_IDLE_BODY_SEARCHING_ING"
+msgstr "正在搜尋..."
+
+msgid "IDS_IDLE_BODY_NO_SIM"
+msgstr "無 SIM 卡"
+
+msgid "IDS_IDLE_BODY_NO_SERVICE"
+msgstr "無服務"
+
+msgid "IDS_IDLE_BODY_INVALID_SIM_CARD"
+msgstr "SIM 卡無效"
+
+msgid "IDS_IDLE_BODY_EMERGENCY_CALLS_ONLY"
+msgstr "僅限緊急通話"
+
+msgid "IDS_QP_OPT_OUTDOORS_ABB"
+msgstr "戶外"
+
+msgid "IDS_QP_MBODY_SAFE_MODE_ENABLED"
+msgstr "已啟用安全模式"
+
+msgid "IDS_QP_HEADER_NOTIFICATIONS_HPD_ABB"
+msgstr "通知 (%d)"
+
+msgid "IDS_QP_HEADER_CLEAR_ALL_ABB"
+msgstr "全部清除"
+
+msgid "IDS_QP_BUTTON_NOTIFICATION"
+msgstr "通知"
+
+msgid "IDS_QP_BUTTON_ALWAYS_ASK_ABB"
+msgstr "每次詢問"
+
+msgid "IDS_QP_BUTTON2_WI_FI"
+msgstr "WiFi"
+
+msgid "IDS_QP_BUTTON2_VIBRATE"
+msgstr "震動"
+
+msgid "IDS_QP_BUTTON2_U_POWER_NSAVING_ABB"
+msgstr "超省電"
+
+msgid "IDS_QP_BUTTON2_TETHERING"
+msgstr "網路共享"
+
+msgid "IDS_QP_BUTTON2_SOUND_ABB"
+msgstr "音效"
+
+msgid "IDS_QP_BUTTON2_SOUND"
+msgstr "聲音"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_MODE"
+msgstr "私密模式"
+
+msgid "IDS_QP_BUTTON2_POWER_N_SAVING"
+msgstr "省電\n模式"
+
+msgid "IDS_QP_BUTTON2_MUTE_ABB"
+msgstr "靜音"
+
+msgid "IDS_QP_BUTTON2_MOBILE_DATA"
+msgstr "行動\n數據"
+
+msgid "IDS_QP_BUTTON2_LOCATION_ABB"
+msgstr "位置"
+
+msgid "IDS_QP_BUTTON2_FLIGHT_N_MODE"
+msgstr "飛航\n模式"
+
+msgid "IDS_QP_BUTTON2_BLUETOOTH"
+msgstr "藍牙"
+
+msgid "IDS_QP_BUTTON2_AUTO_ROTATE"
+msgstr "自動旋轉"
+
+msgid "IDS_QP_BUTTON2_ASSISTIVE_NLIGHT"
+msgstr "輔助\n燈光"
+
+msgid "IDS_QP_BODY_PM_ABB"
+msgstr "下午"
+
+msgid "IDS_QP_BODY_NOTIFICATIONS_ABB2"
+msgstr "通知"
+
+msgid "IDS_QP_BODY_AM_ABB"
+msgstr "上午"
+
+msgid "IDS_ST_TPOP_UNABLE_TO_MAKE_VOICE_CALLS_VIDEO_CALLS_AND_SEND_TEXT_MESSAGES_USING_PS"
+msgstr "無法使用 %s 撥打語音通話、視訊通話與傳送文字簡訊。"
+
+msgid "IDS_ST_TPOP_SELECT_SIM_CARD_FOR_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES"
+msgstr "選擇用於撥出語音通話、視訊通話與傳送文字簡訊的 SIM 卡。"
+
+msgid "IDS_ST_TPOP_OUTGOING_VOICE_CALLS_VIDEO_CALLS_AND_TEXT_MESSAGES_WILL_BE_MADE_USING_THE_PS_SIM_CARD"
+msgstr "將使用 %s SIM 卡撥出語音通話、視訊通話與傳送文字訊息。"
+
+msgid "IDS_ST_SK_OK"
+msgstr "確定"
+
+msgid "IDS_ST_SK_NO"
+msgstr "否"
+
+msgid "IDS_ST_POP_UNABLE_TO_INCREASE_BRIGHTNESS_FURTHER_BECAUSE_OF_PHONE_OVERHEATING"
+msgstr "無法增加螢幕亮度,因為手機過熱。"
+
+msgid "IDS_ST_NPBODY_NO_SERVICE"
+msgstr "無服務"
+
+msgid "IDS_ST_NPBODY_EMERGENCY_CALLS_ONLY_ABB"
+msgstr "僅可撥打緊急通話"
+
+msgid "IDS_ST_HEADER_OUTDOOR"
+msgstr "室外"
+
+msgid "IDS_ST_BUTTON2_WI_FI_NTETHERING"
+msgstr "Wi-Fi\n網路共享"
+
+msgid "IDS_ST_BUTTON2_WI_FI_ABB"
+msgstr "Wi-Fi"
+
+msgid "IDS_ST_BUTTON2_TORCH_ABB"
+msgstr "手電筒"
+
+msgid "IDS_ST_BUTTON2_POWER_NSAVING"
+msgstr "省電"
+
+msgid "IDS_ST_BUTTON2_MOBILE_NDATA"
+msgstr "行動數據"
+
+msgid "IDS_ST_BUTTON2_GPS_ABB"
+msgstr "GPS"
+
+msgid "IDS_ST_BUTTON2_FLIGHT_NMODE"
+msgstr "飛航模式"
+
+msgid "IDS_ST_BUTTON2_BLUETOOTH_ABB"
+msgstr "藍牙"
+
+msgid "IDS_ST_BUTTON2_AUTO_NROTATE"
+msgstr "自動旋轉"
+
+msgid "IDS_ST_BODY_SIM_2"
+msgstr "SIM 2"
+
+msgid "IDS_ST_BODY_SIM_1"
+msgstr "SIM 1"
+
+msgid "IDS_ST_BODY_SCANNING_FOR_MOBILE_NETWORK_ING_ABB"
+msgstr "正在掃描行動網路..."
+
+msgid "IDS_ST_BODY_INSERT_SIM_CARD_TO_ACCESS_NETWORK_SERVICES"
+msgstr "請插入 SIM 卡以存取網路服務。"
+
+msgid "IDS_ST_BODY_ALWAYS_ASK_ABB"
+msgstr "每次詢問"
+
+msgid "IDS_SCP_BODY_UNABLE_TO_CONNECT_TO_MOBILE_NETWORKS_WHILE_FLIGHT_MODE_IS_ENABLED_CONNECT_TO_A_WI_FI_NETWORK_INSTEAD_OR_DISABLE_FLIGHT_MODE_AND_TRY_AGAIN"
+msgstr "啟用飛航模式時無法連接行動網路。請改為連接至 Wi-Fi 或停用飛航模式並重試。"
+
+msgid "IDS_COM_BODY_SEARCHING"
+msgstr "正在搜尋"
+
+msgid "IDS_QP_TPOP_UNABLE_TO_OPEN_PS"
+msgstr "無法開啟 %s。"
+
+msgid "IDS_QP_OPT_OUTDOORS_M_OUTDOOR_MODE_ABB"
+msgstr "戶外"
+
+msgid "IDS_QP_BUTTON2_PRIVATE_NMODE_ABB"
+msgstr "隱私\n模式"
+
diff --git a/test/quickpanel_debug_util.c b/test/quickpanel_debug_util.c
new file mode 100755 (executable)
index 0000000..859506d
--- /dev/null
@@ -0,0 +1,99 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <unistd.h>
+#include <stdarg.h>
+#include <stdlib.h>
+#include <string.h>
+#include <stdio.h>
+#include <time.h>
+#include <Elementary.h>
+#include <common.h>
+#include <glib.h>
+
+#define LINEMAX 256
+#define MAXFILELEN     1048576 /* 32000 */
+#define LOGFILE "/tmp/quickpanel.log"
+
+void debug_printf(char *fmt, ...)
+{
+       va_list ap;
+       FILE *fd = 0;
+       char buf[LINEMAX] = { 0, };
+       char debugString[LINEMAX] = { 0, };
+
+       va_start(ap, fmt);
+       vsnprintf(buf, sizeof(buf), fmt, ap);
+       va_end(ap);
+       int fileLen = 0;
+       struct tm local_t;
+       time_t current_time = 0;
+       bzero((char *) &debugString, LINEMAX);
+       time(&current_time);
+       /* local_t = gmtime(&current_time); */
+       gmtime_r(&current_time, &local_t); /* for prevent 53555 */
+       int len = snprintf(debugString, sizeof(debugString),
+                       "[%d-%02d-%02d, %02d:%02d:%02d]: ", local_t.tm_year + 1900,
+                       local_t.tm_mon + 1, local_t.tm_mday, local_t.tm_hour,
+                       local_t.tm_min, local_t.tm_sec);
+       if (len == -1) {
+               return;
+       } else {
+               debugString[len] = '\0';
+       }
+       len = g_strlcat(debugString, buf, LINEMAX);
+       if (len >= LINEMAX) {
+               /* TODO:ERROR handling */
+               return;
+       } else {
+               debugString[len] = '\n';
+       }
+       /* FIXME this is for permission.. later we should fix and remove this... */
+       /* system("chmod 666 "LOGFILE); */
+       if ((fd = fopen(LOGFILE, "at+")) == NULL) {
+               DBG("File fopen fail for writing Pwlock information");
+       } else {
+               int pid = -1;
+               if (fwrite(debugString, strlen(debugString), 1, fd) < 1) {
+                       DBG("File fwrite fail for writing Pwlock information");
+                       fclose(fd);
+                       if ((pid = fork()) < 0) {
+                       } else if (pid == 0) {
+                               execl("/bin/rm", "rm", "-f", LOGFILE, (char *) 0);
+                       }
+                       /* system("rm -rf "LOGFILE);  */
+               } else {
+                       fseek(fd, 0l, SEEK_END);
+                       fileLen = ftell(fd);
+                       if (fileLen > MAXFILELEN) {
+                               fclose(fd);
+                               if ((pid = fork()) < 0) {
+                                       return;
+                               } else if (pid == 0) {
+                                       execl("/bin/rm", "rm", "-f", LOGFILE, (char *) 0);
+                               }
+                               /* system("rm -rf "LOGFILE); */
+                       } else {
+                               fclose(fd);
+                       }
+               }
+       }
+}
diff --git a/test/quickpanel_debug_util.h b/test/quickpanel_debug_util.h
new file mode 100755 (executable)
index 0000000..f27853b
--- /dev/null
@@ -0,0 +1,24 @@
+/*
+ * Copyright (c) 2009-2015 Samsung Electronics Co., Ltd All Rights Reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ */
+
+
+#ifndef __QUICKPANEL_DEBUG_UTIL_H_
+#define __QUICKPANEL_DEBUG_UTIL_H_
+
+extern void debug_printf(char *fmt, ...);
+
+#endif                         /* __QUICKPANEL_DEBUG_UTIL_H_ */