diff --git a/app/app.iml b/app/app.iml new file mode 100644 index 0000000..fb36cd6 --- /dev/null +++ b/app/app.iml @@ -0,0 +1,112 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/build.gradle b/app/build.gradle new file mode 100644 index 0000000..4a9383a --- /dev/null +++ b/app/build.gradle @@ -0,0 +1,20 @@ +apply plugin: 'com.android.application' + +android { + compileSdkVersion 19 + buildToolsVersion "27.0.3" + + defaultConfig { + applicationId "net.micode.notes" + minSdkVersion 14 + targetSdkVersion 14 + } + + buildTypes { + release { + minifyEnabled false + proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt' + } + } +} + diff --git a/app/build/generated/mockable-android-19.v3.jar b/app/build/generated/mockable-android-19.v3.jar new file mode 100644 index 0000000..735b3d8 Binary files /dev/null and b/app/build/generated/mockable-android-19.v3.jar differ diff --git a/app/build/generated/source/buildConfig/androidTest/debug/net/micode/notes/test/BuildConfig.java b/app/build/generated/source/buildConfig/androidTest/debug/net/micode/notes/test/BuildConfig.java new file mode 100644 index 0000000..888388c --- /dev/null +++ b/app/build/generated/source/buildConfig/androidTest/debug/net/micode/notes/test/BuildConfig.java @@ -0,0 +1,13 @@ +/** + * Automatically generated file. DO NOT MODIFY + */ +package net.micode.notes.test; + +public final class BuildConfig { + public static final boolean DEBUG = Boolean.parseBoolean("true"); + public static final String APPLICATION_ID = "net.micode.notes.test"; + public static final String BUILD_TYPE = "debug"; + public static final String FLAVOR = ""; + public static final int VERSION_CODE = -1; + public static final String VERSION_NAME = ""; +} diff --git a/app/build/generated/source/buildConfig/debug/net/micode/notes/BuildConfig.java b/app/build/generated/source/buildConfig/debug/net/micode/notes/BuildConfig.java new file mode 100644 index 0000000..7325eb3 --- /dev/null +++ b/app/build/generated/source/buildConfig/debug/net/micode/notes/BuildConfig.java @@ -0,0 +1,13 @@ +/** + * Automatically generated file. DO NOT MODIFY + */ +package net.micode.notes; + +public final class BuildConfig { + public static final boolean DEBUG = Boolean.parseBoolean("true"); + public static final String APPLICATION_ID = "net.micode.notes"; + public static final String BUILD_TYPE = "debug"; + public static final String FLAVOR = ""; + public static final int VERSION_CODE = 1; + public static final String VERSION_NAME = "0.1"; +} diff --git a/app/build/generated/source/buildConfig/release/net/micode/notes/BuildConfig.java b/app/build/generated/source/buildConfig/release/net/micode/notes/BuildConfig.java new file mode 100644 index 0000000..dbb34ba --- /dev/null +++ b/app/build/generated/source/buildConfig/release/net/micode/notes/BuildConfig.java @@ -0,0 +1,13 @@ +/** + * Automatically generated file. DO NOT MODIFY + */ +package net.micode.notes; + +public final class BuildConfig { + public static final boolean DEBUG = false; + public static final String APPLICATION_ID = "net.micode.notes"; + public static final String BUILD_TYPE = "release"; + public static final String FLAVOR = ""; + public static final int VERSION_CODE = 1; + public static final String VERSION_NAME = "0.1"; +} diff --git a/app/build/generated/source/r/androidTest/debug/net/micode/notes/test/R.java b/app/build/generated/source/r/androidTest/debug/net/micode/notes/test/R.java new file mode 100644 index 0000000..c4ebebf --- /dev/null +++ b/app/build/generated/source/r/androidTest/debug/net/micode/notes/test/R.java @@ -0,0 +1,11 @@ +/* AUTO-GENERATED FILE. DO NOT MODIFY. + * + * This class was automatically generated by the + * aapt tool from the resource data it found. It + * should not be modified by hand. + */ + +package net.micode.notes.test; + +public final class R { +} \ No newline at end of file diff --git a/app/build/generated/source/r/debug/net/micode/notes/R.java b/app/build/generated/source/r/debug/net/micode/notes/R.java new file mode 100644 index 0000000..945cc13 --- /dev/null +++ b/app/build/generated/source/r/debug/net/micode/notes/R.java @@ -0,0 +1,379 @@ +/* AUTO-GENERATED FILE. DO NOT MODIFY. + * + * This class was automatically generated by the + * aapt tool from the resource data it found. It + * should not be modified by hand. + */ + +package net.micode.notes; + +public final class R { + public static final class array { + public static final int format_for_exported_note=0x7f010000; + public static final int menu_share_ways=0x7f010001; + } + public static final class color { + public static final int primary_text_dark=0x7f020000; + public static final int secondary_text_dark=0x7f020001; + public static final int user_query_highlight=0x7f020002; + } + public static final class dimen { + public static final int text_font_size_large=0x7f030000; + public static final int text_font_size_medium=0x7f030001; + public static final int text_font_size_normal=0x7f030002; + public static final int text_font_size_small=0x7f030003; + public static final int text_font_size_super=0x7f030004; + } + public static final class drawable { + public static final int attention0=0x7f040000; + public static final int attention1=0x7f040001; + public static final int attention2=0x7f040002; + public static final int attention3=0x7f040003; + public static final int attention4=0x7f040004; + public static final int attention5=0x7f040005; + public static final int bg_btn_set_color=0x7f040006; + public static final int bg_color_btn_mask=0x7f040007; + public static final int call_record=0x7f040008; + public static final int cancel=0x7f040009; + public static final int clock=0x7f04000a; + public static final int delete=0x7f04000b; + public static final int dropdown_icon=0x7f04000c; + public static final int edit_blue=0x7f04000d; + public static final int edit_green=0x7f04000e; + public static final int edit_red=0x7f04000f; + public static final int edit_title_blue=0x7f040010; + public static final int edit_title_green=0x7f040011; + public static final int edit_title_red=0x7f040012; + public static final int edit_title_white=0x7f040013; + public static final int edit_title_yellow=0x7f040014; + public static final int edit_white=0x7f040015; + public static final int edit_yellow=0x7f040016; + public static final int font_large=0x7f040017; + public static final int font_normal=0x7f040018; + public static final int font_size_selector_bg=0x7f040019; + public static final int font_small=0x7f04001a; + public static final int font_super=0x7f04001b; + public static final int icon_app=0x7f04001c; + public static final int list_background=0x7f04001d; + public static final int list_blue_down=0x7f04001e; + public static final int list_blue_middle=0x7f04001f; + public static final int list_blue_single=0x7f040020; + public static final int list_blue_up=0x7f040021; + public static final int list_folder=0x7f040022; + public static final int list_footer_bg=0x7f040023; + public static final int list_green_down=0x7f040024; + public static final int list_green_middle=0x7f040025; + public static final int list_green_single=0x7f040026; + public static final int list_green_up=0x7f040027; + public static final int list_red_down=0x7f040028; + public static final int list_red_middle=0x7f040029; + public static final int list_red_single=0x7f04002a; + public static final int list_red_up=0x7f04002b; + public static final int list_white_down=0x7f04002c; + public static final int list_white_middle=0x7f04002d; + public static final int list_white_single=0x7f04002e; + public static final int list_white_up=0x7f04002f; + public static final int list_yellow_down=0x7f040030; + public static final int list_yellow_middle=0x7f040031; + public static final int list_yellow_single=0x7f040032; + public static final int list_yellow_up=0x7f040033; + public static final int lock=0x7f040034; + public static final int menu_delete=0x7f040035; + public static final int menu_move=0x7f040036; + public static final int new_note=0x7f040037; + public static final int new_note_normal=0x7f040038; + public static final int new_note_pressed=0x7f040039; + public static final int note_edit_color_selector_panel=0x7f04003a; + public static final int notification=0x7f04003b; + public static final int search_result=0x7f04003c; + public static final int selected=0x7f04003d; + public static final int selector_grid=0x7f04003e; + public static final int selector_key_del=0x7f04003f; + public static final int title_alert=0x7f040040; + public static final int title_bar_bg=0x7f040041; + public static final int widget_2x_blue=0x7f040042; + public static final int widget_2x_green=0x7f040043; + public static final int widget_2x_red=0x7f040044; + public static final int widget_2x_white=0x7f040045; + public static final int widget_2x_yellow=0x7f040046; + public static final int widget_4x_blue=0x7f040047; + public static final int widget_4x_green=0x7f040048; + public static final int widget_4x_red=0x7f040049; + public static final int widget_4x_white=0x7f04004a; + public static final int widget_4x_yellow=0x7f04004b; + } + public static final class id { + public static final int Blue=0x7f050000; + public static final int Button01=0x7f050001; + public static final int Button02=0x7f050002; + public static final int Button03=0x7f050003; + public static final int Button04=0x7f050004; + public static final int Button06=0x7f050005; + public static final int Button07=0x7f050006; + public static final int Button08=0x7f050007; + public static final int ButtonR=0x7f050008; + public static final int Green=0x7f050009; + public static final int Red=0x7f05000a; + public static final int TableLayout01=0x7f05000b; + public static final int TableLayout02=0x7f05000c; + public static final int account_dialog_subtitle=0x7f05000d; + public static final int account_dialog_title=0x7f05000e; + public static final int action_select_all=0x7f05000f; + public static final int amPm=0x7f050010; + public static final int btn_keys=0x7f050011; + public static final int btn_new_note=0x7f050012; + public static final int btn_set_bg_color=0x7f050013; + public static final int cb_edit_item=0x7f050014; + public static final int date=0x7f050015; + public static final int delete=0x7f050016; + public static final int et_edit_text=0x7f050017; + public static final int et_foler_name=0x7f050018; + public static final int font_size_selector=0x7f050019; + public static final int gv_keyboard=0x7f05001a; + public static final int hour=0x7f05001b; + public static final int img_cancel=0x7f05001c; + public static final int iv_alert_icon=0x7f05001d; + public static final int iv_bg_blue=0x7f05001e; + public static final int iv_bg_blue_select=0x7f05001f; + public static final int iv_bg_green=0x7f050020; + public static final int iv_bg_green_select=0x7f050021; + public static final int iv_bg_red=0x7f050022; + public static final int iv_bg_red_select=0x7f050023; + public static final int iv_bg_white=0x7f050024; + public static final int iv_bg_white_select=0x7f050025; + public static final int iv_bg_yellow=0x7f050026; + public static final int iv_bg_yellow_select=0x7f050027; + public static final int iv_importance=0x7f050028; + public static final int iv_large_select=0x7f050029; + public static final int iv_lock_icon=0x7f05002a; + public static final int iv_medium_select=0x7f05002b; + public static final int iv_small_select=0x7f05002c; + public static final int iv_super_select=0x7f05002d; + public static final int linear_pass=0x7f05002e; + public static final int ll_font_large=0x7f05002f; + public static final int ll_font_normal=0x7f050030; + public static final int ll_font_small=0x7f050031; + public static final int ll_font_super=0x7f050032; + public static final int menu_alert=0x7f050033; + public static final int menu_delete=0x7f050034; + public static final int menu_delete_encrypt=0x7f050035; + public static final int menu_delete_remind=0x7f050036; + public static final int menu_encrypt=0x7f050037; + public static final int menu_export_text=0x7f050038; + public static final int menu_font_size=0x7f050039; + public static final int menu_list_mode=0x7f05003a; + public static final int menu_new_folder=0x7f05003b; + public static final int menu_new_note=0x7f05003c; + public static final int menu_search=0x7f05003d; + public static final int menu_send_to_desktop=0x7f05003e; + public static final int menu_set_importance=0x7f05003f; + public static final int menu_setting=0x7f050040; + public static final int menu_share=0x7f050041; + public static final int menu_sync=0x7f050042; + public static final int minute=0x7f050043; + public static final int move=0x7f050044; + public static final int navigation_bar=0x7f050045; + public static final int note_bg_color_selector=0x7f050046; + public static final int note_decryption=0x7f050047; + public static final int note_edit_list=0x7f050048; + public static final int note_edit_view=0x7f050049; + public static final int note_item=0x7f05004a; + public static final int note_title=0x7f05004b; + public static final int notes_list=0x7f05004c; + public static final int prefenerece_sync_status_textview=0x7f05004d; + public static final int preference_sync_button=0x7f05004e; + public static final int ratingBar=0x7f05004f; + public static final int selection_menu=0x7f050050; + public static final int sv_note_edit=0x7f050051; + public static final int textCount=0x7f050052; + public static final int tv_alert_date=0x7f050053; + public static final int tv_folder_name=0x7f050054; + public static final int tv_modified_date=0x7f050055; + public static final int tv_name=0x7f050056; + public static final int tv_pass1=0x7f050057; + public static final int tv_pass2=0x7f050058; + public static final int tv_pass3=0x7f050059; + public static final int tv_pass4=0x7f05005a; + public static final int tv_time=0x7f05005b; + public static final int tv_title=0x7f05005c; + public static final int tv_title_bar=0x7f05005d; + public static final int widget_bg_image=0x7f05005e; + public static final int widget_text=0x7f05005f; + } + public static final class layout { + public static final int account_dialog_title=0x7f060000; + public static final int add_account_text=0x7f060001; + public static final int current_password_head=0x7f060002; + public static final int datetime_picker=0x7f060003; + public static final int dialog_edit_text=0x7f060004; + public static final int folder_list_item=0x7f060005; + public static final int homepage=0x7f060006; + public static final int item_grid=0x7f060007; + public static final int layout=0x7f060008; + public static final int layout2=0x7f060009; + public static final int new_password_head=0x7f06000a; + public static final int note_decryption=0x7f06000b; + public static final int note_edit=0x7f06000c; + public static final int note_edit_list_item=0x7f06000d; + public static final int note_encryption=0x7f06000e; + public static final int note_encryption_repeat=0x7f06000f; + public static final int note_importance=0x7f060010; + public static final int note_item=0x7f060011; + public static final int note_list=0x7f060012; + public static final int note_list_dropdown_menu=0x7f060013; + public static final int note_list_footer=0x7f060014; + public static final int password_item=0x7f060015; + public static final int repeat_password_head=0x7f060016; + public static final int settings_header=0x7f060017; + public static final int widget_2x=0x7f060018; + public static final int widget_4x=0x7f060019; + } + public static final class menu { + public static final int call_note_edit=0x7f070000; + public static final int call_record_folder=0x7f070001; + public static final int note_edit=0x7f070002; + public static final int note_list=0x7f070003; + public static final int note_list_dropdown=0x7f070004; + public static final int note_list_options=0x7f070005; + public static final int sub_folder=0x7f070006; + } + public static final class plurals { + public static final int search_results_title=0x7f080000; + } + public static final class raw { + public static final int introduction=0x7f090000; + } + public static final class string { + public static final int alert_message_decrypt=0x7f0a0000; + public static final int alert_message_decrypt_error=0x7f0a0001; + public static final int alert_message_delete_folder=0x7f0a0002; + public static final int alert_message_delete_note=0x7f0a0003; + public static final int alert_message_delete_notes=0x7f0a0004; + public static final int alert_message_encrypt=0x7f0a0005; + public static final int alert_message_encrypt_error=0x7f0a0006; + public static final int alert_message_remove_encrypt=0x7f0a0007; + public static final int alert_title_delete=0x7f0a0008; + public static final int alert_title_encrypt=0x7f0a0009; + public static final int alert_title_importance=0x7f0a000a; + public static final int app_name=0x7f0a000b; + public static final int app_widget2x2=0x7f0a000c; + public static final int app_widget4x4=0x7f0a000d; + public static final int button_delete=0x7f0a000e; + public static final int call_record_folder_name=0x7f0a000f; + public static final int datetime_dialog_cancel=0x7f0a0010; + public static final int datetime_dialog_ok=0x7f0a0011; + public static final int delete_remind_time_message=0x7f0a0012; + public static final int error_note_empty_for_clock=0x7f0a0013; + public static final int error_note_empty_for_send_to_desktop=0x7f0a0014; + public static final int error_note_not_exist=0x7f0a0015; + public static final int error_sdcard_export=0x7f0a0016; + public static final int error_sdcard_unmounted=0x7f0a0017; + public static final int error_sync_cancelled=0x7f0a0018; + public static final int error_sync_internal=0x7f0a0019; + public static final int error_sync_network=0x7f0a001a; + public static final int failed_sdcard_export=0x7f0a001b; + public static final int file_name_txt_format=0x7f0a001c; + public static final int file_path=0x7f0a001d; + public static final int folder_exist=0x7f0a001e; + public static final int format_date_ymd=0x7f0a001f; + public static final int format_datetime_mdhm=0x7f0a0020; + public static final int format_exported_file_location=0x7f0a0021; + public static final int format_folder_files_count=0x7f0a0022; + public static final int format_move_notes_to_folder=0x7f0a0023; + public static final int hint_foler_name=0x7f0a0024; + public static final int info_note_enter_desktop=0x7f0a0025; + public static final int menu_alert=0x7f0a0026; + public static final int menu_create_folder=0x7f0a0027; + public static final int menu_delete=0x7f0a0028; + public static final int menu_deselect_all=0x7f0a0029; + public static final int menu_encrypt=0x7f0a002a; + public static final int menu_export_text=0x7f0a002b; + public static final int menu_folder_change_name=0x7f0a002c; + public static final int menu_folder_delete=0x7f0a002d; + public static final int menu_folder_view=0x7f0a002e; + public static final int menu_font_large=0x7f0a002f; + public static final int menu_font_normal=0x7f0a0030; + public static final int menu_font_size=0x7f0a0031; + public static final int menu_font_small=0x7f0a0032; + public static final int menu_font_super=0x7f0a0033; + public static final int menu_list_mode=0x7f0a0034; + public static final int menu_move=0x7f0a0035; + public static final int menu_move_parent_folder=0x7f0a0036; + public static final int menu_normal_mode=0x7f0a0037; + public static final int menu_remove_encrypt=0x7f0a0038; + public static final int menu_remove_remind=0x7f0a0039; + public static final int menu_search=0x7f0a003a; + public static final int menu_select_all=0x7f0a003b; + public static final int menu_select_none=0x7f0a003c; + public static final int menu_select_title=0x7f0a003d; + public static final int menu_send_to_desktop=0x7f0a003e; + public static final int menu_set_importance=0x7f0a003f; + public static final int menu_setting=0x7f0a0040; + public static final int menu_share=0x7f0a0041; + public static final int menu_sync=0x7f0a0042; + public static final int menu_sync_cancel=0x7f0a0043; + public static final int menu_title_select_folder=0x7f0a0044; + public static final int note_alert_expired=0x7f0a0045; + public static final int note_link_email=0x7f0a0046; + public static final int note_link_other=0x7f0a0047; + public static final int note_link_tel=0x7f0a0048; + public static final int note_link_web=0x7f0a0049; + public static final int notealert_enter=0x7f0a004a; + public static final int notealert_ok=0x7f0a004b; + public static final int notelist_menu_new=0x7f0a004c; + public static final int notelist_string_info=0x7f0a004d; + public static final int preferences_account_summary=0x7f0a004e; + public static final int preferences_account_title=0x7f0a004f; + public static final int preferences_add_account=0x7f0a0050; + public static final int preferences_bg_random_appear_title=0x7f0a0051; + public static final int preferences_button_sync_cancel=0x7f0a0052; + public static final int preferences_button_sync_immediately=0x7f0a0053; + public static final int preferences_dialog_change_account_title=0x7f0a0054; + public static final int preferences_dialog_change_account_warn_msg=0x7f0a0055; + public static final int preferences_dialog_select_account_tips=0x7f0a0056; + public static final int preferences_dialog_select_account_title=0x7f0a0057; + public static final int preferences_last_sync_time=0x7f0a0058; + public static final int preferences_last_sync_time_format=0x7f0a0059; + public static final int preferences_menu_cancel=0x7f0a005a; + public static final int preferences_menu_change_account=0x7f0a005b; + public static final int preferences_menu_remove_account=0x7f0a005c; + public static final int preferences_title=0x7f0a005d; + public static final int preferences_toast_cannot_change_account=0x7f0a005e; + public static final int preferences_toast_success_set_accout=0x7f0a005f; + public static final int search=0x7f0a0060; + public static final int search_hint=0x7f0a0061; + public static final int search_label=0x7f0a0062; + public static final int search_setting_description=0x7f0a0063; + public static final int set_remind_time_message=0x7f0a0064; + public static final int success_sdcard_export=0x7f0a0065; + public static final int success_sync_account=0x7f0a0066; + public static final int sync_progress_init_list=0x7f0a0067; + public static final int sync_progress_login=0x7f0a0068; + public static final int sync_progress_syncing=0x7f0a0069; + public static final int ticker_cancel=0x7f0a006a; + public static final int ticker_fail=0x7f0a006b; + public static final int ticker_success=0x7f0a006c; + public static final int ticker_syncing=0x7f0a006d; + public static final int widget_havenot_content=0x7f0a006e; + public static final int widget_under_visit_mode=0x7f0a006f; + } + public static final class style { + public static final int HighlightTextAppearancePrimary=0x7f0b0000; + public static final int HighlightTextAppearanceSecondary=0x7f0b0001; + public static final int NoteActionBarStyle=0x7f0b0002; + public static final int NoteTheme=0x7f0b0003; + public static final int TextAppearanceLarge=0x7f0b0004; + public static final int TextAppearanceMedium=0x7f0b0005; + public static final int TextAppearanceNormal=0x7f0b0006; + public static final int TextAppearancePrimaryItem=0x7f0b0007; + public static final int TextAppearanceSecondaryItem=0x7f0b0008; + public static final int TextAppearanceSuper=0x7f0b0009; + public static final int TextAppearanceUnderMenuIcon=0x7f0b000a; + } + public static final class xml { + public static final int preferences=0x7f0c0000; + public static final int searchable=0x7f0c0001; + public static final int widget_2x_info=0x7f0c0002; + public static final int widget_4x_info=0x7f0c0003; + } +} \ No newline at end of file diff --git a/app/build/generated/source/r/release/net/micode/notes/R.java b/app/build/generated/source/r/release/net/micode/notes/R.java new file mode 100644 index 0000000..3781701 --- /dev/null +++ b/app/build/generated/source/r/release/net/micode/notes/R.java @@ -0,0 +1,318 @@ +/* AUTO-GENERATED FILE. DO NOT MODIFY. + * + * This class was automatically generated by the + * aapt tool from the resource data it found. It + * should not be modified by hand. + */ + +package net.micode.notes; + +public final class R { + public static final class array { + public static final int format_for_exported_note=0x7f010000; + public static final int menu_share_ways=0x7f010001; + } + public static final class color { + public static final int primary_text_dark=0x7f020000; + public static final int secondary_text_dark=0x7f020001; + public static final int user_query_highlight=0x7f020002; + } + public static final class dimen { + public static final int text_font_size_large=0x7f030000; + public static final int text_font_size_medium=0x7f030001; + public static final int text_font_size_normal=0x7f030002; + public static final int text_font_size_small=0x7f030003; + public static final int text_font_size_super=0x7f030004; + } + public static final class drawable { + public static final int bg_btn_set_color=0x7f040000; + public static final int bg_color_btn_mask=0x7f040001; + public static final int call_record=0x7f040002; + public static final int clock=0x7f040003; + public static final int delete=0x7f040004; + public static final int dropdown_icon=0x7f040005; + public static final int edit_blue=0x7f040006; + public static final int edit_green=0x7f040007; + public static final int edit_red=0x7f040008; + public static final int edit_title_blue=0x7f040009; + public static final int edit_title_green=0x7f04000a; + public static final int edit_title_red=0x7f04000b; + public static final int edit_title_white=0x7f04000c; + public static final int edit_title_yellow=0x7f04000d; + public static final int edit_white=0x7f04000e; + public static final int edit_yellow=0x7f04000f; + public static final int font_large=0x7f040010; + public static final int font_normal=0x7f040011; + public static final int font_size_selector_bg=0x7f040012; + public static final int font_small=0x7f040013; + public static final int font_super=0x7f040014; + public static final int icon_app=0x7f040015; + public static final int list_background=0x7f040016; + public static final int list_blue_down=0x7f040017; + public static final int list_blue_middle=0x7f040018; + public static final int list_blue_single=0x7f040019; + public static final int list_blue_up=0x7f04001a; + public static final int list_folder=0x7f04001b; + public static final int list_footer_bg=0x7f04001c; + public static final int list_green_down=0x7f04001d; + public static final int list_green_middle=0x7f04001e; + public static final int list_green_single=0x7f04001f; + public static final int list_green_up=0x7f040020; + public static final int list_red_down=0x7f040021; + public static final int list_red_middle=0x7f040022; + public static final int list_red_single=0x7f040023; + public static final int list_red_up=0x7f040024; + public static final int list_white_down=0x7f040025; + public static final int list_white_middle=0x7f040026; + public static final int list_white_single=0x7f040027; + public static final int list_white_up=0x7f040028; + public static final int list_yellow_down=0x7f040029; + public static final int list_yellow_middle=0x7f04002a; + public static final int list_yellow_single=0x7f04002b; + public static final int list_yellow_up=0x7f04002c; + public static final int menu_delete=0x7f04002d; + public static final int menu_move=0x7f04002e; + public static final int new_note=0x7f04002f; + public static final int new_note_normal=0x7f040030; + public static final int new_note_pressed=0x7f040031; + public static final int note_edit_color_selector_panel=0x7f040032; + public static final int notification=0x7f040033; + public static final int search_result=0x7f040034; + public static final int selected=0x7f040035; + public static final int title_alert=0x7f040036; + public static final int title_bar_bg=0x7f040037; + public static final int widget_2x_blue=0x7f040038; + public static final int widget_2x_green=0x7f040039; + public static final int widget_2x_red=0x7f04003a; + public static final int widget_2x_white=0x7f04003b; + public static final int widget_2x_yellow=0x7f04003c; + public static final int widget_4x_blue=0x7f04003d; + public static final int widget_4x_green=0x7f04003e; + public static final int widget_4x_red=0x7f04003f; + public static final int widget_4x_white=0x7f040040; + public static final int widget_4x_yellow=0x7f040041; + } + public static final class id { + public static final int account_dialog_subtitle=0x7f050000; + public static final int account_dialog_title=0x7f050001; + public static final int action_select_all=0x7f050002; + public static final int amPm=0x7f050003; + public static final int btn_new_note=0x7f050004; + public static final int btn_set_bg_color=0x7f050005; + public static final int cb_edit_item=0x7f050006; + public static final int date=0x7f050007; + public static final int delete=0x7f050008; + public static final int et_edit_text=0x7f050009; + public static final int et_foler_name=0x7f05000a; + public static final int font_size_selector=0x7f05000b; + public static final int hour=0x7f05000c; + public static final int iv_alert_icon=0x7f05000d; + public static final int iv_bg_blue=0x7f05000e; + public static final int iv_bg_blue_select=0x7f05000f; + public static final int iv_bg_green=0x7f050010; + public static final int iv_bg_green_select=0x7f050011; + public static final int iv_bg_red=0x7f050012; + public static final int iv_bg_red_select=0x7f050013; + public static final int iv_bg_white=0x7f050014; + public static final int iv_bg_white_select=0x7f050015; + public static final int iv_bg_yellow=0x7f050016; + public static final int iv_bg_yellow_select=0x7f050017; + public static final int iv_large_select=0x7f050018; + public static final int iv_medium_select=0x7f050019; + public static final int iv_small_select=0x7f05001a; + public static final int iv_super_select=0x7f05001b; + public static final int ll_font_large=0x7f05001c; + public static final int ll_font_normal=0x7f05001d; + public static final int ll_font_small=0x7f05001e; + public static final int ll_font_super=0x7f05001f; + public static final int menu_alert=0x7f050020; + public static final int menu_delete=0x7f050021; + public static final int menu_delete_remind=0x7f050022; + public static final int menu_export_text=0x7f050023; + public static final int menu_font_size=0x7f050024; + public static final int menu_list_mode=0x7f050025; + public static final int menu_new_folder=0x7f050026; + public static final int menu_new_note=0x7f050027; + public static final int menu_search=0x7f050028; + public static final int menu_send_to_desktop=0x7f050029; + public static final int menu_setting=0x7f05002a; + public static final int menu_share=0x7f05002b; + public static final int menu_sync=0x7f05002c; + public static final int minute=0x7f05002d; + public static final int move=0x7f05002e; + public static final int navigation_bar=0x7f05002f; + public static final int note_bg_color_selector=0x7f050030; + public static final int note_edit_list=0x7f050031; + public static final int note_edit_view=0x7f050032; + public static final int note_item=0x7f050033; + public static final int note_title=0x7f050034; + public static final int notes_list=0x7f050035; + public static final int prefenerece_sync_status_textview=0x7f050036; + public static final int preference_sync_button=0x7f050037; + public static final int selection_menu=0x7f050038; + public static final int sv_note_edit=0x7f050039; + public static final int tv_alert_date=0x7f05003a; + public static final int tv_folder_name=0x7f05003b; + public static final int tv_modified_date=0x7f05003c; + public static final int tv_name=0x7f05003d; + public static final int tv_time=0x7f05003e; + public static final int tv_title=0x7f05003f; + public static final int tv_title_bar=0x7f050040; + public static final int widget_bg_image=0x7f050041; + public static final int widget_text=0x7f050042; + } + public static final class layout { + public static final int account_dialog_title=0x7f060000; + public static final int add_account_text=0x7f060001; + public static final int datetime_picker=0x7f060002; + public static final int dialog_edit_text=0x7f060003; + public static final int folder_list_item=0x7f060004; + public static final int note_edit=0x7f060005; + public static final int note_edit_list_item=0x7f060006; + public static final int note_item=0x7f060007; + public static final int note_list=0x7f060008; + public static final int note_list_dropdown_menu=0x7f060009; + public static final int note_list_footer=0x7f06000a; + public static final int settings_header=0x7f06000b; + public static final int widget_2x=0x7f06000c; + public static final int widget_4x=0x7f06000d; + } + public static final class menu { + public static final int call_note_edit=0x7f070000; + public static final int call_record_folder=0x7f070001; + public static final int note_edit=0x7f070002; + public static final int note_list=0x7f070003; + public static final int note_list_dropdown=0x7f070004; + public static final int note_list_options=0x7f070005; + public static final int sub_folder=0x7f070006; + } + public static final class plurals { + public static final int search_results_title=0x7f080000; + } + public static final class raw { + public static final int introduction=0x7f090000; + } + public static final class string { + public static final int alert_message_delete_folder=0x7f0a0000; + public static final int alert_message_delete_note=0x7f0a0001; + public static final int alert_message_delete_notes=0x7f0a0002; + public static final int alert_title_delete=0x7f0a0003; + public static final int app_name=0x7f0a0004; + public static final int app_widget2x2=0x7f0a0005; + public static final int app_widget4x4=0x7f0a0006; + public static final int button_delete=0x7f0a0007; + public static final int call_record_folder_name=0x7f0a0008; + public static final int datetime_dialog_cancel=0x7f0a0009; + public static final int datetime_dialog_ok=0x7f0a000a; + public static final int delete_remind_time_message=0x7f0a000b; + public static final int error_note_empty_for_clock=0x7f0a000c; + public static final int error_note_empty_for_send_to_desktop=0x7f0a000d; + public static final int error_note_not_exist=0x7f0a000e; + public static final int error_sdcard_export=0x7f0a000f; + public static final int error_sdcard_unmounted=0x7f0a0010; + public static final int error_sync_cancelled=0x7f0a0011; + public static final int error_sync_internal=0x7f0a0012; + public static final int error_sync_network=0x7f0a0013; + public static final int failed_sdcard_export=0x7f0a0014; + public static final int file_name_txt_format=0x7f0a0015; + public static final int file_path=0x7f0a0016; + public static final int folder_exist=0x7f0a0017; + public static final int format_date_ymd=0x7f0a0018; + public static final int format_datetime_mdhm=0x7f0a0019; + public static final int format_exported_file_location=0x7f0a001a; + public static final int format_folder_files_count=0x7f0a001b; + public static final int format_move_notes_to_folder=0x7f0a001c; + public static final int hint_foler_name=0x7f0a001d; + public static final int info_note_enter_desktop=0x7f0a001e; + public static final int menu_alert=0x7f0a001f; + public static final int menu_create_folder=0x7f0a0020; + public static final int menu_delete=0x7f0a0021; + public static final int menu_deselect_all=0x7f0a0022; + public static final int menu_export_text=0x7f0a0023; + public static final int menu_folder_change_name=0x7f0a0024; + public static final int menu_folder_delete=0x7f0a0025; + public static final int menu_folder_view=0x7f0a0026; + public static final int menu_font_large=0x7f0a0027; + public static final int menu_font_normal=0x7f0a0028; + public static final int menu_font_size=0x7f0a0029; + public static final int menu_font_small=0x7f0a002a; + public static final int menu_font_super=0x7f0a002b; + public static final int menu_list_mode=0x7f0a002c; + public static final int menu_move=0x7f0a002d; + public static final int menu_move_parent_folder=0x7f0a002e; + public static final int menu_normal_mode=0x7f0a002f; + public static final int menu_remove_remind=0x7f0a0030; + public static final int menu_search=0x7f0a0031; + public static final int menu_select_all=0x7f0a0032; + public static final int menu_select_none=0x7f0a0033; + public static final int menu_select_title=0x7f0a0034; + public static final int menu_send_to_desktop=0x7f0a0035; + public static final int menu_setting=0x7f0a0036; + public static final int menu_share=0x7f0a0037; + public static final int menu_sync=0x7f0a0038; + public static final int menu_sync_cancel=0x7f0a0039; + public static final int menu_title_select_folder=0x7f0a003a; + public static final int note_alert_expired=0x7f0a003b; + public static final int note_link_email=0x7f0a003c; + public static final int note_link_other=0x7f0a003d; + public static final int note_link_tel=0x7f0a003e; + public static final int note_link_web=0x7f0a003f; + public static final int notealert_enter=0x7f0a0040; + public static final int notealert_ok=0x7f0a0041; + public static final int notelist_menu_new=0x7f0a0042; + public static final int notelist_string_info=0x7f0a0043; + public static final int preferences_account_summary=0x7f0a0044; + public static final int preferences_account_title=0x7f0a0045; + public static final int preferences_add_account=0x7f0a0046; + public static final int preferences_bg_random_appear_title=0x7f0a0047; + public static final int preferences_button_sync_cancel=0x7f0a0048; + public static final int preferences_button_sync_immediately=0x7f0a0049; + public static final int preferences_dialog_change_account_title=0x7f0a004a; + public static final int preferences_dialog_change_account_warn_msg=0x7f0a004b; + public static final int preferences_dialog_select_account_tips=0x7f0a004c; + public static final int preferences_dialog_select_account_title=0x7f0a004d; + public static final int preferences_last_sync_time=0x7f0a004e; + public static final int preferences_last_sync_time_format=0x7f0a004f; + public static final int preferences_menu_cancel=0x7f0a0050; + public static final int preferences_menu_change_account=0x7f0a0051; + public static final int preferences_menu_remove_account=0x7f0a0052; + public static final int preferences_title=0x7f0a0053; + public static final int preferences_toast_cannot_change_account=0x7f0a0054; + public static final int preferences_toast_success_set_accout=0x7f0a0055; + public static final int search=0x7f0a0056; + public static final int search_hint=0x7f0a0057; + public static final int search_label=0x7f0a0058; + public static final int search_setting_description=0x7f0a0059; + public static final int set_remind_time_message=0x7f0a005a; + public static final int success_sdcard_export=0x7f0a005b; + public static final int success_sync_account=0x7f0a005c; + public static final int sync_progress_init_list=0x7f0a005d; + public static final int sync_progress_login=0x7f0a005e; + public static final int sync_progress_syncing=0x7f0a005f; + public static final int ticker_cancel=0x7f0a0060; + public static final int ticker_fail=0x7f0a0061; + public static final int ticker_success=0x7f0a0062; + public static final int ticker_syncing=0x7f0a0063; + public static final int widget_havenot_content=0x7f0a0064; + public static final int widget_under_visit_mode=0x7f0a0065; + } + public static final class style { + public static final int HighlightTextAppearancePrimary=0x7f0b0000; + public static final int HighlightTextAppearanceSecondary=0x7f0b0001; + public static final int NoteActionBarStyle=0x7f0b0002; + public static final int NoteTheme=0x7f0b0003; + public static final int TextAppearanceLarge=0x7f0b0004; + public static final int TextAppearanceMedium=0x7f0b0005; + public static final int TextAppearanceNormal=0x7f0b0006; + public static final int TextAppearancePrimaryItem=0x7f0b0007; + public static final int TextAppearanceSecondaryItem=0x7f0b0008; + public static final int TextAppearanceSuper=0x7f0b0009; + public static final int TextAppearanceUnderMenuIcon=0x7f0b000a; + } + public static final class xml { + public static final int preferences=0x7f0c0000; + public static final int searchable=0x7f0c0001; + public static final int widget_2x_info=0x7f0c0002; + public static final int widget_4x_info=0x7f0c0003; + } +} \ No newline at end of file diff --git a/app/build/intermediates/blame/res/debug/multi-v2/debug.json b/app/build/intermediates/blame/res/debug/multi-v2/debug.json new file mode 100644 index 0000000..c66edaa --- /dev/null +++ b/app/build/intermediates/blame/res/debug/multi-v2/debug.json @@ -0,0 +1,182 @@ +{ + "logs": [ + { + "outputFile": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\values-zh-rCN_values-zh-rCN.arsc.flat", + "map": [ + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values-zh-rCN\\arrays.xml", + "from": { + "startLines": "-1", + "startColumns": "-1", + "startOffsets": "-1" + }, + "to": { + "startLines": "2", + "startColumns": "4", + "startOffsets": "105", + "endLines": "5", + "endColumns": "19", + "endOffsets": "210" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values-zh-rCN\\strings.xml", + "from": { + "startLines": "-1,-1,82,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1", + "startColumns": "-1,-1,4,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1", + "startOffsets": "-1,-1,4368,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1", + "endColumns": "-1,-1,68,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1", + "endOffsets": "-1,-1,4432,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1" + }, + "to": { + "startLines": "6,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "215,384,448,517,590,656,729,798,875,943,993,1046,1103,1143,1191,1239,1284,1341,1395,1445,1507,1575,1652,1711,1776,1839,1894,1954,2017,2071,2131,2184,2246,2331,2412,2462,2521,2564,2617,2660,2711,2757,2807,2867,2920,2971,3017,3065,3113,3159,3206,3256,3301,3360,3412,3465,3517,3560,3607,3663,3718,3773,3829,3873,3915,3956,4006,4065,4116,4165,4214,4261,4308,4355,4400,4451,4504,4579,4638,4695,4769,4833,4902,4980,5090,5194,5267,5333,5388,5453,5518,5567,5650,5728,5766,5811,5859,5921,5978,6033,6092,6159,6217,6279,6327,6372,6420,6471,6537", + "endLines": "8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116", + "endColumns": "14,63,68,72,65,72,68,76,67,49,52,56,39,47,47,44,56,53,49,61,67,76,58,64,62,54,59,62,53,59,52,61,84,80,49,58,42,52,42,50,45,49,59,52,50,45,47,47,45,46,49,44,58,51,52,51,42,46,55,54,54,55,43,41,40,49,58,50,48,48,46,46,46,44,50,52,74,58,56,73,63,68,77,109,103,72,65,54,64,64,48,82,77,37,44,47,61,56,54,58,66,57,61,47,44,47,50,65,65", + "endOffsets": "379,443,512,585,651,724,793,870,938,988,1041,1098,1138,1186,1234,1279,1336,1390,1440,1502,1570,1647,1706,1771,1834,1889,1949,2012,2066,2126,2179,2241,2326,2407,2457,2516,2559,2612,2655,2706,2752,2802,2862,2915,2966,3012,3060,3108,3154,3201,3251,3296,3355,3407,3460,3512,3555,3602,3658,3713,3768,3824,3868,3910,3951,4001,4060,4111,4160,4209,4256,4303,4350,4395,4446,4499,4574,4633,4690,4764,4828,4897,4975,5085,5189,5262,5328,5383,5448,5513,5562,5645,5723,5761,5806,5854,5916,5973,6028,6087,6154,6212,6274,6322,6367,6415,6466,6532,6598" + } + } + ] + }, + { + "outputFile": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\values_values.arsc.flat", + "map": [ + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values\\arrays.xml", + "from": { + "startLines": "19,26", + "startColumns": "4,4", + "startOffsets": "739,1047", + "endLines": "24,29", + "endColumns": "19,19", + "endOffsets": "1041,1162" + }, + "to": { + "startLines": "2,8", + "startColumns": "4,4", + "startOffsets": "105,412", + "endLines": "7,11", + "endColumns": "19,19", + "endOffsets": "407,527" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values\\styles.xml", + "from": { + "startLines": "50,55,64,60,22,26,30,35,40,18,45", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "2062,2267,2640,2479,895,1078,1263,1449,1653,712,1860", + "endLines": "53,58,67,62,25,29,33,38,43,21,48", + "endColumns": "12,12,12,12,12,12,12,12,12,12,12", + "endOffsets": "2261,2473,2843,2634,1073,1258,1443,1647,1854,890,2056" + }, + "to": { + "startLines": "135,139,143,147,150,154,158,162,166,170,174", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "9055,9259,9470,9677,9837,10020,10205,10390,10593,10799,10982", + "endLines": "138,142,146,149,153,157,161,165,169,173,177", + "endColumns": "12,12,12,12,12,12,12,12,12,12,12", + "endOffsets": "9254,9465,9672,9832,10015,10200,10385,10588,10794,10977,11178" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values\\colors.xml", + "from": { + "startLines": "18", + "startColumns": "4", + "startOffsets": "712", + "endColumns": "56", + "endOffsets": "764" + }, + "to": { + "startLines": "12", + "startColumns": "4", + "startOffsets": "532", + "endColumns": "56", + "endOffsets": "584" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values\\dimens.xml", + "from": { + "startLines": "19,20,21,22,18", + "startColumns": "4,4,4,4,4", + "startOffsets": "764,816,869,922,712", + "endColumns": "51,52,52,51,51", + "endOffsets": "811,864,917,969,759" + }, + "to": { + "startLines": "13,14,15,16,17", + "startColumns": "4,4,4,4,4", + "startOffsets": "589,641,694,747,799", + "endColumns": "51,52,52,51,51", + "endOffsets": "636,689,742,794,846" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values\\strings.xml", + "from": { + "startLines": "144,86,87,78,81,80,84,85,88,79,83,90,19,20,21,134,135,143,142,26,97,98,96,95,94,110,109,108,100,39,38,64,29,30,101,41,92,136,77,67,42,48,53,70,43,63,62,61,57,56,54,55,58,59,49,76,60,71,68,47,52,51,50,66,73,46,65,44,45,75,28,34,36,33,35,32,31,25,24,117,116,120,132,125,124,126,127,129,128,118,119,123,121,122,115,130,131,141,139,138,140,27,99,107,112,111,113,106,105,104,103,22,23", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "9333,5075,5152,4360,4624,4527,4869,4962,5256,4457,4809,5347,846,890,943,8821,8871,9274,9222,1308,5891,5986,5819,5734,5650,6865,6781,6678,6164,2043,1991,3461,1515,1569,6226,2138,5515,8935,4288,3649,2198,2519,2825,3864,2257,3389,3327,3269,3043,2990,2885,2939,3094,3145,2567,4221,3206,3919,3699,2471,2769,2680,2621,3586,3988,2420,3540,2315,2359,4153,1459,1784,1894,1736,1840,1679,1630,1252,1198,7328,7260,7572,8722,7941,7859,8016,8106,8350,8270,7413,7489,7799,7637,7718,7204,8495,8618,9180,9051,8993,9105,1393,6095,6591,7002,6932,7083,6531,6475,6412,6351,996,1107", + "endLines": "148,86,87,78,81,80,84,85,88,79,83,90,19,20,21,134,135,143,142,26,97,98,96,95,94,110,109,108,100,39,38,64,29,30,101,41,92,136,77,67,42,48,53,70,43,63,62,61,57,56,54,55,58,59,49,76,60,71,68,47,52,51,50,66,73,46,65,44,45,75,28,34,36,33,35,32,31,25,24,117,116,120,132,125,124,126,127,129,128,118,119,123,121,122,115,130,131,141,139,138,140,27,99,107,112,111,113,106,105,104,103,22,23", + "endColumns": "14,75,102,95,82,95,91,111,87,68,58,65,42,51,51,48,62,57,50,83,93,107,70,83,82,65,82,101,60,61,50,77,52,59,104,58,101,54,70,48,57,46,58,53,56,70,60,56,49,51,52,49,49,59,52,65,61,65,62,46,54,87,57,61,62,49,44,42,59,66,54,54,52,46,52,55,47,54,52,83,66,63,95,73,80,88,162,143,78,74,81,58,79,79,54,121,102,40,52,56,73,64,67,85,79,68,93,58,54,61,59,109,89", + "endOffsets": "9741,5146,5250,4451,4702,4618,4956,5069,5339,4521,4863,5408,884,937,990,8865,8929,9327,9268,1387,5980,6089,5885,5813,5728,6926,6859,6775,6220,2100,2037,3534,1563,1624,6326,2192,5612,8985,4354,3693,2251,2561,2879,3913,2309,3455,3383,3321,3088,3037,2933,2984,3139,3200,2615,4282,3263,3980,3757,2513,2819,2763,2674,3643,4046,2465,3580,2353,2414,4215,1509,1834,1942,1778,1888,1730,1673,1302,1246,7407,7322,7631,8813,8010,7935,8100,8264,8489,8344,7483,7566,7853,7712,7793,7254,8612,8716,9216,9099,9045,9174,1453,6158,6672,7077,6996,7172,6585,6525,6469,6406,1101,1192" + }, + "to": { + "startLines": "18,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "851,1244,1320,1423,1519,1602,1698,1790,1902,1990,2059,2118,2184,2227,2279,2331,2380,2443,2501,2552,2636,2730,2838,2909,2993,3076,3142,3225,3327,3388,3450,3501,3579,3632,3692,3797,3856,3958,4013,4084,4133,4191,4238,4297,4351,4408,4479,4540,4597,4647,4699,4752,4802,4852,4912,4965,5031,5093,5159,5222,5269,5324,5412,5470,5532,5595,5645,5690,5733,5793,5860,5915,5970,6023,6070,6123,6179,6227,6282,6335,6419,6486,6550,6646,6720,6801,6890,7053,7197,7276,7351,7433,7492,7572,7652,7707,7829,7932,7973,8026,8083,8157,8222,8290,8376,8456,8525,8619,8678,8733,8795,8855,8965", + "endLines": "22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134", + "endColumns": "14,75,102,95,82,95,91,111,87,68,58,65,42,51,51,48,62,57,50,83,93,107,70,83,82,65,82,101,60,61,50,77,52,59,104,58,101,54,70,48,57,46,58,53,56,70,60,56,49,51,52,49,49,59,52,65,61,65,62,46,54,87,57,61,62,49,44,42,59,66,54,54,52,46,52,55,47,54,52,83,66,63,95,73,80,88,162,143,78,74,81,58,79,79,54,121,102,40,52,56,73,64,67,85,79,68,93,58,54,61,59,109,89", + "endOffsets": "1239,1315,1418,1514,1597,1693,1785,1897,1985,2054,2113,2179,2222,2274,2326,2375,2438,2496,2547,2631,2725,2833,2904,2988,3071,3137,3220,3322,3383,3445,3496,3574,3627,3687,3792,3851,3953,4008,4079,4128,4186,4233,4292,4346,4403,4474,4535,4592,4642,4694,4747,4797,4847,4907,4960,5026,5088,5154,5217,5264,5319,5407,5465,5527,5590,5640,5685,5728,5788,5855,5910,5965,6018,6065,6118,6174,6222,6277,6330,6414,6481,6545,6641,6715,6796,6885,7048,7192,7271,7346,7428,7487,7567,7647,7702,7824,7927,7968,8021,8078,8152,8217,8285,8371,8451,8520,8614,8673,8728,8790,8850,8960,9050" + } + } + ] + }, + { + "outputFile": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\values-zh-rTW_values-zh-rTW.arsc.flat", + "map": [ + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values-zh-rTW\\arrays.xml", + "from": { + "startLines": "18", + "startColumns": "4", + "startOffsets": "712", + "endLines": "21", + "endColumns": "19", + "endOffsets": "817" + }, + "to": { + "startLines": "2", + "startColumns": "4", + "startOffsets": "105", + "endLines": "5", + "endColumns": "19", + "endOffsets": "210" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values-zh-rTW\\strings.xml", + "from": { + "startLines": "122,72,71,70,69,19,20,21,112,113,121,120,26,76,77,75,74,73,89,88,87,79,61,29,30,80,37,114,68,64,39,45,50,40,60,59,58,54,53,51,52,55,56,46,67,57,65,44,49,48,47,63,43,62,41,42,66,28,34,36,33,35,32,31,25,24,96,95,98,110,103,102,104,105,107,106,97,101,99,100,94,108,109,119,117,116,118,27,78,86,91,90,92,85,84,83,82,22,23", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "6507,3575,3509,3436,3386,827,867,915,6057,6102,6453,6403,1199,3835,3903,3776,3710,3647,4565,4505,4442,4035,2957,1369,1422,4089,1768,6159,3327,3114,1878,2159,2405,1931,2897,2844,2793,2598,2550,2456,2504,2644,2691,2202,3268,2741,3157,2116,2358,2302,2247,3059,2072,3017,1981,2022,3209,1318,1623,1719,1576,1672,1529,1484,1148,1095,4940,4881,5081,5982,5392,5323,5456,5534,5717,5644,5015,5268,5138,5203,4832,5821,5904,6365,6258,6210,6303,1261,3980,4383,4678,4620,4745,4335,4290,4242,4191,963,1029", + "endLines": "124,72,71,70,69,19,20,21,112,113,121,120,26,76,77,75,74,73,89,88,87,79,61,29,30,80,37,114,68,64,39,45,50,40,60,59,58,54,53,51,52,55,56,46,67,57,65,44,49,48,47,63,43,62,41,42,66,28,34,36,33,35,32,31,25,24,96,95,98,110,103,102,104,105,107,106,97,101,99,100,94,108,109,119,117,116,118,27,78,86,91,90,92,85,84,83,82,22,23", + "endColumns": "14,71,65,72,49,39,47,47,44,56,53,49,61,67,76,58,65,62,54,59,62,53,59,52,61,83,79,49,58,42,52,42,50,49,59,52,50,45,47,47,45,46,49,44,58,51,51,42,46,55,54,54,43,41,40,49,58,50,48,48,46,46,46,44,50,52,74,58,56,73,63,68,77,109,103,72,65,54,64,64,48,82,77,37,44,47,61,56,54,58,66,57,61,47,44,47,50,65,65", + "endOffsets": "6679,3642,3570,3504,3431,862,910,958,6097,6154,6502,6448,1256,3898,3975,3830,3771,3705,4615,4560,4500,4084,3012,1417,1479,4168,1843,6204,3381,3152,1926,2197,2451,1976,2952,2892,2839,2639,2593,2499,2545,2686,2736,2242,3322,2788,3204,2154,2400,2353,2297,3109,2111,3054,2017,2067,3263,1364,1667,1763,1618,1714,1571,1524,1194,1143,5010,4935,5133,6051,5451,5387,5529,5639,5816,5712,5076,5318,5198,5263,4876,5899,5977,6398,6298,6253,6360,1313,4030,4437,4740,4673,4802,4378,4330,4285,4237,1024,1090" + }, + "to": { + "startLines": "6,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "215,384,456,522,595,645,685,733,781,826,883,937,987,1049,1117,1194,1253,1319,1382,1437,1497,1560,1614,1674,1727,1789,1873,1953,2003,2062,2105,2158,2201,2252,2302,2362,2415,2466,2512,2560,2608,2654,2701,2751,2796,2855,2907,2959,3002,3049,3105,3160,3215,3259,3301,3342,3392,3451,3502,3551,3600,3647,3694,3741,3786,3837,3890,3965,4024,4081,4155,4219,4288,4366,4476,4580,4653,4719,4774,4839,4904,4953,5036,5114,5152,5197,5245,5307,5364,5419,5478,5545,5603,5665,5713,5758,5806,5857,5923", + "endLines": "8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106", + "endColumns": "14,71,65,72,49,39,47,47,44,56,53,49,61,67,76,58,65,62,54,59,62,53,59,52,61,83,79,49,58,42,52,42,50,49,59,52,50,45,47,47,45,46,49,44,58,51,51,42,46,55,54,54,43,41,40,49,58,50,48,48,46,46,46,44,50,52,74,58,56,73,63,68,77,109,103,72,65,54,64,64,48,82,77,37,44,47,61,56,54,58,66,57,61,47,44,47,50,65,65", + "endOffsets": "379,451,517,590,640,680,728,776,821,878,932,982,1044,1112,1189,1248,1314,1377,1432,1492,1555,1609,1669,1722,1784,1868,1948,1998,2057,2100,2153,2196,2247,2297,2357,2410,2461,2507,2555,2603,2649,2696,2746,2791,2850,2902,2954,2997,3044,3100,3155,3210,3254,3296,3337,3387,3446,3497,3546,3595,3642,3689,3736,3781,3832,3885,3960,4019,4076,4150,4214,4283,4361,4471,4575,4648,4714,4769,4834,4899,4948,5031,5109,5147,5192,5240,5302,5359,5414,5473,5540,5598,5660,5708,5753,5801,5852,5918,5984" + } + } + ] + } + ] +} \ No newline at end of file diff --git a/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rCN.json b/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rCN.json new file mode 100644 index 0000000..fc23fb5 --- /dev/null +++ b/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rCN.json @@ -0,0 +1,43 @@ +{ + "logs": [ + { + "outputFile": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-zh-rCN\\values-zh-rCN.xml", + "map": [ + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values-zh-rCN\\arrays.xml", + "from": { + "startLines": "-1", + "startColumns": "-1", + "startOffsets": "-1" + }, + "to": { + "startLines": "2", + "startColumns": "4", + "startOffsets": "105", + "endLines": "5", + "endColumns": "19", + "endOffsets": "210" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values-zh-rCN\\strings.xml", + "from": { + "startLines": "-1,-1,82,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1", + "startColumns": "-1,-1,4,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1", + "startOffsets": "-1,-1,4368,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1", + "endColumns": "-1,-1,68,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1", + "endOffsets": "-1,-1,4432,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1" + }, + "to": { + "startLines": "6,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "215,384,448,517,590,656,729,798,875,943,993,1046,1103,1143,1191,1239,1284,1341,1395,1445,1507,1575,1652,1711,1776,1839,1894,1954,2017,2071,2131,2184,2246,2331,2412,2462,2521,2564,2617,2660,2711,2757,2807,2867,2920,2971,3017,3065,3113,3159,3206,3256,3301,3360,3412,3465,3517,3560,3607,3663,3718,3773,3829,3873,3915,3956,4006,4065,4116,4165,4214,4261,4308,4355,4400,4451,4504,4579,4638,4695,4769,4833,4902,4980,5090,5194,5267,5333,5388,5453,5518,5567,5650,5728,5766,5811,5859,5921,5978,6033,6092,6159,6217,6279,6327,6372,6420,6471,6537", + "endLines": "8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116", + "endColumns": "14,63,68,72,65,72,68,76,67,49,52,56,39,47,47,44,56,53,49,61,67,76,58,64,62,54,59,62,53,59,52,61,84,80,49,58,42,52,42,50,45,49,59,52,50,45,47,47,45,46,49,44,58,51,52,51,42,46,55,54,54,55,43,41,40,49,58,50,48,48,46,46,46,44,50,52,74,58,56,73,63,68,77,109,103,72,65,54,64,64,48,82,77,37,44,47,61,56,54,58,66,57,61,47,44,47,50,65,65", + "endOffsets": "379,443,512,585,651,724,793,870,938,988,1041,1098,1138,1186,1234,1279,1336,1390,1440,1502,1570,1647,1706,1771,1834,1889,1949,2012,2066,2126,2179,2241,2326,2407,2457,2516,2559,2612,2655,2706,2752,2802,2862,2915,2966,3012,3060,3108,3154,3201,3251,3296,3355,3407,3460,3512,3555,3602,3658,3713,3768,3824,3868,3910,3951,4001,4060,4111,4160,4209,4256,4303,4350,4395,4446,4499,4574,4633,4690,4764,4828,4897,4975,5085,5189,5262,5328,5383,5448,5513,5562,5645,5723,5761,5806,5854,5916,5973,6028,6087,6154,6212,6274,6322,6367,6415,6466,6532,6598" + } + } + ] + } + ] +} \ No newline at end of file diff --git a/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rTW.json b/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rTW.json new file mode 100644 index 0000000..bbc9730 --- /dev/null +++ b/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rTW.json @@ -0,0 +1,47 @@ +{ + "logs": [ + { + "outputFile": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-zh-rTW\\values-zh-rTW.xml", + "map": [ + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values-zh-rTW\\arrays.xml", + "from": { + "startLines": "18", + "startColumns": "4", + "startOffsets": "712", + "endLines": "21", + "endColumns": "19", + "endOffsets": "817" + }, + "to": { + "startLines": "2", + "startColumns": "4", + "startOffsets": "105", + "endLines": "5", + "endColumns": "19", + "endOffsets": "210" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values-zh-rTW\\strings.xml", + "from": { + "startLines": "122,72,71,70,69,19,20,21,112,113,121,120,26,76,77,75,74,73,89,88,87,79,61,29,30,80,37,114,68,64,39,45,50,40,60,59,58,54,53,51,52,55,56,46,67,57,65,44,49,48,47,63,43,62,41,42,66,28,34,36,33,35,32,31,25,24,96,95,98,110,103,102,104,105,107,106,97,101,99,100,94,108,109,119,117,116,118,27,78,86,91,90,92,85,84,83,82,22,23", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "6507,3575,3509,3436,3386,827,867,915,6057,6102,6453,6403,1199,3835,3903,3776,3710,3647,4565,4505,4442,4035,2957,1369,1422,4089,1768,6159,3327,3114,1878,2159,2405,1931,2897,2844,2793,2598,2550,2456,2504,2644,2691,2202,3268,2741,3157,2116,2358,2302,2247,3059,2072,3017,1981,2022,3209,1318,1623,1719,1576,1672,1529,1484,1148,1095,4940,4881,5081,5982,5392,5323,5456,5534,5717,5644,5015,5268,5138,5203,4832,5821,5904,6365,6258,6210,6303,1261,3980,4383,4678,4620,4745,4335,4290,4242,4191,963,1029", + "endLines": "124,72,71,70,69,19,20,21,112,113,121,120,26,76,77,75,74,73,89,88,87,79,61,29,30,80,37,114,68,64,39,45,50,40,60,59,58,54,53,51,52,55,56,46,67,57,65,44,49,48,47,63,43,62,41,42,66,28,34,36,33,35,32,31,25,24,96,95,98,110,103,102,104,105,107,106,97,101,99,100,94,108,109,119,117,116,118,27,78,86,91,90,92,85,84,83,82,22,23", + "endColumns": "14,71,65,72,49,39,47,47,44,56,53,49,61,67,76,58,65,62,54,59,62,53,59,52,61,83,79,49,58,42,52,42,50,49,59,52,50,45,47,47,45,46,49,44,58,51,51,42,46,55,54,54,43,41,40,49,58,50,48,48,46,46,46,44,50,52,74,58,56,73,63,68,77,109,103,72,65,54,64,64,48,82,77,37,44,47,61,56,54,58,66,57,61,47,44,47,50,65,65", + "endOffsets": "6679,3642,3570,3504,3431,862,910,958,6097,6154,6502,6448,1256,3898,3975,3830,3771,3705,4615,4560,4500,4084,3012,1417,1479,4168,1843,6204,3381,3152,1926,2197,2451,1976,2952,2892,2839,2639,2593,2499,2545,2686,2736,2242,3322,2788,3204,2154,2400,2353,2297,3109,2111,3054,2017,2067,3263,1364,1667,1763,1618,1714,1571,1524,1194,1143,5010,4935,5133,6051,5451,5387,5529,5639,5816,5712,5076,5318,5198,5263,4876,5899,5977,6398,6298,6253,6360,1313,4030,4437,4740,4673,4802,4378,4330,4285,4237,1024,1090" + }, + "to": { + "startLines": "6,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "215,384,456,522,595,645,685,733,781,826,883,937,987,1049,1117,1194,1253,1319,1382,1437,1497,1560,1614,1674,1727,1789,1873,1953,2003,2062,2105,2158,2201,2252,2302,2362,2415,2466,2512,2560,2608,2654,2701,2751,2796,2855,2907,2959,3002,3049,3105,3160,3215,3259,3301,3342,3392,3451,3502,3551,3600,3647,3694,3741,3786,3837,3890,3965,4024,4081,4155,4219,4288,4366,4476,4580,4653,4719,4774,4839,4904,4953,5036,5114,5152,5197,5245,5307,5364,5419,5478,5545,5603,5665,5713,5758,5806,5857,5923", + "endLines": "8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106", + "endColumns": "14,71,65,72,49,39,47,47,44,56,53,49,61,67,76,58,65,62,54,59,62,53,59,52,61,83,79,49,58,42,52,42,50,49,59,52,50,45,47,47,45,46,49,44,58,51,51,42,46,55,54,54,43,41,40,49,58,50,48,48,46,46,46,44,50,52,74,58,56,73,63,68,77,109,103,72,65,54,64,64,48,82,77,37,44,47,61,56,54,58,66,57,61,47,44,47,50,65,65", + "endOffsets": "379,451,517,590,640,680,728,776,821,878,932,982,1044,1112,1189,1248,1314,1377,1432,1492,1555,1609,1669,1722,1784,1868,1948,1998,2057,2100,2153,2196,2247,2297,2357,2410,2461,2507,2555,2603,2649,2696,2746,2791,2850,2902,2954,2997,3044,3100,3155,3210,3254,3296,3337,3387,3446,3497,3546,3595,3642,3689,3736,3781,3832,3885,3960,4019,4076,4150,4214,4283,4361,4471,4575,4648,4714,4769,4834,4899,4948,5031,5109,5147,5192,5240,5302,5359,5414,5473,5540,5598,5660,5708,5753,5801,5852,5918,5984" + } + } + ] + } + ] +} \ No newline at end of file diff --git a/app/build/intermediates/blame/res/debug/multi-v2/values.json b/app/build/intermediates/blame/res/debug/multi-v2/values.json new file mode 100644 index 0000000..de6549d --- /dev/null +++ b/app/build/intermediates/blame/res/debug/multi-v2/values.json @@ -0,0 +1,100 @@ +{ + "logs": [ + { + "outputFile": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values\\values.xml", + "map": [ + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values\\arrays.xml", + "from": { + "startLines": "19,26", + "startColumns": "4,4", + "startOffsets": "739,1047", + "endLines": "24,29", + "endColumns": "19,19", + "endOffsets": "1041,1162" + }, + "to": { + "startLines": "2,8", + "startColumns": "4,4", + "startOffsets": "105,412", + "endLines": "7,11", + "endColumns": "19,19", + "endOffsets": "407,527" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values\\styles.xml", + "from": { + "startLines": "50,55,64,60,22,26,30,35,40,18,45", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "2062,2267,2640,2479,895,1078,1263,1449,1653,712,1860", + "endLines": "53,58,67,62,25,29,33,38,43,21,48", + "endColumns": "12,12,12,12,12,12,12,12,12,12,12", + "endOffsets": "2261,2473,2843,2634,1073,1258,1443,1647,1854,890,2056" + }, + "to": { + "startLines": "135,139,143,147,150,154,158,162,166,170,174", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "9055,9259,9470,9677,9837,10020,10205,10390,10593,10799,10982", + "endLines": "138,142,146,149,153,157,161,165,169,173,177", + "endColumns": "12,12,12,12,12,12,12,12,12,12,12", + "endOffsets": "9254,9465,9672,9832,10015,10200,10385,10588,10794,10977,11178" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values\\colors.xml", + "from": { + "startLines": "18", + "startColumns": "4", + "startOffsets": "712", + "endColumns": "56", + "endOffsets": "764" + }, + "to": { + "startLines": "12", + "startColumns": "4", + "startOffsets": "532", + "endColumns": "56", + "endOffsets": "584" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values\\dimens.xml", + "from": { + "startLines": "19,20,21,22,18", + "startColumns": "4,4,4,4,4", + "startOffsets": "764,816,869,922,712", + "endColumns": "51,52,52,51,51", + "endOffsets": "811,864,917,969,759" + }, + "to": { + "startLines": "13,14,15,16,17", + "startColumns": "4,4,4,4,4", + "startOffsets": "589,641,694,747,799", + "endColumns": "51,52,52,51,51", + "endOffsets": "636,689,742,794,846" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values\\strings.xml", + "from": { + "startLines": "144,86,87,78,81,80,84,85,88,79,83,90,19,20,21,134,135,143,142,26,97,98,96,95,94,110,109,108,100,39,38,64,29,30,101,41,92,136,77,67,42,48,53,70,43,63,62,61,57,56,54,55,58,59,49,76,60,71,68,47,52,51,50,66,73,46,65,44,45,75,28,34,36,33,35,32,31,25,24,117,116,120,132,125,124,126,127,129,128,118,119,123,121,122,115,130,131,141,139,138,140,27,99,107,112,111,113,106,105,104,103,22,23", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "9333,5075,5152,4360,4624,4527,4869,4962,5256,4457,4809,5347,846,890,943,8821,8871,9274,9222,1308,5891,5986,5819,5734,5650,6865,6781,6678,6164,2043,1991,3461,1515,1569,6226,2138,5515,8935,4288,3649,2198,2519,2825,3864,2257,3389,3327,3269,3043,2990,2885,2939,3094,3145,2567,4221,3206,3919,3699,2471,2769,2680,2621,3586,3988,2420,3540,2315,2359,4153,1459,1784,1894,1736,1840,1679,1630,1252,1198,7328,7260,7572,8722,7941,7859,8016,8106,8350,8270,7413,7489,7799,7637,7718,7204,8495,8618,9180,9051,8993,9105,1393,6095,6591,7002,6932,7083,6531,6475,6412,6351,996,1107", + "endLines": "148,86,87,78,81,80,84,85,88,79,83,90,19,20,21,134,135,143,142,26,97,98,96,95,94,110,109,108,100,39,38,64,29,30,101,41,92,136,77,67,42,48,53,70,43,63,62,61,57,56,54,55,58,59,49,76,60,71,68,47,52,51,50,66,73,46,65,44,45,75,28,34,36,33,35,32,31,25,24,117,116,120,132,125,124,126,127,129,128,118,119,123,121,122,115,130,131,141,139,138,140,27,99,107,112,111,113,106,105,104,103,22,23", + "endColumns": "14,75,102,95,82,95,91,111,87,68,58,65,42,51,51,48,62,57,50,83,93,107,70,83,82,65,82,101,60,61,50,77,52,59,104,58,101,54,70,48,57,46,58,53,56,70,60,56,49,51,52,49,49,59,52,65,61,65,62,46,54,87,57,61,62,49,44,42,59,66,54,54,52,46,52,55,47,54,52,83,66,63,95,73,80,88,162,143,78,74,81,58,79,79,54,121,102,40,52,56,73,64,67,85,79,68,93,58,54,61,59,109,89", + "endOffsets": "9741,5146,5250,4451,4702,4618,4956,5069,5339,4521,4863,5408,884,937,990,8865,8929,9327,9268,1387,5980,6089,5885,5813,5728,6926,6859,6775,6220,2100,2037,3534,1563,1624,6326,2192,5612,8985,4354,3693,2251,2561,2879,3913,2309,3455,3383,3321,3088,3037,2933,2984,3139,3200,2615,4282,3263,3980,3757,2513,2819,2763,2674,3643,4046,2465,3580,2353,2414,4215,1509,1834,1942,1778,1888,1730,1673,1302,1246,7407,7322,7631,8813,8010,7935,8100,8264,8489,8344,7483,7566,7853,7712,7793,7254,8612,8716,9216,9099,9045,9174,1453,6158,6672,7077,6996,7172,6585,6525,6469,6406,1101,1192" + }, + "to": { + "startLines": "18,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "851,1244,1320,1423,1519,1602,1698,1790,1902,1990,2059,2118,2184,2227,2279,2331,2380,2443,2501,2552,2636,2730,2838,2909,2993,3076,3142,3225,3327,3388,3450,3501,3579,3632,3692,3797,3856,3958,4013,4084,4133,4191,4238,4297,4351,4408,4479,4540,4597,4647,4699,4752,4802,4852,4912,4965,5031,5093,5159,5222,5269,5324,5412,5470,5532,5595,5645,5690,5733,5793,5860,5915,5970,6023,6070,6123,6179,6227,6282,6335,6419,6486,6550,6646,6720,6801,6890,7053,7197,7276,7351,7433,7492,7572,7652,7707,7829,7932,7973,8026,8083,8157,8222,8290,8376,8456,8525,8619,8678,8733,8795,8855,8965", + "endLines": "22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134", + "endColumns": "14,75,102,95,82,95,91,111,87,68,58,65,42,51,51,48,62,57,50,83,93,107,70,83,82,65,82,101,60,61,50,77,52,59,104,58,101,54,70,48,57,46,58,53,56,70,60,56,49,51,52,49,49,59,52,65,61,65,62,46,54,87,57,61,62,49,44,42,59,66,54,54,52,46,52,55,47,54,52,83,66,63,95,73,80,88,162,143,78,74,81,58,79,79,54,121,102,40,52,56,73,64,67,85,79,68,93,58,54,61,59,109,89", + "endOffsets": "1239,1315,1418,1514,1597,1693,1785,1897,1985,2054,2113,2179,2222,2274,2326,2375,2438,2496,2547,2631,2725,2833,2904,2988,3071,3137,3220,3322,3383,3445,3496,3574,3627,3687,3792,3851,3953,4008,4079,4128,4186,4233,4292,4346,4403,4474,4535,4592,4642,4694,4747,4797,4847,4907,4960,5026,5088,5154,5217,5264,5319,5407,5465,5527,5590,5640,5685,5728,5788,5855,5910,5965,6018,6065,6118,6174,6222,6277,6330,6414,6481,6545,6641,6715,6796,6885,7048,7192,7271,7346,7428,7487,7567,7647,7702,7824,7927,7968,8021,8078,8152,8217,8285,8371,8451,8520,8614,8673,8728,8790,8850,8960,9050" + } + } + ] + } + ] +} \ No newline at end of file diff --git a/app/build/intermediates/blame/res/debug/single/debug.json b/app/build/intermediates/blame/res/debug/single/debug.json new file mode 100644 index 0000000..bb48158 --- /dev/null +++ b/app/build/intermediates/blame/res/debug/single/debug.json @@ -0,0 +1,470 @@ +[ + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_red.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_red.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_folder.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_folder.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_middle.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_blue_middle.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_call_record_folder.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\call_record_folder.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list_options.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\note_list_options.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable_selector_key_del.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable\\selector_key_del.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_white.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_white.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_dropdown_icon.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\dropdown_icon.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_title_alert.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\title_alert.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_attention3.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\attention3.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_small.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_small.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_widget_2x.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\widget_2x.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\raw-zh-rCN_introduction.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\raw-zh-rCN\\introduction" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list_dropdown_menu.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_list_dropdown_menu.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_current_password_head.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\current_password_head.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_blue.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_blue.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_down.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_white_down.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_single.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_green_single.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_size_selector_bg.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_size_selector_bg.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_encryption.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_encryption.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_attention2.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\attention2.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_red.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_red.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_blue.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_blue.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_cancel.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\cancel.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_background.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_background.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_white.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_white.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_down.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_red_down.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_icon_app.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\icon_app.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_green.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_green.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_white.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_white.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_folder_list_item.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\folder_list_item.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_footer_bg.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_footer_bg.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_down.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_down.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_yellow.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_yellow.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_super.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_super.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_datetime_picker.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\datetime_picker.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_password_item.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\password_item.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\xml_searchable.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\xml\\searchable.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable_new_note.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable\\new_note.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_search_result.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\search_result.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_notification.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\notification.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_single.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_red_single.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_attention5.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\attention5.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_up.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_up.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_normal.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_normal.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_layout2.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\layout2.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_green.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_green.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_decryption.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_decryption.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_attention0.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\attention0.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_add_account_text.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\add_account_text.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_yellow.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_yellow.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_importance.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_importance.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_call_note_edit.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\call_note_edit.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_delete.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\delete.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\xml_widget_2x_info.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\xml\\widget_2x_info.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_item.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_item.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list_footer.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_list_footer.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_edit_list_item.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_edit_list_item.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_menu_move.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\menu_move.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_middle.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_red_middle.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_down.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_green_down.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_up.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_white_up.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list_dropdown.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\note_list_dropdown.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_new_note_pressed.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\new_note_pressed.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_new_note_normal.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\new_note_normal.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_large.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_large.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_single.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_blue_single.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_bg_color_btn_mask.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\bg_color_btn_mask.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_up.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_blue_up.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable_selector_grid.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable\\selector_grid.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_edit.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_edit.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_clock.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\clock.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\xml_widget_4x_info.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\xml\\widget_4x_info.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_call_record.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\call_record.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_sub_folder.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\sub_folder.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_item_grid.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\item_grid.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_middle.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_green_middle.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_blue.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_blue.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_edit.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\note_edit.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_account_dialog_title.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\account_dialog_title.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_red.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_red.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_dialog_edit_text.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\dialog_edit_text.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_layout.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\layout.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_bg_btn_set_color.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\bg_btn_set_color.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_list.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_new_password_head.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\new_password_head.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_homepage.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\homepage.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\xml_preferences.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\xml\\preferences.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_red.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_red.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_note_edit_color_selector_panel.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\note_edit_color_selector_panel.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_attention1.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\attention1.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_white.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_white.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\raw_introduction.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\raw\\introduction" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_repeat_password_head.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\repeat_password_head.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_single.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_white_single.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\color_secondary_text_dark.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\color\\secondary_text_dark.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_blue.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_blue.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_title_bar_bg.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\title_bar_bg.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_menu_delete.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\menu_delete.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_green.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_green.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_yellow.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_yellow.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_green.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_green.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_selected.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\selected.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_settings_header.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\settings_header.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_middle.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_middle.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_single.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_single.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\note_list.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_lock.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\lock.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_down.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_blue_down.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_up.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_green_up.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_yellow.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_yellow.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\color_primary_text_dark.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\color\\primary_text_dark.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_middle.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_white_middle.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_widget_4x.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\widget_4x.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_encryption_repeat.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_encryption_repeat.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_attention4.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\attention4.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_up.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_red_up.9.png" + } +] \ No newline at end of file diff --git a/app/build/intermediates/blame/res/release/multi-v2/release.json b/app/build/intermediates/blame/res/release/multi-v2/release.json new file mode 100644 index 0000000..d8f6a99 --- /dev/null +++ b/app/build/intermediates/blame/res/release/multi-v2/release.json @@ -0,0 +1,186 @@ +{ + "logs": [ + { + "outputFile": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\values-zh-rTW_values-zh-rTW.arsc.flat", + "map": [ + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values-zh-rTW\\arrays.xml", + "from": { + "startLines": "18", + "startColumns": "4", + "startOffsets": "712", + "endLines": "21", + "endColumns": "19", + "endOffsets": "817" + }, + "to": { + "startLines": "2", + "startColumns": "4", + "startOffsets": "105", + "endLines": "5", + "endColumns": "19", + "endOffsets": "210" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values-zh-rTW\\strings.xml", + "from": { + "startLines": "122,72,71,70,69,19,20,21,112,113,121,120,26,76,77,75,74,73,89,88,87,79,61,29,30,80,37,114,68,64,39,45,50,40,60,59,58,54,53,51,52,55,56,46,67,57,65,44,49,48,47,63,43,62,41,42,66,28,34,36,33,35,32,31,25,24,96,95,98,110,103,102,104,105,107,106,97,101,99,100,94,108,109,119,117,116,118,27,78,86,91,90,92,85,84,83,82,22,23", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "6507,3575,3509,3436,3386,827,867,915,6057,6102,6453,6403,1199,3835,3903,3776,3710,3647,4565,4505,4442,4035,2957,1369,1422,4089,1768,6159,3327,3114,1878,2159,2405,1931,2897,2844,2793,2598,2550,2456,2504,2644,2691,2202,3268,2741,3157,2116,2358,2302,2247,3059,2072,3017,1981,2022,3209,1318,1623,1719,1576,1672,1529,1484,1148,1095,4940,4881,5081,5982,5392,5323,5456,5534,5717,5644,5015,5268,5138,5203,4832,5821,5904,6365,6258,6210,6303,1261,3980,4383,4678,4620,4745,4335,4290,4242,4191,963,1029", + "endLines": "124,72,71,70,69,19,20,21,112,113,121,120,26,76,77,75,74,73,89,88,87,79,61,29,30,80,37,114,68,64,39,45,50,40,60,59,58,54,53,51,52,55,56,46,67,57,65,44,49,48,47,63,43,62,41,42,66,28,34,36,33,35,32,31,25,24,96,95,98,110,103,102,104,105,107,106,97,101,99,100,94,108,109,119,117,116,118,27,78,86,91,90,92,85,84,83,82,22,23", + "endColumns": "14,71,65,72,49,39,47,47,44,56,53,49,61,67,76,58,65,62,54,59,62,53,59,52,61,83,79,49,58,42,52,42,50,49,59,52,50,45,47,47,45,46,49,44,58,51,51,42,46,55,54,54,43,41,40,49,58,50,48,48,46,46,46,44,50,52,74,58,56,73,63,68,77,109,103,72,65,54,64,64,48,82,77,37,44,47,61,56,54,58,66,57,61,47,44,47,50,65,65", + "endOffsets": "6679,3642,3570,3504,3431,862,910,958,6097,6154,6502,6448,1256,3898,3975,3830,3771,3705,4615,4560,4500,4084,3012,1417,1479,4168,1843,6204,3381,3152,1926,2197,2451,1976,2952,2892,2839,2639,2593,2499,2545,2686,2736,2242,3322,2788,3204,2154,2400,2353,2297,3109,2111,3054,2017,2067,3263,1364,1667,1763,1618,1714,1571,1524,1194,1143,5010,4935,5133,6051,5451,5387,5529,5639,5816,5712,5076,5318,5198,5263,4876,5899,5977,6398,6298,6253,6360,1313,4030,4437,4740,4673,4802,4378,4330,4285,4237,1024,1090" + }, + "to": { + "startLines": "6,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "215,384,456,522,595,645,685,733,781,826,883,937,987,1049,1117,1194,1253,1319,1382,1437,1497,1560,1614,1674,1727,1789,1873,1953,2003,2062,2105,2158,2201,2252,2302,2362,2415,2466,2512,2560,2608,2654,2701,2751,2796,2855,2907,2959,3002,3049,3105,3160,3215,3259,3301,3342,3392,3451,3502,3551,3600,3647,3694,3741,3786,3837,3890,3965,4024,4081,4155,4219,4288,4366,4476,4580,4653,4719,4774,4839,4904,4953,5036,5114,5152,5197,5245,5307,5364,5419,5478,5545,5603,5665,5713,5758,5806,5857,5923", + "endLines": "8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106", + "endColumns": "14,71,65,72,49,39,47,47,44,56,53,49,61,67,76,58,65,62,54,59,62,53,59,52,61,83,79,49,58,42,52,42,50,49,59,52,50,45,47,47,45,46,49,44,58,51,51,42,46,55,54,54,43,41,40,49,58,50,48,48,46,46,46,44,50,52,74,58,56,73,63,68,77,109,103,72,65,54,64,64,48,82,77,37,44,47,61,56,54,58,66,57,61,47,44,47,50,65,65", + "endOffsets": "379,451,517,590,640,680,728,776,821,878,932,982,1044,1112,1189,1248,1314,1377,1432,1492,1555,1609,1669,1722,1784,1868,1948,1998,2057,2100,2153,2196,2247,2297,2357,2410,2461,2507,2555,2603,2649,2696,2746,2791,2850,2902,2954,2997,3044,3100,3155,3210,3254,3296,3337,3387,3446,3497,3546,3595,3642,3689,3736,3781,3832,3885,3960,4019,4076,4150,4214,4283,4361,4471,4575,4648,4714,4769,4834,4899,4948,5031,5109,5147,5192,5240,5302,5359,5414,5473,5540,5598,5660,5708,5753,5801,5852,5918,5984" + } + } + ] + }, + { + "outputFile": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\values_values.arsc.flat", + "map": [ + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values\\arrays.xml", + "from": { + "startLines": "19,26", + "startColumns": "4,4", + "startOffsets": "739,1047", + "endLines": "24,29", + "endColumns": "19,19", + "endOffsets": "1041,1162" + }, + "to": { + "startLines": "2,8", + "startColumns": "4,4", + "startOffsets": "105,412", + "endLines": "7,11", + "endColumns": "19,19", + "endOffsets": "407,527" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values\\styles.xml", + "from": { + "startLines": "50,55,64,60,22,26,30,35,40,18,45", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "2062,2267,2640,2479,895,1078,1263,1449,1653,712,1860", + "endLines": "53,58,67,62,25,29,33,38,43,21,48", + "endColumns": "12,12,12,12,12,12,12,12,12,12,12", + "endOffsets": "2261,2473,2843,2634,1073,1258,1443,1647,1854,890,2056" + }, + "to": { + "startLines": "125,129,133,137,140,144,148,152,156,160,164", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "8276,8480,8691,8898,9058,9241,9426,9611,9814,10020,10203", + "endLines": "128,132,136,139,143,147,151,155,159,163,167", + "endColumns": "12,12,12,12,12,12,12,12,12,12,12", + "endOffsets": "8475,8686,8893,9053,9236,9421,9606,9809,10015,10198,10399" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values\\colors.xml", + "from": { + "startLines": "18", + "startColumns": "4", + "startOffsets": "712", + "endColumns": "56", + "endOffsets": "764" + }, + "to": { + "startLines": "12", + "startColumns": "4", + "startOffsets": "532", + "endColumns": "56", + "endOffsets": "584" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values\\dimens.xml", + "from": { + "startLines": "19,20,21,22,18", + "startColumns": "4,4,4,4,4", + "startOffsets": "764,816,869,922,712", + "endColumns": "51,52,52,51,51", + "endOffsets": "811,864,917,969,759" + }, + "to": { + "startLines": "13,14,15,16,17", + "startColumns": "4,4,4,4,4", + "startOffsets": "589,641,694,747,799", + "endColumns": "51,52,52,51,51", + "endOffsets": "636,689,742,794,846" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values\\strings.xml", + "from": { + "startLines": "128,72,75,74,73,19,20,21,118,119,127,126,26,81,82,80,79,78,94,93,92,84,39,38,64,29,30,85,41,76,120,71,67,42,48,53,43,63,62,61,57,56,54,55,58,59,49,70,60,68,47,52,51,50,66,46,65,44,45,69,28,34,36,33,35,32,31,25,24,101,100,104,116,109,108,110,111,113,112,102,103,107,105,106,99,114,115,125,123,122,124,27,83,91,96,95,97,90,89,88,87,22,23", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "8008,3898,4159,4063,3994,827,870,922,7506,7555,7950,7899,1282,4613,4707,4542,4458,4375,5574,5491,5389,4883,2004,1953,3397,1486,1539,4944,2097,4242,7618,3827,3582,2156,2471,2772,2214,3326,3265,3208,2986,2934,2831,2884,3036,3086,2518,3761,3146,3631,2424,2717,2629,2571,3520,2374,3475,2271,2314,3694,1431,1750,1858,1703,1805,1647,1599,1227,1174,6030,5963,6271,7409,6635,6554,6709,6798,7040,6961,6114,6189,6495,6335,6415,5908,7184,7306,7858,7731,7674,7784,1366,4815,5303,5709,5640,5789,5244,5189,5127,5067,974,1084", + "endLines": "132,72,75,74,73,19,20,21,118,119,127,126,26,81,82,80,79,78,94,93,92,84,39,38,64,29,30,85,41,76,120,71,67,42,48,53,43,63,62,61,57,56,54,55,58,59,49,70,60,68,47,52,51,50,66,46,65,44,45,69,28,34,36,33,35,32,31,25,24,101,100,104,116,109,108,110,111,113,112,102,103,107,105,106,99,114,115,125,123,122,124,27,83,91,96,95,97,90,89,88,87,22,23", + "endColumns": "14,95,82,95,68,42,51,51,48,62,57,50,83,93,107,70,83,82,65,82,101,60,61,50,77,52,59,104,58,101,54,70,48,57,46,58,56,70,60,56,49,51,52,49,49,59,52,65,61,62,46,54,87,57,61,49,44,42,59,66,54,54,52,46,52,55,47,54,52,83,66,63,95,73,80,88,162,143,78,74,81,58,79,79,54,121,102,40,52,56,73,64,67,85,79,68,93,58,54,61,59,109,89", + "endOffsets": "8412,3989,4237,4154,4058,865,917,969,7550,7613,8003,7945,1361,4702,4810,4608,4537,4453,5635,5569,5486,4939,2061,1999,3470,1534,1594,5044,2151,4339,7668,3893,3626,2209,2513,2826,2266,3392,3321,3260,3031,2981,2879,2929,3081,3141,2566,3822,3203,3689,2466,2767,2712,2624,3577,2419,3515,2309,2369,3756,1481,1800,1906,1745,1853,1698,1642,1277,1222,6109,6025,6330,7500,6704,6630,6793,6956,7179,7035,6184,6266,6549,6410,6490,5958,7301,7404,7894,7779,7726,7853,1426,4878,5384,5784,5704,5878,5298,5239,5184,5122,1079,1169" + }, + "to": { + "startLines": "18,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "851,1244,1340,1423,1519,1588,1631,1683,1735,1784,1847,1905,1956,2040,2134,2242,2313,2397,2480,2546,2629,2731,2792,2854,2905,2983,3036,3096,3201,3260,3362,3417,3488,3537,3595,3642,3701,3758,3829,3890,3947,3997,4049,4102,4152,4202,4262,4315,4381,4443,4506,4553,4608,4696,4754,4816,4866,4911,4954,5014,5081,5136,5191,5244,5291,5344,5400,5448,5503,5556,5640,5707,5771,5867,5941,6022,6111,6274,6418,6497,6572,6654,6713,6793,6873,6928,7050,7153,7194,7247,7304,7378,7443,7511,7597,7677,7746,7840,7899,7954,8016,8076,8186", + "endLines": "22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124", + "endColumns": "14,95,82,95,68,42,51,51,48,62,57,50,83,93,107,70,83,82,65,82,101,60,61,50,77,52,59,104,58,101,54,70,48,57,46,58,56,70,60,56,49,51,52,49,49,59,52,65,61,62,46,54,87,57,61,49,44,42,59,66,54,54,52,46,52,55,47,54,52,83,66,63,95,73,80,88,162,143,78,74,81,58,79,79,54,121,102,40,52,56,73,64,67,85,79,68,93,58,54,61,59,109,89", + "endOffsets": "1239,1335,1418,1514,1583,1626,1678,1730,1779,1842,1900,1951,2035,2129,2237,2308,2392,2475,2541,2624,2726,2787,2849,2900,2978,3031,3091,3196,3255,3357,3412,3483,3532,3590,3637,3696,3753,3824,3885,3942,3992,4044,4097,4147,4197,4257,4310,4376,4438,4501,4548,4603,4691,4749,4811,4861,4906,4949,5009,5076,5131,5186,5239,5286,5339,5395,5443,5498,5551,5635,5702,5766,5862,5936,6017,6106,6269,6413,6492,6567,6649,6708,6788,6868,6923,7045,7148,7189,7242,7299,7373,7438,7506,7592,7672,7741,7835,7894,7949,8011,8071,8181,8271" + } + } + ] + }, + { + "outputFile": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\values-zh-rCN_values-zh-rCN.arsc.flat", + "map": [ + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values-zh-rCN\\arrays.xml", + "from": { + "startLines": "18", + "startColumns": "4", + "startOffsets": "712", + "endLines": "21", + "endColumns": "19", + "endOffsets": "817" + }, + "to": { + "startLines": "2", + "startColumns": "4", + "startOffsets": "105", + "endLines": "5", + "endColumns": "19", + "endOffsets": "210" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values-zh-rCN\\strings.xml", + "from": { + "startLines": "121,71,70,69,68,19,20,21,112,113,120,119,26,77,78,76,75,74,90,89,88,80,60,29,30,81,72,114,67,63,38,44,49,39,59,58,57,53,52,50,51,54,55,45,66,56,64,43,48,47,46,62,42,61,40,41,65,28,34,36,33,35,32,31,25,24,97,96,99,111,104,103,105,106,108,107,98,102,100,101,95,109,110,118,116,115,117,27,79,87,92,91,93,86,85,84,83,22,23", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "6532,3495,3429,3356,3306,827,867,915,6083,6128,6478,6428,1199,3861,3929,3802,3737,3674,4592,4532,4469,4061,2877,1369,1422,4115,3568,6185,3247,3034,1798,2079,2325,1851,2817,2764,2713,2518,2470,2376,2424,2564,2611,2122,3188,2661,3077,2036,2278,2222,2167,2979,1992,2937,1901,1942,3129,1318,1623,1719,1576,1672,1529,1484,1148,1095,4967,4908,5108,6009,5419,5350,5483,5561,5744,5671,5042,5295,5165,5230,4859,5848,5931,6390,6283,6235,6328,1261,4006,4410,4705,4647,4772,4362,4317,4269,4218,963,1029", + "endLines": "123,71,70,69,68,19,20,21,112,113,120,119,26,77,78,76,75,74,90,89,88,80,60,29,30,81,72,114,67,63,38,44,49,39,59,58,57,53,52,50,51,54,55,45,66,56,64,43,48,47,46,62,42,61,40,41,65,28,34,36,33,35,32,31,25,24,97,96,99,111,104,103,105,106,108,107,98,102,100,101,95,109,110,118,116,115,117,27,79,87,92,91,93,86,85,84,83,22,23", + "endColumns": "14,72,65,72,49,39,47,47,44,56,53,49,61,67,76,58,64,62,54,59,62,53,59,52,61,84,80,49,58,42,52,42,50,49,59,52,50,45,47,47,45,46,49,44,58,51,51,42,46,55,54,54,43,41,40,49,58,50,48,48,46,46,46,44,50,52,74,58,56,73,63,68,77,109,103,72,65,54,64,64,48,82,77,37,44,47,61,56,54,58,66,57,61,47,44,47,50,65,65", + "endOffsets": "6704,3563,3490,3424,3351,862,910,958,6123,6180,6527,6473,1256,3924,4001,3856,3797,3732,4642,4587,4527,4110,2932,1417,1479,4195,3644,6230,3301,3072,1846,2117,2371,1896,2872,2812,2759,2559,2513,2419,2465,2606,2656,2162,3242,2708,3124,2074,2320,2273,2217,3029,2031,2974,1937,1987,3183,1364,1667,1763,1618,1714,1571,1524,1194,1143,5037,4962,5160,6078,5478,5414,5556,5666,5843,5739,5103,5345,5225,5290,4903,5926,6004,6423,6323,6278,6385,1313,4056,4464,4767,4700,4829,4405,4357,4312,4264,1024,1090" + }, + "to": { + "startLines": "6,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "215,384,457,523,596,646,686,734,782,827,884,938,988,1050,1118,1195,1254,1319,1382,1437,1497,1560,1614,1674,1727,1789,1874,1955,2005,2064,2107,2160,2203,2254,2304,2364,2417,2468,2514,2562,2610,2656,2703,2753,2798,2857,2909,2961,3004,3051,3107,3162,3217,3261,3303,3344,3394,3453,3504,3553,3602,3649,3696,3743,3788,3839,3892,3967,4026,4083,4157,4221,4290,4368,4478,4582,4655,4721,4776,4841,4906,4955,5038,5116,5154,5199,5247,5309,5366,5421,5480,5547,5605,5667,5715,5760,5808,5859,5925", + "endLines": "8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106", + "endColumns": "14,72,65,72,49,39,47,47,44,56,53,49,61,67,76,58,64,62,54,59,62,53,59,52,61,84,80,49,58,42,52,42,50,49,59,52,50,45,47,47,45,46,49,44,58,51,51,42,46,55,54,54,43,41,40,49,58,50,48,48,46,46,46,44,50,52,74,58,56,73,63,68,77,109,103,72,65,54,64,64,48,82,77,37,44,47,61,56,54,58,66,57,61,47,44,47,50,65,65", + "endOffsets": "379,452,518,591,641,681,729,777,822,879,933,983,1045,1113,1190,1249,1314,1377,1432,1492,1555,1609,1669,1722,1784,1869,1950,2000,2059,2102,2155,2198,2249,2299,2359,2412,2463,2509,2557,2605,2651,2698,2748,2793,2852,2904,2956,2999,3046,3102,3157,3212,3256,3298,3339,3389,3448,3499,3548,3597,3644,3691,3738,3783,3834,3887,3962,4021,4078,4152,4216,4285,4363,4473,4577,4650,4716,4771,4836,4901,4950,5033,5111,5149,5194,5242,5304,5361,5416,5475,5542,5600,5662,5710,5755,5803,5854,5920,5986" + } + } + ] + } + ] +} \ No newline at end of file diff --git a/app/build/intermediates/blame/res/release/multi-v2/values-zh-rCN.json b/app/build/intermediates/blame/res/release/multi-v2/values-zh-rCN.json new file mode 100644 index 0000000..a95d85c --- /dev/null +++ b/app/build/intermediates/blame/res/release/multi-v2/values-zh-rCN.json @@ -0,0 +1,47 @@ +{ + "logs": [ + { + "outputFile": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\incremental\\mergeReleaseResources\\merged.dir\\values-zh-rCN\\values-zh-rCN.xml", + "map": [ + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values-zh-rCN\\arrays.xml", + "from": { + "startLines": "18", + "startColumns": "4", + "startOffsets": "712", + "endLines": "21", + "endColumns": "19", + "endOffsets": "817" + }, + "to": { + "startLines": "2", + "startColumns": "4", + "startOffsets": "105", + "endLines": "5", + "endColumns": "19", + "endOffsets": "210" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values-zh-rCN\\strings.xml", + "from": { + "startLines": "121,71,70,69,68,19,20,21,112,113,120,119,26,77,78,76,75,74,90,89,88,80,60,29,30,81,72,114,67,63,38,44,49,39,59,58,57,53,52,50,51,54,55,45,66,56,64,43,48,47,46,62,42,61,40,41,65,28,34,36,33,35,32,31,25,24,97,96,99,111,104,103,105,106,108,107,98,102,100,101,95,109,110,118,116,115,117,27,79,87,92,91,93,86,85,84,83,22,23", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "6532,3495,3429,3356,3306,827,867,915,6083,6128,6478,6428,1199,3861,3929,3802,3737,3674,4592,4532,4469,4061,2877,1369,1422,4115,3568,6185,3247,3034,1798,2079,2325,1851,2817,2764,2713,2518,2470,2376,2424,2564,2611,2122,3188,2661,3077,2036,2278,2222,2167,2979,1992,2937,1901,1942,3129,1318,1623,1719,1576,1672,1529,1484,1148,1095,4967,4908,5108,6009,5419,5350,5483,5561,5744,5671,5042,5295,5165,5230,4859,5848,5931,6390,6283,6235,6328,1261,4006,4410,4705,4647,4772,4362,4317,4269,4218,963,1029", + "endLines": "123,71,70,69,68,19,20,21,112,113,120,119,26,77,78,76,75,74,90,89,88,80,60,29,30,81,72,114,67,63,38,44,49,39,59,58,57,53,52,50,51,54,55,45,66,56,64,43,48,47,46,62,42,61,40,41,65,28,34,36,33,35,32,31,25,24,97,96,99,111,104,103,105,106,108,107,98,102,100,101,95,109,110,118,116,115,117,27,79,87,92,91,93,86,85,84,83,22,23", + "endColumns": "14,72,65,72,49,39,47,47,44,56,53,49,61,67,76,58,64,62,54,59,62,53,59,52,61,84,80,49,58,42,52,42,50,49,59,52,50,45,47,47,45,46,49,44,58,51,51,42,46,55,54,54,43,41,40,49,58,50,48,48,46,46,46,44,50,52,74,58,56,73,63,68,77,109,103,72,65,54,64,64,48,82,77,37,44,47,61,56,54,58,66,57,61,47,44,47,50,65,65", + "endOffsets": "6704,3563,3490,3424,3351,862,910,958,6123,6180,6527,6473,1256,3924,4001,3856,3797,3732,4642,4587,4527,4110,2932,1417,1479,4195,3644,6230,3301,3072,1846,2117,2371,1896,2872,2812,2759,2559,2513,2419,2465,2606,2656,2162,3242,2708,3124,2074,2320,2273,2217,3029,2031,2974,1937,1987,3183,1364,1667,1763,1618,1714,1571,1524,1194,1143,5037,4962,5160,6078,5478,5414,5556,5666,5843,5739,5103,5345,5225,5290,4903,5926,6004,6423,6323,6278,6385,1313,4056,4464,4767,4700,4829,4405,4357,4312,4264,1024,1090" + }, + "to": { + "startLines": "6,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "215,384,457,523,596,646,686,734,782,827,884,938,988,1050,1118,1195,1254,1319,1382,1437,1497,1560,1614,1674,1727,1789,1874,1955,2005,2064,2107,2160,2203,2254,2304,2364,2417,2468,2514,2562,2610,2656,2703,2753,2798,2857,2909,2961,3004,3051,3107,3162,3217,3261,3303,3344,3394,3453,3504,3553,3602,3649,3696,3743,3788,3839,3892,3967,4026,4083,4157,4221,4290,4368,4478,4582,4655,4721,4776,4841,4906,4955,5038,5116,5154,5199,5247,5309,5366,5421,5480,5547,5605,5667,5715,5760,5808,5859,5925", + "endLines": "8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106", + "endColumns": "14,72,65,72,49,39,47,47,44,56,53,49,61,67,76,58,64,62,54,59,62,53,59,52,61,84,80,49,58,42,52,42,50,49,59,52,50,45,47,47,45,46,49,44,58,51,51,42,46,55,54,54,43,41,40,49,58,50,48,48,46,46,46,44,50,52,74,58,56,73,63,68,77,109,103,72,65,54,64,64,48,82,77,37,44,47,61,56,54,58,66,57,61,47,44,47,50,65,65", + "endOffsets": "379,452,518,591,641,681,729,777,822,879,933,983,1045,1113,1190,1249,1314,1377,1432,1492,1555,1609,1669,1722,1784,1869,1950,2000,2059,2102,2155,2198,2249,2299,2359,2412,2463,2509,2557,2605,2651,2698,2748,2793,2852,2904,2956,2999,3046,3102,3157,3212,3256,3298,3339,3389,3448,3499,3548,3597,3644,3691,3738,3783,3834,3887,3962,4021,4078,4152,4216,4285,4363,4473,4577,4650,4716,4771,4836,4901,4950,5033,5111,5149,5194,5242,5304,5361,5416,5475,5542,5600,5662,5710,5755,5803,5854,5920,5986" + } + } + ] + } + ] +} \ No newline at end of file diff --git a/app/build/intermediates/blame/res/release/multi-v2/values-zh-rTW.json b/app/build/intermediates/blame/res/release/multi-v2/values-zh-rTW.json new file mode 100644 index 0000000..efc70a1 --- /dev/null +++ b/app/build/intermediates/blame/res/release/multi-v2/values-zh-rTW.json @@ -0,0 +1,47 @@ +{ + "logs": [ + { + "outputFile": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\incremental\\mergeReleaseResources\\merged.dir\\values-zh-rTW\\values-zh-rTW.xml", + "map": [ + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values-zh-rTW\\arrays.xml", + "from": { + "startLines": "18", + "startColumns": "4", + "startOffsets": "712", + "endLines": "21", + "endColumns": "19", + "endOffsets": "817" + }, + "to": { + "startLines": "2", + "startColumns": "4", + "startOffsets": "105", + "endLines": "5", + "endColumns": "19", + "endOffsets": "210" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values-zh-rTW\\strings.xml", + "from": { + "startLines": "122,72,71,70,69,19,20,21,112,113,121,120,26,76,77,75,74,73,89,88,87,79,61,29,30,80,37,114,68,64,39,45,50,40,60,59,58,54,53,51,52,55,56,46,67,57,65,44,49,48,47,63,43,62,41,42,66,28,34,36,33,35,32,31,25,24,96,95,98,110,103,102,104,105,107,106,97,101,99,100,94,108,109,119,117,116,118,27,78,86,91,90,92,85,84,83,82,22,23", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "6507,3575,3509,3436,3386,827,867,915,6057,6102,6453,6403,1199,3835,3903,3776,3710,3647,4565,4505,4442,4035,2957,1369,1422,4089,1768,6159,3327,3114,1878,2159,2405,1931,2897,2844,2793,2598,2550,2456,2504,2644,2691,2202,3268,2741,3157,2116,2358,2302,2247,3059,2072,3017,1981,2022,3209,1318,1623,1719,1576,1672,1529,1484,1148,1095,4940,4881,5081,5982,5392,5323,5456,5534,5717,5644,5015,5268,5138,5203,4832,5821,5904,6365,6258,6210,6303,1261,3980,4383,4678,4620,4745,4335,4290,4242,4191,963,1029", + "endLines": "124,72,71,70,69,19,20,21,112,113,121,120,26,76,77,75,74,73,89,88,87,79,61,29,30,80,37,114,68,64,39,45,50,40,60,59,58,54,53,51,52,55,56,46,67,57,65,44,49,48,47,63,43,62,41,42,66,28,34,36,33,35,32,31,25,24,96,95,98,110,103,102,104,105,107,106,97,101,99,100,94,108,109,119,117,116,118,27,78,86,91,90,92,85,84,83,82,22,23", + "endColumns": "14,71,65,72,49,39,47,47,44,56,53,49,61,67,76,58,65,62,54,59,62,53,59,52,61,83,79,49,58,42,52,42,50,49,59,52,50,45,47,47,45,46,49,44,58,51,51,42,46,55,54,54,43,41,40,49,58,50,48,48,46,46,46,44,50,52,74,58,56,73,63,68,77,109,103,72,65,54,64,64,48,82,77,37,44,47,61,56,54,58,66,57,61,47,44,47,50,65,65", + "endOffsets": "6679,3642,3570,3504,3431,862,910,958,6097,6154,6502,6448,1256,3898,3975,3830,3771,3705,4615,4560,4500,4084,3012,1417,1479,4168,1843,6204,3381,3152,1926,2197,2451,1976,2952,2892,2839,2639,2593,2499,2545,2686,2736,2242,3322,2788,3204,2154,2400,2353,2297,3109,2111,3054,2017,2067,3263,1364,1667,1763,1618,1714,1571,1524,1194,1143,5010,4935,5133,6051,5451,5387,5529,5639,5816,5712,5076,5318,5198,5263,4876,5899,5977,6398,6298,6253,6360,1313,4030,4437,4740,4673,4802,4378,4330,4285,4237,1024,1090" + }, + "to": { + "startLines": "6,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "215,384,456,522,595,645,685,733,781,826,883,937,987,1049,1117,1194,1253,1319,1382,1437,1497,1560,1614,1674,1727,1789,1873,1953,2003,2062,2105,2158,2201,2252,2302,2362,2415,2466,2512,2560,2608,2654,2701,2751,2796,2855,2907,2959,3002,3049,3105,3160,3215,3259,3301,3342,3392,3451,3502,3551,3600,3647,3694,3741,3786,3837,3890,3965,4024,4081,4155,4219,4288,4366,4476,4580,4653,4719,4774,4839,4904,4953,5036,5114,5152,5197,5245,5307,5364,5419,5478,5545,5603,5665,5713,5758,5806,5857,5923", + "endLines": "8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106", + "endColumns": "14,71,65,72,49,39,47,47,44,56,53,49,61,67,76,58,65,62,54,59,62,53,59,52,61,83,79,49,58,42,52,42,50,49,59,52,50,45,47,47,45,46,49,44,58,51,51,42,46,55,54,54,43,41,40,49,58,50,48,48,46,46,46,44,50,52,74,58,56,73,63,68,77,109,103,72,65,54,64,64,48,82,77,37,44,47,61,56,54,58,66,57,61,47,44,47,50,65,65", + "endOffsets": "379,451,517,590,640,680,728,776,821,878,932,982,1044,1112,1189,1248,1314,1377,1432,1492,1555,1609,1669,1722,1784,1868,1948,1998,2057,2100,2153,2196,2247,2297,2357,2410,2461,2507,2555,2603,2649,2696,2746,2791,2850,2902,2954,2997,3044,3100,3155,3210,3254,3296,3337,3387,3446,3497,3546,3595,3642,3689,3736,3781,3832,3885,3960,4019,4076,4150,4214,4283,4361,4471,4575,4648,4714,4769,4834,4899,4948,5031,5109,5147,5192,5240,5302,5359,5414,5473,5540,5598,5660,5708,5753,5801,5852,5918,5984" + } + } + ] + } + ] +} \ No newline at end of file diff --git a/app/build/intermediates/blame/res/release/multi-v2/values.json b/app/build/intermediates/blame/res/release/multi-v2/values.json new file mode 100644 index 0000000..4ab4b75 --- /dev/null +++ b/app/build/intermediates/blame/res/release/multi-v2/values.json @@ -0,0 +1,100 @@ +{ + "logs": [ + { + "outputFile": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\incremental\\mergeReleaseResources\\merged.dir\\values\\values.xml", + "map": [ + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values\\arrays.xml", + "from": { + "startLines": "19,26", + "startColumns": "4,4", + "startOffsets": "739,1047", + "endLines": "24,29", + "endColumns": "19,19", + "endOffsets": "1041,1162" + }, + "to": { + "startLines": "2,8", + "startColumns": "4,4", + "startOffsets": "105,412", + "endLines": "7,11", + "endColumns": "19,19", + "endOffsets": "407,527" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values\\styles.xml", + "from": { + "startLines": "50,55,64,60,22,26,30,35,40,18,45", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "2062,2267,2640,2479,895,1078,1263,1449,1653,712,1860", + "endLines": "53,58,67,62,25,29,33,38,43,21,48", + "endColumns": "12,12,12,12,12,12,12,12,12,12,12", + "endOffsets": "2261,2473,2843,2634,1073,1258,1443,1647,1854,890,2056" + }, + "to": { + "startLines": "125,129,133,137,140,144,148,152,156,160,164", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "8276,8480,8691,8898,9058,9241,9426,9611,9814,10020,10203", + "endLines": "128,132,136,139,143,147,151,155,159,163,167", + "endColumns": "12,12,12,12,12,12,12,12,12,12,12", + "endOffsets": "8475,8686,8893,9053,9236,9421,9606,9809,10015,10198,10399" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values\\colors.xml", + "from": { + "startLines": "18", + "startColumns": "4", + "startOffsets": "712", + "endColumns": "56", + "endOffsets": "764" + }, + "to": { + "startLines": "12", + "startColumns": "4", + "startOffsets": "532", + "endColumns": "56", + "endOffsets": "584" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values\\dimens.xml", + "from": { + "startLines": "19,20,21,22,18", + "startColumns": "4,4,4,4,4", + "startOffsets": "764,816,869,922,712", + "endColumns": "51,52,52,51,51", + "endOffsets": "811,864,917,969,759" + }, + "to": { + "startLines": "13,14,15,16,17", + "startColumns": "4,4,4,4,4", + "startOffsets": "589,641,694,747,799", + "endColumns": "51,52,52,51,51", + "endOffsets": "636,689,742,794,846" + } + }, + { + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\values\\strings.xml", + "from": { + "startLines": "128,72,75,74,73,19,20,21,118,119,127,126,26,81,82,80,79,78,94,93,92,84,39,38,64,29,30,85,41,76,120,71,67,42,48,53,43,63,62,61,57,56,54,55,58,59,49,70,60,68,47,52,51,50,66,46,65,44,45,69,28,34,36,33,35,32,31,25,24,101,100,104,116,109,108,110,111,113,112,102,103,107,105,106,99,114,115,125,123,122,124,27,83,91,96,95,97,90,89,88,87,22,23", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "8008,3898,4159,4063,3994,827,870,922,7506,7555,7950,7899,1282,4613,4707,4542,4458,4375,5574,5491,5389,4883,2004,1953,3397,1486,1539,4944,2097,4242,7618,3827,3582,2156,2471,2772,2214,3326,3265,3208,2986,2934,2831,2884,3036,3086,2518,3761,3146,3631,2424,2717,2629,2571,3520,2374,3475,2271,2314,3694,1431,1750,1858,1703,1805,1647,1599,1227,1174,6030,5963,6271,7409,6635,6554,6709,6798,7040,6961,6114,6189,6495,6335,6415,5908,7184,7306,7858,7731,7674,7784,1366,4815,5303,5709,5640,5789,5244,5189,5127,5067,974,1084", + "endLines": "132,72,75,74,73,19,20,21,118,119,127,126,26,81,82,80,79,78,94,93,92,84,39,38,64,29,30,85,41,76,120,71,67,42,48,53,43,63,62,61,57,56,54,55,58,59,49,70,60,68,47,52,51,50,66,46,65,44,45,69,28,34,36,33,35,32,31,25,24,101,100,104,116,109,108,110,111,113,112,102,103,107,105,106,99,114,115,125,123,122,124,27,83,91,96,95,97,90,89,88,87,22,23", + "endColumns": "14,95,82,95,68,42,51,51,48,62,57,50,83,93,107,70,83,82,65,82,101,60,61,50,77,52,59,104,58,101,54,70,48,57,46,58,56,70,60,56,49,51,52,49,49,59,52,65,61,62,46,54,87,57,61,49,44,42,59,66,54,54,52,46,52,55,47,54,52,83,66,63,95,73,80,88,162,143,78,74,81,58,79,79,54,121,102,40,52,56,73,64,67,85,79,68,93,58,54,61,59,109,89", + "endOffsets": "8412,3989,4237,4154,4058,865,917,969,7550,7613,8003,7945,1361,4702,4810,4608,4537,4453,5635,5569,5486,4939,2061,1999,3470,1534,1594,5044,2151,4339,7668,3893,3626,2209,2513,2826,2266,3392,3321,3260,3031,2981,2879,2929,3081,3141,2566,3822,3203,3689,2466,2767,2712,2624,3577,2419,3515,2309,2369,3756,1481,1800,1906,1745,1853,1698,1642,1277,1222,6109,6025,6330,7500,6704,6630,6793,6956,7179,7035,6184,6266,6549,6410,6490,5958,7301,7404,7894,7779,7726,7853,1426,4878,5384,5784,5704,5878,5298,5239,5184,5122,1079,1169" + }, + "to": { + "startLines": "18,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124", + "startColumns": "4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4", + "startOffsets": "851,1244,1340,1423,1519,1588,1631,1683,1735,1784,1847,1905,1956,2040,2134,2242,2313,2397,2480,2546,2629,2731,2792,2854,2905,2983,3036,3096,3201,3260,3362,3417,3488,3537,3595,3642,3701,3758,3829,3890,3947,3997,4049,4102,4152,4202,4262,4315,4381,4443,4506,4553,4608,4696,4754,4816,4866,4911,4954,5014,5081,5136,5191,5244,5291,5344,5400,5448,5503,5556,5640,5707,5771,5867,5941,6022,6111,6274,6418,6497,6572,6654,6713,6793,6873,6928,7050,7153,7194,7247,7304,7378,7443,7511,7597,7677,7746,7840,7899,7954,8016,8076,8186", + "endLines": "22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124", + "endColumns": "14,95,82,95,68,42,51,51,48,62,57,50,83,93,107,70,83,82,65,82,101,60,61,50,77,52,59,104,58,101,54,70,48,57,46,58,56,70,60,56,49,51,52,49,49,59,52,65,61,62,46,54,87,57,61,49,44,42,59,66,54,54,52,46,52,55,47,54,52,83,66,63,95,73,80,88,162,143,78,74,81,58,79,79,54,121,102,40,52,56,73,64,67,85,79,68,93,58,54,61,59,109,89", + "endOffsets": "1239,1335,1418,1514,1583,1626,1678,1730,1779,1842,1900,1951,2035,2129,2237,2308,2392,2475,2541,2624,2726,2787,2849,2900,2978,3031,3091,3196,3255,3357,3412,3483,3532,3590,3637,3696,3753,3824,3885,3942,3992,4044,4097,4147,4197,4257,4310,4376,4438,4501,4548,4603,4691,4749,4811,4861,4906,4949,5009,5076,5131,5186,5239,5286,5339,5395,5443,5498,5551,5635,5702,5766,5862,5936,6017,6106,6269,6413,6492,6567,6649,6708,6788,6868,6923,7045,7148,7189,7242,7299,7373,7438,7506,7592,7672,7741,7835,7894,7949,8011,8071,8181,8271" + } + } + ] + } + ] +} \ No newline at end of file diff --git a/app/build/intermediates/blame/res/release/single/release.json b/app/build/intermediates/blame/res/release/single/release.json new file mode 100644 index 0000000..49feca0 --- /dev/null +++ b/app/build/intermediates/blame/res/release/single/release.json @@ -0,0 +1,382 @@ +[ + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\menu_sub_folder.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\sub_folder.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_folder_list_item.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\folder_list_item.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_widget_2x_yellow.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_yellow.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_menu_delete.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\menu_delete.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_call_record.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\call_record.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_yellow_up.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_up.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_settings_header.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\settings_header.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_widget_4x_red.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_red.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_font_small.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_small.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_note_list_dropdown_menu.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_list_dropdown_menu.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\raw-zh-rCN_introduction.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\raw-zh-rCN\\introduction" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_green_single.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_green_single.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_yellow_single.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_single.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_note_item.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_item.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_blue_up.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_blue_up.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_edit_title_green.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_green.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\raw_introduction.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\raw\\introduction" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\color_secondary_text_dark.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\color\\secondary_text_dark.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_edit_title_blue.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_blue.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_blue_down.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_blue_down.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\menu_note_list_options.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\note_list_options.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_dialog_edit_text.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\dialog_edit_text.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_note_list.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_list.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_title_alert.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\title_alert.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_icon_app.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\icon_app.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_bg_color_btn_mask.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\bg_color_btn_mask.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_menu_move.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\menu_move.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\xml_searchable.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\xml\\searchable.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_widget_2x_green.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_green.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_note_edit_color_selector_panel.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\note_edit_color_selector_panel.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_widget_2x_red.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_red.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_footer_bg.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_footer_bg.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_font_normal.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_normal.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_edit_title_red.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_red.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_folder.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_folder.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_account_dialog_title.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\account_dialog_title.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_widget_4x_yellow.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_yellow.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_white_single.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_white_single.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_add_account_text.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\add_account_text.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_dropdown_icon.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\dropdown_icon.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_green_middle.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_green_middle.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\menu_note_edit.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\note_edit.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_widget_4x_white.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_white.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_red_down.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_red_down.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_new_note_normal.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\new_note_normal.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_font_large.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_large.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_bg_btn_set_color.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\bg_btn_set_color.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_white_up.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_white_up.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_note_edit.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_edit.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_new_note_pressed.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\new_note_pressed.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_notification.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\notification.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\menu_note_list_dropdown.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\note_list_dropdown.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_background.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_background.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_red_middle.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_red_middle.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_edit_white.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_white.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_widget_4x_green.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_green.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_blue_middle.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_blue_middle.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_blue_single.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_blue_single.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_widget_2x_white.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_white.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\menu_call_record_folder.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\call_record_folder.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_edit_yellow.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_yellow.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_white_down.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_white_down.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_green_up.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_green_up.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_edit_green.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_green.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\menu_note_list.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\note_list.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\xml_widget_2x_info.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\xml\\widget_2x_info.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_edit_blue.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_blue.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_red_single.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_red_single.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_edit_red.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_red.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_widget_4x.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\widget_4x.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_widget_4x_blue.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_blue.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_clock.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\clock.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_font_size_selector_bg.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_size_selector_bg.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_search_result.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\search_result.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_note_edit_list_item.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_edit_list_item.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\color_primary_text_dark.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\color\\primary_text_dark.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_note_list_footer.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_list_footer.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\xml_preferences.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\xml\\preferences.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_yellow_down.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_down.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_delete.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\delete.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_white_middle.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_white_middle.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_widget_2x_blue.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_blue.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_edit_title_white.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_white.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_edit_title_yellow.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_yellow.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\xml_widget_4x_info.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\xml\\widget_4x_info.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_selected.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\selected.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_red_up.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_red_up.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\menu_call_note_edit.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\call_note_edit.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_datetime_picker.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\datetime_picker.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_title_bar_bg.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\title_bar_bg.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_green_down.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_green_down.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable_new_note.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable\\new_note.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_widget_2x.xml.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\widget_2x.xml" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_yellow_middle.9.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_middle.9.png" + }, + { + "merged": "E:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_font_super.png.flat", + "source": "E:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_super.png" + } +] \ No newline at end of file diff --git a/app/build/intermediates/classes-jar/debug/classes.jar b/app/build/intermediates/classes-jar/debug/classes.jar new file mode 100644 index 0000000..e7ab0a3 Binary files /dev/null and b/app/build/intermediates/classes-jar/debug/classes.jar differ diff --git a/app/build/intermediates/classes/androidTest/debug/net/micode/notes/test/BuildConfig.class b/app/build/intermediates/classes/androidTest/debug/net/micode/notes/test/BuildConfig.class new file mode 100644 index 0000000..04844bf Binary files /dev/null and b/app/build/intermediates/classes/androidTest/debug/net/micode/notes/test/BuildConfig.class differ diff --git a/app/build/intermediates/classes/androidTest/debug/net/micode/notes/test/R.class b/app/build/intermediates/classes/androidTest/debug/net/micode/notes/test/R.class new file mode 100644 index 0000000..fd0b254 Binary files /dev/null and b/app/build/intermediates/classes/androidTest/debug/net/micode/notes/test/R.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/BuildConfig.class b/app/build/intermediates/classes/debug/net/micode/notes/BuildConfig.class new file mode 100644 index 0000000..1d7a3f6 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/BuildConfig.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/R$array.class b/app/build/intermediates/classes/debug/net/micode/notes/R$array.class new file mode 100644 index 0000000..e8141dd Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/R$array.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/R$color.class b/app/build/intermediates/classes/debug/net/micode/notes/R$color.class new file mode 100644 index 0000000..82e6a7f Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/R$color.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/R$dimen.class b/app/build/intermediates/classes/debug/net/micode/notes/R$dimen.class new file mode 100644 index 0000000..fed0665 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/R$dimen.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/R$drawable.class b/app/build/intermediates/classes/debug/net/micode/notes/R$drawable.class new file mode 100644 index 0000000..cccc1e1 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/R$drawable.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/R$id.class b/app/build/intermediates/classes/debug/net/micode/notes/R$id.class new file mode 100644 index 0000000..96c0586 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/R$id.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/R$layout.class b/app/build/intermediates/classes/debug/net/micode/notes/R$layout.class new file mode 100644 index 0000000..d7dd89c Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/R$layout.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/R$menu.class b/app/build/intermediates/classes/debug/net/micode/notes/R$menu.class new file mode 100644 index 0000000..6b73701 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/R$menu.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/R$plurals.class b/app/build/intermediates/classes/debug/net/micode/notes/R$plurals.class new file mode 100644 index 0000000..d8f69c2 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/R$plurals.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/R$raw.class b/app/build/intermediates/classes/debug/net/micode/notes/R$raw.class new file mode 100644 index 0000000..9014906 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/R$raw.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/R$string.class b/app/build/intermediates/classes/debug/net/micode/notes/R$string.class new file mode 100644 index 0000000..f552f1f Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/R$string.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/R$style.class b/app/build/intermediates/classes/debug/net/micode/notes/R$style.class new file mode 100644 index 0000000..53d448f Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/R$style.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/R$xml.class b/app/build/intermediates/classes/debug/net/micode/notes/R$xml.class new file mode 100644 index 0000000..e921241 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/R$xml.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/R.class b/app/build/intermediates/classes/debug/net/micode/notes/R.class new file mode 100644 index 0000000..cdd1372 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/R.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/data/Contact.class b/app/build/intermediates/classes/debug/net/micode/notes/data/Contact.class new file mode 100644 index 0000000..77f2300 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/data/Contact.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/data/Notes$CallNote.class b/app/build/intermediates/classes/debug/net/micode/notes/data/Notes$CallNote.class new file mode 100644 index 0000000..d765e52 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/data/Notes$CallNote.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/data/Notes$DataColumns.class b/app/build/intermediates/classes/debug/net/micode/notes/data/Notes$DataColumns.class new file mode 100644 index 0000000..2dca96a Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/data/Notes$DataColumns.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/data/Notes$DataConstants.class b/app/build/intermediates/classes/debug/net/micode/notes/data/Notes$DataConstants.class new file mode 100644 index 0000000..1f14a2d Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/data/Notes$DataConstants.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/data/Notes$NoteColumns.class b/app/build/intermediates/classes/debug/net/micode/notes/data/Notes$NoteColumns.class new file mode 100644 index 0000000..51cf42a Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/data/Notes$NoteColumns.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/data/Notes$TextNote.class b/app/build/intermediates/classes/debug/net/micode/notes/data/Notes$TextNote.class new file mode 100644 index 0000000..6aaf17a Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/data/Notes$TextNote.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/data/Notes.class b/app/build/intermediates/classes/debug/net/micode/notes/data/Notes.class new file mode 100644 index 0000000..3e2d98c Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/data/Notes.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/data/NotesDatabaseHelper$TABLE.class b/app/build/intermediates/classes/debug/net/micode/notes/data/NotesDatabaseHelper$TABLE.class new file mode 100644 index 0000000..03731af Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/data/NotesDatabaseHelper$TABLE.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/data/NotesDatabaseHelper.class b/app/build/intermediates/classes/debug/net/micode/notes/data/NotesDatabaseHelper.class new file mode 100644 index 0000000..727889e Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/data/NotesDatabaseHelper.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/data/NotesProvider.class b/app/build/intermediates/classes/debug/net/micode/notes/data/NotesProvider.class new file mode 100644 index 0000000..a870b31 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/data/NotesProvider.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/gtask/data/MetaData.class b/app/build/intermediates/classes/debug/net/micode/notes/gtask/data/MetaData.class new file mode 100644 index 0000000..0a3a356 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/gtask/data/MetaData.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/gtask/data/Node.class b/app/build/intermediates/classes/debug/net/micode/notes/gtask/data/Node.class new file mode 100644 index 0000000..2b5118e Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/gtask/data/Node.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/gtask/data/SqlData.class b/app/build/intermediates/classes/debug/net/micode/notes/gtask/data/SqlData.class new file mode 100644 index 0000000..645f1f5 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/gtask/data/SqlData.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/gtask/data/SqlNote.class b/app/build/intermediates/classes/debug/net/micode/notes/gtask/data/SqlNote.class new file mode 100644 index 0000000..8acd622 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/gtask/data/SqlNote.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/gtask/data/Task.class b/app/build/intermediates/classes/debug/net/micode/notes/gtask/data/Task.class new file mode 100644 index 0000000..7a0c4ed Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/gtask/data/Task.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/gtask/data/TaskList.class b/app/build/intermediates/classes/debug/net/micode/notes/gtask/data/TaskList.class new file mode 100644 index 0000000..8e8396b Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/gtask/data/TaskList.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/gtask/exception/ActionFailureException.class b/app/build/intermediates/classes/debug/net/micode/notes/gtask/exception/ActionFailureException.class new file mode 100644 index 0000000..9ae78d8 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/gtask/exception/ActionFailureException.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/gtask/exception/NetworkFailureException.class b/app/build/intermediates/classes/debug/net/micode/notes/gtask/exception/NetworkFailureException.class new file mode 100644 index 0000000..c29e580 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/gtask/exception/NetworkFailureException.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskASyncTask$1.class b/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskASyncTask$1.class new file mode 100644 index 0000000..02960fb Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskASyncTask$1.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.class b/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.class new file mode 100644 index 0000000..ebb2251 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskASyncTask.class b/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskASyncTask.class new file mode 100644 index 0000000..60917a9 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskASyncTask.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskClient.class b/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskClient.class new file mode 100644 index 0000000..323fe9e Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskClient.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskManager.class b/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskManager.class new file mode 100644 index 0000000..405d717 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskManager.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskSyncService$1.class b/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskSyncService$1.class new file mode 100644 index 0000000..b20d33f Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskSyncService$1.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskSyncService.class b/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskSyncService.class new file mode 100644 index 0000000..2df0dae Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/gtask/remote/GTaskSyncService.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/model/Note$NoteData.class b/app/build/intermediates/classes/debug/net/micode/notes/model/Note$NoteData.class new file mode 100644 index 0000000..34b9be0 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/model/Note$NoteData.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/model/Note.class b/app/build/intermediates/classes/debug/net/micode/notes/model/Note.class new file mode 100644 index 0000000..8fd931d Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/model/Note.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.class b/app/build/intermediates/classes/debug/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.class new file mode 100644 index 0000000..6bbe48a Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/model/WorkingNote.class b/app/build/intermediates/classes/debug/net/micode/notes/model/WorkingNote.class new file mode 100644 index 0000000..a86888d Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/model/WorkingNote.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/tool/BackupUtils$TextExport.class b/app/build/intermediates/classes/debug/net/micode/notes/tool/BackupUtils$TextExport.class new file mode 100644 index 0000000..0e4d0bb Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/tool/BackupUtils$TextExport.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/tool/BackupUtils.class b/app/build/intermediates/classes/debug/net/micode/notes/tool/BackupUtils.class new file mode 100644 index 0000000..32ebe9d Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/tool/BackupUtils.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/tool/DataUtils.class b/app/build/intermediates/classes/debug/net/micode/notes/tool/DataUtils.class new file mode 100644 index 0000000..ccaf3f6 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/tool/DataUtils.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/tool/GTaskStringUtils.class b/app/build/intermediates/classes/debug/net/micode/notes/tool/GTaskStringUtils.class new file mode 100644 index 0000000..93c2bc9 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/tool/GTaskStringUtils.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/tool/ResourceParser$NoteBgResources.class b/app/build/intermediates/classes/debug/net/micode/notes/tool/ResourceParser$NoteBgResources.class new file mode 100644 index 0000000..05f45bb Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/tool/ResourceParser$NoteBgResources.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/tool/ResourceParser$NoteItemBgResources.class b/app/build/intermediates/classes/debug/net/micode/notes/tool/ResourceParser$NoteItemBgResources.class new file mode 100644 index 0000000..4bccb47 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/tool/ResourceParser$NoteItemBgResources.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/tool/ResourceParser$TextAppearanceResources.class b/app/build/intermediates/classes/debug/net/micode/notes/tool/ResourceParser$TextAppearanceResources.class new file mode 100644 index 0000000..59b0099 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/tool/ResourceParser$TextAppearanceResources.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/tool/ResourceParser$WidgetBgResources.class b/app/build/intermediates/classes/debug/net/micode/notes/tool/ResourceParser$WidgetBgResources.class new file mode 100644 index 0000000..be2abab Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/tool/ResourceParser$WidgetBgResources.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/tool/ResourceParser.class b/app/build/intermediates/classes/debug/net/micode/notes/tool/ResourceParser.class new file mode 100644 index 0000000..d5f24f4 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/tool/ResourceParser.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/AlarmAlertActivity.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/AlarmAlertActivity.class new file mode 100644 index 0000000..e052c4c Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/AlarmAlertActivity.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/AlarmInitReceiver.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/AlarmInitReceiver.class new file mode 100644 index 0000000..3483f88 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/AlarmInitReceiver.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/AlarmReceiver.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/AlarmReceiver.class new file mode 100644 index 0000000..68c5c88 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/AlarmReceiver.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePicker$1.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePicker$1.class new file mode 100644 index 0000000..eff3719 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePicker$1.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePicker$2.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePicker$2.class new file mode 100644 index 0000000..afe201e Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePicker$2.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePicker$3.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePicker$3.class new file mode 100644 index 0000000..255d90a Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePicker$3.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePicker$4.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePicker$4.class new file mode 100644 index 0000000..e44ae63 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePicker$4.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.class new file mode 100644 index 0000000..86c542e Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePicker.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePicker.class new file mode 100644 index 0000000..6882229 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePicker.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePickerDialog$1.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePickerDialog$1.class new file mode 100644 index 0000000..1b880ba Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePickerDialog$1.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.class new file mode 100644 index 0000000..5adfb41 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePickerDialog.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePickerDialog.class new file mode 100644 index 0000000..45eea44 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/DateTimePickerDialog.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/DropdownMenu$1.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/DropdownMenu$1.class new file mode 100644 index 0000000..03711b9 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/DropdownMenu$1.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/DropdownMenu.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/DropdownMenu.class new file mode 100644 index 0000000..1d007e3 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/DropdownMenu.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/FoldersListAdapter$FolderListItem.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/FoldersListAdapter$FolderListItem.class new file mode 100644 index 0000000..9634d11 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/FoldersListAdapter$FolderListItem.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/FoldersListAdapter.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/FoldersListAdapter.class new file mode 100644 index 0000000..3139462 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/FoldersListAdapter.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$1.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$1.class new file mode 100644 index 0000000..f789b13 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$1.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$10.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$10.class new file mode 100644 index 0000000..122854a Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$10.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$11.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$11.class new file mode 100644 index 0000000..7a424f1 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$11.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$12.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$12.class new file mode 100644 index 0000000..cc1a15f Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$12.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$2$1.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$2$1.class new file mode 100644 index 0000000..3b17ec4 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$2$1.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$2.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$2.class new file mode 100644 index 0000000..5fb382a Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$2.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$3.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$3.class new file mode 100644 index 0000000..7c9dafd Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$3.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$4.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$4.class new file mode 100644 index 0000000..63885e8 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$4.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$5.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$5.class new file mode 100644 index 0000000..5c1d045 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$5.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$6.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$6.class new file mode 100644 index 0000000..564daed Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$6.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$7.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$7.class new file mode 100644 index 0000000..e26f81e Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$7.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$8$1.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$8$1.class new file mode 100644 index 0000000..d310f3f Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$8$1.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$8.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$8.class new file mode 100644 index 0000000..6fbc732 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$8.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$9.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$9.class new file mode 100644 index 0000000..cf6dbb7 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$9.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.class new file mode 100644 index 0000000..8a086e4 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$RatingBarLayout$1.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$RatingBarLayout$1.class new file mode 100644 index 0000000..db80f14 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$RatingBarLayout$1.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$RatingBarLayout.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$RatingBarLayout.class new file mode 100644 index 0000000..d7927c3 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity$RatingBarLayout.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity.class new file mode 100644 index 0000000..3bdd17e Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditActivity.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditText$1.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditText$1.class new file mode 100644 index 0000000..b20379b Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditText$1.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.class new file mode 100644 index 0000000..3b31419 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditText.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditText.class new file mode 100644 index 0000000..bfb9a35 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteEditText.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteItemData.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteItemData.class new file mode 100644 index 0000000..6325003 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NoteItemData.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$1.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$1.class new file mode 100644 index 0000000..7ef1ba4 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$1.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$2.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$2.class new file mode 100644 index 0000000..eb67507 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$2.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$3.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$3.class new file mode 100644 index 0000000..dc50384 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$3.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$4.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$4.class new file mode 100644 index 0000000..f49ae2d Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$4.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$5.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$5.class new file mode 100644 index 0000000..0b7dc11 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$5.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$6.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$6.class new file mode 100644 index 0000000..867493d Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$6.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$7.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$7.class new file mode 100644 index 0000000..e3c31c7 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$7.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$8.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$8.class new file mode 100644 index 0000000..f973f23 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$8.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$9.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$9.class new file mode 100644 index 0000000..58de8b4 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$9.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.class new file mode 100644 index 0000000..dc224fc Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$ListEditState.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$ListEditState.class new file mode 100644 index 0000000..2e6cdfe Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$ListEditState.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$ModeCallback$1.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$ModeCallback$1.class new file mode 100644 index 0000000..a6f3ac4 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$ModeCallback$1.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$ModeCallback$2.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$ModeCallback$2.class new file mode 100644 index 0000000..ac66193 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$ModeCallback$2.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$ModeCallback.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$ModeCallback.class new file mode 100644 index 0000000..fea91da Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$ModeCallback.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.class new file mode 100644 index 0000000..5e269c0 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.class new file mode 100644 index 0000000..522d1ab Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity.class new file mode 100644 index 0000000..64a65a2 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListActivity.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.class new file mode 100644 index 0000000..5914578 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListAdapter.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListAdapter.class new file mode 100644 index 0000000..4e1f881 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListAdapter.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListItem.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListItem.class new file mode 100644 index 0000000..16e6581 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesListItem.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$1.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$1.class new file mode 100644 index 0000000..9d073e3 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$1.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$2.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$2.class new file mode 100644 index 0000000..d2efa89 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$2.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$3.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$3.class new file mode 100644 index 0000000..499e024 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$3.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$4.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$4.class new file mode 100644 index 0000000..ee403d2 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$4.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$5.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$5.class new file mode 100644 index 0000000..811b0fc Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$5.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$6.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$6.class new file mode 100644 index 0000000..9b88bb9 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$6.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$7.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$7.class new file mode 100644 index 0000000..3bafdd6 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$7.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$8.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$8.class new file mode 100644 index 0000000..bd821d1 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$8.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.class new file mode 100644 index 0000000..c65d6a6 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity.class new file mode 100644 index 0000000..f33f824 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/NotesPreferenceActivity.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/OnPasswordInputFinish.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/OnPasswordInputFinish.class new file mode 100644 index 0000000..941f418 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/OnPasswordInputFinish.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/PasswordView$1.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/PasswordView$1.class new file mode 100644 index 0000000..5138c4e Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/PasswordView$1.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/PasswordView$2.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/PasswordView$2.class new file mode 100644 index 0000000..54f45f5 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/PasswordView$2.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/PasswordView$3.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/PasswordView$3.class new file mode 100644 index 0000000..c132d3e Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/PasswordView$3.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/PasswordView$ViewHolder.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/PasswordView$ViewHolder.class new file mode 100644 index 0000000..ef126eb Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/PasswordView$ViewHolder.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/ui/PasswordView.class b/app/build/intermediates/classes/debug/net/micode/notes/ui/PasswordView.class new file mode 100644 index 0000000..f35a218 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/ui/PasswordView.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/widget/NoteWidgetProvider.class b/app/build/intermediates/classes/debug/net/micode/notes/widget/NoteWidgetProvider.class new file mode 100644 index 0000000..0e63983 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/widget/NoteWidgetProvider.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/widget/NoteWidgetProvider_2x.class b/app/build/intermediates/classes/debug/net/micode/notes/widget/NoteWidgetProvider_2x.class new file mode 100644 index 0000000..8a9f8a5 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/widget/NoteWidgetProvider_2x.class differ diff --git a/app/build/intermediates/classes/debug/net/micode/notes/widget/NoteWidgetProvider_4x.class b/app/build/intermediates/classes/debug/net/micode/notes/widget/NoteWidgetProvider_4x.class new file mode 100644 index 0000000..c4a7611 Binary files /dev/null and b/app/build/intermediates/classes/debug/net/micode/notes/widget/NoteWidgetProvider_4x.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/BuildConfig.class b/app/build/intermediates/classes/release/net/micode/notes/BuildConfig.class new file mode 100644 index 0000000..7fc7ebe Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/BuildConfig.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/R$array.class b/app/build/intermediates/classes/release/net/micode/notes/R$array.class new file mode 100644 index 0000000..e8141dd Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/R$array.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/R$color.class b/app/build/intermediates/classes/release/net/micode/notes/R$color.class new file mode 100644 index 0000000..82e6a7f Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/R$color.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/R$dimen.class b/app/build/intermediates/classes/release/net/micode/notes/R$dimen.class new file mode 100644 index 0000000..fed0665 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/R$dimen.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/R$drawable.class b/app/build/intermediates/classes/release/net/micode/notes/R$drawable.class new file mode 100644 index 0000000..adb2f25 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/R$drawable.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/R$id.class b/app/build/intermediates/classes/release/net/micode/notes/R$id.class new file mode 100644 index 0000000..fe279be Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/R$id.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/R$layout.class b/app/build/intermediates/classes/release/net/micode/notes/R$layout.class new file mode 100644 index 0000000..60585b8 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/R$layout.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/R$menu.class b/app/build/intermediates/classes/release/net/micode/notes/R$menu.class new file mode 100644 index 0000000..e610fb6 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/R$menu.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/R$plurals.class b/app/build/intermediates/classes/release/net/micode/notes/R$plurals.class new file mode 100644 index 0000000..e324daf Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/R$plurals.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/R$raw.class b/app/build/intermediates/classes/release/net/micode/notes/R$raw.class new file mode 100644 index 0000000..73a6a4d Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/R$raw.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/R$string.class b/app/build/intermediates/classes/release/net/micode/notes/R$string.class new file mode 100644 index 0000000..16f022b Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/R$string.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/R$style.class b/app/build/intermediates/classes/release/net/micode/notes/R$style.class new file mode 100644 index 0000000..6cf1b3d Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/R$style.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/R$xml.class b/app/build/intermediates/classes/release/net/micode/notes/R$xml.class new file mode 100644 index 0000000..544cbfb Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/R$xml.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/R.class b/app/build/intermediates/classes/release/net/micode/notes/R.class new file mode 100644 index 0000000..cdd1372 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/R.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/data/Contact.class b/app/build/intermediates/classes/release/net/micode/notes/data/Contact.class new file mode 100644 index 0000000..77f2300 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/data/Contact.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/data/Notes$CallNote.class b/app/build/intermediates/classes/release/net/micode/notes/data/Notes$CallNote.class new file mode 100644 index 0000000..37273aa Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/data/Notes$CallNote.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/data/Notes$DataColumns.class b/app/build/intermediates/classes/release/net/micode/notes/data/Notes$DataColumns.class new file mode 100644 index 0000000..2dca96a Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/data/Notes$DataColumns.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/data/Notes$DataConstants.class b/app/build/intermediates/classes/release/net/micode/notes/data/Notes$DataConstants.class new file mode 100644 index 0000000..1f14a2d Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/data/Notes$DataConstants.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/data/Notes$NoteColumns.class b/app/build/intermediates/classes/release/net/micode/notes/data/Notes$NoteColumns.class new file mode 100644 index 0000000..36315c7 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/data/Notes$NoteColumns.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/data/Notes$TextNote.class b/app/build/intermediates/classes/release/net/micode/notes/data/Notes$TextNote.class new file mode 100644 index 0000000..720d1ac Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/data/Notes$TextNote.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/data/Notes.class b/app/build/intermediates/classes/release/net/micode/notes/data/Notes.class new file mode 100644 index 0000000..3e2d98c Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/data/Notes.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/data/NotesDatabaseHelper$TABLE.class b/app/build/intermediates/classes/release/net/micode/notes/data/NotesDatabaseHelper$TABLE.class new file mode 100644 index 0000000..03731af Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/data/NotesDatabaseHelper$TABLE.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/data/NotesDatabaseHelper.class b/app/build/intermediates/classes/release/net/micode/notes/data/NotesDatabaseHelper.class new file mode 100644 index 0000000..d324f0e Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/data/NotesDatabaseHelper.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/data/NotesProvider.class b/app/build/intermediates/classes/release/net/micode/notes/data/NotesProvider.class new file mode 100644 index 0000000..cb3bdc2 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/data/NotesProvider.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/gtask/data/MetaData.class b/app/build/intermediates/classes/release/net/micode/notes/gtask/data/MetaData.class new file mode 100644 index 0000000..0a3a356 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/gtask/data/MetaData.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/gtask/data/Node.class b/app/build/intermediates/classes/release/net/micode/notes/gtask/data/Node.class new file mode 100644 index 0000000..2b5118e Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/gtask/data/Node.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/gtask/data/SqlData.class b/app/build/intermediates/classes/release/net/micode/notes/gtask/data/SqlData.class new file mode 100644 index 0000000..645f1f5 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/gtask/data/SqlData.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/gtask/data/SqlNote.class b/app/build/intermediates/classes/release/net/micode/notes/gtask/data/SqlNote.class new file mode 100644 index 0000000..8acd622 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/gtask/data/SqlNote.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/gtask/data/Task.class b/app/build/intermediates/classes/release/net/micode/notes/gtask/data/Task.class new file mode 100644 index 0000000..7a0c4ed Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/gtask/data/Task.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/gtask/data/TaskList.class b/app/build/intermediates/classes/release/net/micode/notes/gtask/data/TaskList.class new file mode 100644 index 0000000..8e8396b Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/gtask/data/TaskList.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/gtask/exception/ActionFailureException.class b/app/build/intermediates/classes/release/net/micode/notes/gtask/exception/ActionFailureException.class new file mode 100644 index 0000000..9ae78d8 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/gtask/exception/ActionFailureException.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/gtask/exception/NetworkFailureException.class b/app/build/intermediates/classes/release/net/micode/notes/gtask/exception/NetworkFailureException.class new file mode 100644 index 0000000..c29e580 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/gtask/exception/NetworkFailureException.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskASyncTask$1.class b/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskASyncTask$1.class new file mode 100644 index 0000000..02960fb Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskASyncTask$1.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.class b/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.class new file mode 100644 index 0000000..ebb2251 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskASyncTask.class b/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskASyncTask.class new file mode 100644 index 0000000..c39f210 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskASyncTask.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskClient.class b/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskClient.class new file mode 100644 index 0000000..323fe9e Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskClient.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskManager.class b/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskManager.class new file mode 100644 index 0000000..48df1a6 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskManager.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskSyncService$1.class b/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskSyncService$1.class new file mode 100644 index 0000000..b20d33f Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskSyncService$1.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskSyncService.class b/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskSyncService.class new file mode 100644 index 0000000..2df0dae Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/gtask/remote/GTaskSyncService.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/model/Note$NoteData.class b/app/build/intermediates/classes/release/net/micode/notes/model/Note$NoteData.class new file mode 100644 index 0000000..2777f1e Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/model/Note$NoteData.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/model/Note.class b/app/build/intermediates/classes/release/net/micode/notes/model/Note.class new file mode 100644 index 0000000..9368278 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/model/Note.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.class b/app/build/intermediates/classes/release/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.class new file mode 100644 index 0000000..6bbe48a Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/model/WorkingNote.class b/app/build/intermediates/classes/release/net/micode/notes/model/WorkingNote.class new file mode 100644 index 0000000..ca8b760 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/model/WorkingNote.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/tool/BackupUtils$TextExport.class b/app/build/intermediates/classes/release/net/micode/notes/tool/BackupUtils$TextExport.class new file mode 100644 index 0000000..093ef28 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/tool/BackupUtils$TextExport.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/tool/BackupUtils.class b/app/build/intermediates/classes/release/net/micode/notes/tool/BackupUtils.class new file mode 100644 index 0000000..65e50c8 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/tool/BackupUtils.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/tool/DataUtils.class b/app/build/intermediates/classes/release/net/micode/notes/tool/DataUtils.class new file mode 100644 index 0000000..ccaf3f6 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/tool/DataUtils.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/tool/GTaskStringUtils.class b/app/build/intermediates/classes/release/net/micode/notes/tool/GTaskStringUtils.class new file mode 100644 index 0000000..93c2bc9 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/tool/GTaskStringUtils.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/tool/ResourceParser$NoteBgResources.class b/app/build/intermediates/classes/release/net/micode/notes/tool/ResourceParser$NoteBgResources.class new file mode 100644 index 0000000..4fbc40c Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/tool/ResourceParser$NoteBgResources.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/tool/ResourceParser$NoteItemBgResources.class b/app/build/intermediates/classes/release/net/micode/notes/tool/ResourceParser$NoteItemBgResources.class new file mode 100644 index 0000000..e77df14 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/tool/ResourceParser$NoteItemBgResources.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/tool/ResourceParser$TextAppearanceResources.class b/app/build/intermediates/classes/release/net/micode/notes/tool/ResourceParser$TextAppearanceResources.class new file mode 100644 index 0000000..59b0099 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/tool/ResourceParser$TextAppearanceResources.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/tool/ResourceParser$WidgetBgResources.class b/app/build/intermediates/classes/release/net/micode/notes/tool/ResourceParser$WidgetBgResources.class new file mode 100644 index 0000000..30ee496 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/tool/ResourceParser$WidgetBgResources.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/tool/ResourceParser.class b/app/build/intermediates/classes/release/net/micode/notes/tool/ResourceParser.class new file mode 100644 index 0000000..d5f24f4 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/tool/ResourceParser.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/AlarmAlertActivity.class b/app/build/intermediates/classes/release/net/micode/notes/ui/AlarmAlertActivity.class new file mode 100644 index 0000000..e62463b Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/AlarmAlertActivity.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/AlarmInitReceiver.class b/app/build/intermediates/classes/release/net/micode/notes/ui/AlarmInitReceiver.class new file mode 100644 index 0000000..3483f88 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/AlarmInitReceiver.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/AlarmReceiver.class b/app/build/intermediates/classes/release/net/micode/notes/ui/AlarmReceiver.class new file mode 100644 index 0000000..68c5c88 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/AlarmReceiver.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePicker$1.class b/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePicker$1.class new file mode 100644 index 0000000..eff3719 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePicker$1.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePicker$2.class b/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePicker$2.class new file mode 100644 index 0000000..afe201e Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePicker$2.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePicker$3.class b/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePicker$3.class new file mode 100644 index 0000000..255d90a Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePicker$3.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePicker$4.class b/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePicker$4.class new file mode 100644 index 0000000..e44ae63 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePicker$4.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.class b/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.class new file mode 100644 index 0000000..86c542e Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePicker.class b/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePicker.class new file mode 100644 index 0000000..ad69268 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePicker.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePickerDialog$1.class b/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePickerDialog$1.class new file mode 100644 index 0000000..f44100a Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePickerDialog$1.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.class b/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.class new file mode 100644 index 0000000..5adfb41 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePickerDialog.class b/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePickerDialog.class new file mode 100644 index 0000000..325d898 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/DateTimePickerDialog.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/DropdownMenu$1.class b/app/build/intermediates/classes/release/net/micode/notes/ui/DropdownMenu$1.class new file mode 100644 index 0000000..a715afc Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/DropdownMenu$1.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/DropdownMenu.class b/app/build/intermediates/classes/release/net/micode/notes/ui/DropdownMenu.class new file mode 100644 index 0000000..f3790d6 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/DropdownMenu.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/FoldersListAdapter$FolderListItem.class b/app/build/intermediates/classes/release/net/micode/notes/ui/FoldersListAdapter$FolderListItem.class new file mode 100644 index 0000000..92c96f3 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/FoldersListAdapter$FolderListItem.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/FoldersListAdapter.class b/app/build/intermediates/classes/release/net/micode/notes/ui/FoldersListAdapter.class new file mode 100644 index 0000000..708089b Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/FoldersListAdapter.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditActivity$1.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditActivity$1.class new file mode 100644 index 0000000..b040523 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditActivity$1.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditActivity$2.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditActivity$2.class new file mode 100644 index 0000000..233d13d Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditActivity$2.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditActivity$3.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditActivity$3.class new file mode 100644 index 0000000..32a806a Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditActivity$3.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.class new file mode 100644 index 0000000..d748b65 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditActivity.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditActivity.class new file mode 100644 index 0000000..630e423 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditActivity.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditText$1.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditText$1.class new file mode 100644 index 0000000..e0ab5ed Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditText$1.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.class new file mode 100644 index 0000000..3b31419 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditText.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditText.class new file mode 100644 index 0000000..710a505 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NoteEditText.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NoteItemData.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NoteItemData.class new file mode 100644 index 0000000..1394920 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NoteItemData.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$1.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$1.class new file mode 100644 index 0000000..0413f42 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$1.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$2.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$2.class new file mode 100644 index 0000000..eb67507 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$2.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$3.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$3.class new file mode 100644 index 0000000..c7383d8 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$3.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$4.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$4.class new file mode 100644 index 0000000..410b249 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$4.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$5.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$5.class new file mode 100644 index 0000000..aadb9c7 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$5.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$6.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$6.class new file mode 100644 index 0000000..a585631 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$6.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$7.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$7.class new file mode 100644 index 0000000..75f325f Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$7.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$8.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$8.class new file mode 100644 index 0000000..37f5817 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$8.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$9.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$9.class new file mode 100644 index 0000000..6dbe68d Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$9.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.class new file mode 100644 index 0000000..dc224fc Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$ListEditState.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$ListEditState.class new file mode 100644 index 0000000..2e6cdfe Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$ListEditState.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$ModeCallback$1.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$ModeCallback$1.class new file mode 100644 index 0000000..a6f3ac4 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$ModeCallback$1.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$ModeCallback$2.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$ModeCallback$2.class new file mode 100644 index 0000000..ac66193 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$ModeCallback$2.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$ModeCallback.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$ModeCallback.class new file mode 100644 index 0000000..4d869f0 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$ModeCallback.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.class new file mode 100644 index 0000000..5e269c0 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.class new file mode 100644 index 0000000..18243a8 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity.class new file mode 100644 index 0000000..e60d704 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListActivity.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.class new file mode 100644 index 0000000..5914578 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListAdapter.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListAdapter.class new file mode 100644 index 0000000..4e1f881 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListAdapter.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListItem.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListItem.class new file mode 100644 index 0000000..d88881e Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesListItem.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$1.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$1.class new file mode 100644 index 0000000..a1adb13 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$1.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$2.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$2.class new file mode 100644 index 0000000..d2efa89 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$2.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$3.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$3.class new file mode 100644 index 0000000..499e024 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$3.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$4.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$4.class new file mode 100644 index 0000000..ee403d2 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$4.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$5.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$5.class new file mode 100644 index 0000000..811b0fc Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$5.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$6.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$6.class new file mode 100644 index 0000000..9b88bb9 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$6.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$7.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$7.class new file mode 100644 index 0000000..3bafdd6 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$7.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$8.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$8.class new file mode 100644 index 0000000..bd821d1 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$8.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.class new file mode 100644 index 0000000..123e6f0 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity.class b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity.class new file mode 100644 index 0000000..f871385 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/ui/NotesPreferenceActivity.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/widget/NoteWidgetProvider.class b/app/build/intermediates/classes/release/net/micode/notes/widget/NoteWidgetProvider.class new file mode 100644 index 0000000..3abf96e Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/widget/NoteWidgetProvider.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/widget/NoteWidgetProvider_2x.class b/app/build/intermediates/classes/release/net/micode/notes/widget/NoteWidgetProvider_2x.class new file mode 100644 index 0000000..ac50656 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/widget/NoteWidgetProvider_2x.class differ diff --git a/app/build/intermediates/classes/release/net/micode/notes/widget/NoteWidgetProvider_4x.class b/app/build/intermediates/classes/release/net/micode/notes/widget/NoteWidgetProvider_4x.class new file mode 100644 index 0000000..02050c4 Binary files /dev/null and b/app/build/intermediates/classes/release/net/micode/notes/widget/NoteWidgetProvider_4x.class differ diff --git a/app/build/intermediates/incremental/compileDebugAidl/dependency.store b/app/build/intermediates/incremental/compileDebugAidl/dependency.store new file mode 100644 index 0000000..8b8400d Binary files /dev/null and b/app/build/intermediates/incremental/compileDebugAidl/dependency.store differ diff --git a/app/build/intermediates/incremental/compileDebugAndroidTestAidl/dependency.store b/app/build/intermediates/incremental/compileDebugAndroidTestAidl/dependency.store new file mode 100644 index 0000000..8b8400d Binary files /dev/null and b/app/build/intermediates/incremental/compileDebugAndroidTestAidl/dependency.store differ diff --git a/app/build/intermediates/incremental/compileReleaseAidl/dependency.store b/app/build/intermediates/incremental/compileReleaseAidl/dependency.store new file mode 100644 index 0000000..8b8400d Binary files /dev/null and b/app/build/intermediates/incremental/compileReleaseAidl/dependency.store differ diff --git a/app/build/intermediates/incremental/debug-mergeJavaRes/merge-state b/app/build/intermediates/incremental/debug-mergeJavaRes/merge-state new file mode 100644 index 0000000..16cb59c Binary files /dev/null and b/app/build/intermediates/incremental/debug-mergeJavaRes/merge-state differ diff --git a/app/build/intermediates/incremental/debug-mergeJniLibs/merge-state b/app/build/intermediates/incremental/debug-mergeJniLibs/merge-state new file mode 100644 index 0000000..5b5314a Binary files /dev/null and b/app/build/intermediates/incremental/debug-mergeJniLibs/merge-state differ diff --git a/app/build/intermediates/incremental/mergeDebugAndroidTestResources/compile-file-map.properties b/app/build/intermediates/incremental/mergeDebugAndroidTestResources/compile-file-map.properties new file mode 100644 index 0000000..21e5d03 --- /dev/null +++ b/app/build/intermediates/incremental/mergeDebugAndroidTestResources/compile-file-map.properties @@ -0,0 +1 @@ +#Sat Dec 08 16:29:32 CST 2018 diff --git a/app/build/intermediates/incremental/mergeDebugAndroidTestResources/merger.xml b/app/build/intermediates/incremental/mergeDebugAndroidTestResources/merger.xml new file mode 100644 index 0000000..abbcc57 --- /dev/null +++ b/app/build/intermediates/incremental/mergeDebugAndroidTestResources/merger.xml @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/app/build/intermediates/incremental/mergeDebugAssets/merger.xml b/app/build/intermediates/incremental/mergeDebugAssets/merger.xml new file mode 100644 index 0000000..6af1505 --- /dev/null +++ b/app/build/intermediates/incremental/mergeDebugAssets/merger.xml @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/app/build/intermediates/incremental/mergeDebugJniLibFolders/merger.xml b/app/build/intermediates/incremental/mergeDebugJniLibFolders/merger.xml new file mode 100644 index 0000000..2a65790 --- /dev/null +++ b/app/build/intermediates/incremental/mergeDebugJniLibFolders/merger.xml @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/app/build/intermediates/incremental/mergeDebugResources/compile-file-map.properties b/app/build/intermediates/incremental/mergeDebugResources/compile-file-map.properties new file mode 100644 index 0000000..c340173 --- /dev/null +++ b/app/build/intermediates/incremental/mergeDebugResources/compile-file-map.properties @@ -0,0 +1,235 @@ +#Tue Jan 29 17:20:29 CST 2019 +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\call_record.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_call_record.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_green.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_green.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\xml\\searchable.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\xml_searchable.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\color\\secondary_text_dark.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\color_secondary_text_dark.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\layout.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_layout.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_white_up.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_up.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\menu_delete.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_menu_delete.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_blue.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_blue.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_list_footer.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list_footer.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_small.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_small.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable\\selector_grid.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable_selector_grid.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\raw-zh-rCN\\introduction=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\raw-zh-rCN_introduction.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\selected.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_selected.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\widget_4x.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_widget_4x.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable\\new_note.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable_new_note.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_red_down.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_down.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\attention1.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_attention1.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_blue_down.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_down.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\repeat_password_head.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_repeat_password_head.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_red_single.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_single.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_single.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_single.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\title_bar_bg.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_title_bar_bg.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_yellow.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_yellow.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_yellow.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_yellow.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_yellow.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_yellow.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\layout2.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_layout2.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_up.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_up.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\note_edit_color_selector_panel.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_note_edit_color_selector_panel.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_small.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_small.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_green_middle.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_middle.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\title_alert.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_title_alert.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\menu\\sub_folder.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_sub_folder.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\attention1.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_attention1.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_white.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_white.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_item.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_item.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\menu_move.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_menu_move.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_edit_list_item.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_edit_list_item.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_red.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_red.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\settings_header.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_settings_header.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\new_note_normal.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_new_note_normal.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_white_middle.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_middle.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_decryption.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_decryption.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_green.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_green.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\repeat_password_head.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_repeat_password_head.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_white.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_white.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_white_down.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_down.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_blue.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_blue.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_blue_middle.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_middle.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\item_grid.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_item_grid.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_yellow.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_yellow.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_folder.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_folder.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_blue_up.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_up.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\xml\\preferences.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\xml_preferences.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_green.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_green.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\attention4.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_attention4.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_background.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_background.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\icon_app.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_icon_app.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\lock.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_lock.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\datetime_picker.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_datetime_picker.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_green_down.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_down.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\call_note_edit.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_call_note_edit.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_blue.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_blue.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_edit.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_edit.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_folder.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_folder.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_encryption.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_encryption.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\attention4.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_attention4.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_down.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_down.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\homepage.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_homepage.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_yellow.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_yellow.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_footer_bg.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_footer_bg.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\password_item.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_password_item.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\title_alert.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_title_alert.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_green_up.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_up.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_list_dropdown_menu.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list_dropdown_menu.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\bg_btn_set_color.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_bg_btn_set_color.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\attention0.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_attention0.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\delete.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_delete.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_white.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_white.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\add_account_text.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_add_account_text.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_encryption_repeat.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_encryption_repeat.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\notification.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_notification.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\xml\\widget_2x_info.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\xml_widget_2x_info.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_large.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_large.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_white.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_white.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\widget_4x.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_widget_4x.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_red_single.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_single.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\folder_list_item.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_folder_list_item.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\attention0.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_attention0.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_white_down.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_down.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_normal.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_normal.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_green.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_green.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\selected.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_selected.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\xml\\searchable.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\xml_searchable.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_green.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_green.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_green_middle.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_middle.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\note_edit.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_edit.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_green_single.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_single.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_blue.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_blue.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\lock.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_lock.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\menu\\note_list_dropdown.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list_dropdown.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_white_middle.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_middle.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\new_note_pressed.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_new_note_pressed.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\clock.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_clock.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_white_single.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_single.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\color\\primary_text_dark.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\color_primary_text_dark.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_list.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_red.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_red.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_blue.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_blue.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_importance.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_importance.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\menu\\note_list.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\attention3.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_attention3.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\password_item.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_password_item.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\add_account_text.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_add_account_text.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\layout2.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_layout2.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\new_note_normal.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_new_note_normal.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_blue_up.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_up.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_blue_single.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_single.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_blue_middle.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_middle.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_large.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_large.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\bg_color_btn_mask.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_bg_color_btn_mask.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\folder_list_item.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_folder_list_item.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\delete.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_delete.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\widget_2x.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_widget_2x.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_white.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_white.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\attention3.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_attention3.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\xml\\widget_4x_info.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\xml_widget_4x_info.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\search_result.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_search_result.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_red.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_red.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\menu\\call_record_folder.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_call_record_folder.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\account_dialog_title.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_account_dialog_title.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\dialog_edit_text.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_dialog_edit_text.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_edit_list_item.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_edit_list_item.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_super.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_super.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\note_edit_color_selector_panel.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_note_edit_color_selector_panel.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\note_list_options.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list_options.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\dropdown_icon.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_dropdown_icon.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_background.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_background.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\note_list_dropdown.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list_dropdown.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\raw\\introduction=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\raw_introduction.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\color\\primary_text_dark.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\color_primary_text_dark.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_normal.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_normal.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_red_up.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_up.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable\\selector_key_del.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable_selector_key_del.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_green.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_green.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_blue.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_blue.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_middle.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_middle.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_super.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_super.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\current_password_head.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_current_password_head.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\raw-zh-rCN\\introduction=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\raw-zh-rCN_introduction.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\raw\\introduction=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\raw_introduction.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_white_up.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_up.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\search_result.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_search_result.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_red.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_red.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\account_dialog_title.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_account_dialog_title.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_white.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_white.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\xml\\widget_2x_info.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\xml_widget_2x_info.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable\\selector_grid.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable_selector_grid.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\sub_folder.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_sub_folder.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_yellow.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_yellow.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_decryption.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_decryption.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_item.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_item.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_blue_down.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_down.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\bg_btn_set_color.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_bg_btn_set_color.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\call_record_folder.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_call_record_folder.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_red_up.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_up.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\dialog_edit_text.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_dialog_edit_text.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_red_middle.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_middle.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_white.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_white.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_yellow.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_yellow.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_up.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_up.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_middle.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_middle.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_white.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_white.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_red.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_red.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_yellow.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_yellow.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\settings_header.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_settings_header.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\new_password_head.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_new_password_head.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\menu\\call_note_edit.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_call_note_edit.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_red_down.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_down.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\title_bar_bg.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_title_bar_bg.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\icon_app.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_icon_app.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\xml\\preferences.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\xml_preferences.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_blue.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_blue.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\xml\\widget_4x_info.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\xml_widget_4x_info.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\cancel.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_cancel.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_green_single.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_single.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\attention2.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_attention2.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\call_record.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_call_record.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\color\\secondary_text_dark.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\color_secondary_text_dark.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\new_password_head.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_new_password_head.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_white_single.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_single.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_list.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\menu_delete.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_menu_delete.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_green.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_green.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_red.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_red.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\attention2.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_attention2.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\item_grid.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_item_grid.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_red.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_red.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\new_note_pressed.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_new_note_pressed.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable\\selector_key_del.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable_selector_key_del.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\bg_color_btn_mask.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_bg_color_btn_mask.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_blue_single.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_single.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\datetime_picker.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_datetime_picker.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_importance.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_importance.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\homepage.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_homepage.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\widget_2x.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_widget_2x.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_green.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_green.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_encryption.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_encryption.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_list_footer.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list_footer.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\notification.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_notification.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_green_down.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_down.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable\\new_note.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable_new_note.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_edit.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_edit.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\attention5.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_attention5.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\menu\\note_edit.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_edit.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_green_up.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_up.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_blue.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_blue.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_footer_bg.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_footer_bg.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\cancel.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_cancel.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_down.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_down.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_red_middle.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_middle.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\clock.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_clock.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\current_password_head.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_current_password_head.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_list_dropdown_menu.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list_dropdown_menu.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\menu\\note_list_options.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list_options.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_encryption_repeat.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_encryption_repeat.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\menu_move.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_menu_move.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\layout\\layout.xml=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\layout_layout.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_single.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_single.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_red.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_red.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\dropdown_icon.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_dropdown_icon.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_size_selector_bg.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_size_selector_bg.9.png.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\attention5.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_attention5.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\note_list.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list.xml.flat +C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_size_selector_bg.9.png=C\:\\Users\\12231\\Desktop\\software\\reading\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_size_selector_bg.9.png.flat diff --git a/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-zh-rCN/values-zh-rCN.xml b/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-zh-rCN/values-zh-rCN.xml new file mode 100644 index 0000000..62b59b7 --- /dev/null +++ b/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-zh-rCN/values-zh-rCN.xml @@ -0,0 +1,118 @@ + + + + 短信 + 邮件 + + + %1$s 条符合“%2$s”的搜索结果 + + 密码输入正确,即将进入便签 + 密码输入错误,请重新输入 + 确认删除文件夹及所包含的便签吗? + 确认要删除该条便签吗? + 确认要删除所选的 %d 条便签吗? + 便签访问密码设置成功, 密码是 %s + 便签访问密码设置成功,两次密码输入不一致 + 解除便签访问密码成功 + 删除 + 密码提示 + 设置重要性 + 便签 + 便签2x2 + 便签4x4 + 删除 + 通话便签 + 取消 + 设置 + 成功删除提醒 + 不能为空便签设置闹钟提醒 + 不能将空便签发送到桌面 + 要查看的便签不存在 + 导出文本时发生错误,请检查SD卡 + SD卡被占用,不能操作 + 同步已取消 + 同步失败,发生内部错误 + 同步失败,请检查网络和帐号设置 + 导出失败 + 文件夹 %1$s 已存在,请重新命名 + yyyyMMdd + MM月dd日 kk:mm + 已将文本文件(%1$s)输出至SD卡(%2$s)目录 + 已将所选 %1$d 条便签移到 %2$s 文件夹 + 请输入名称 + 已添加到桌面 + 提醒我 + 新建文件夹 + 删除 + 取消全选 + 设置密码 + 导出文本 + 修改文件夹名称 + 刪除文件夹 + 查看文件夹 + + 正常 + 文字大小 + + 超大 + 进入清单模式 + 移动到文件夹 + 上一级文件夹 + 退出清单模式 + 解除密码 + 删除提醒 + 搜索 + 全选 + 没有选中项,操作无效 + 选中了 %d 项 + 发送到桌面 + 设置便签重要性 + 设置 + 分享 + 同步 + 取消同步 + 选择文件夹 + 已过期 + 发送邮件 + 打开地图 + 呼叫电话 + 浏览网页 + 查看 + 知道了 + 新建便签 + ... + 与google task同步便签记录 + 同步账号 + 添加账号 + 新建便签背景颜色随机 + 取消同步 + 立即同步 + 当前帐号 %1$s + 如更换同步帐号,过去的帐号同步信息将被清空,再次切换的同时可能会造成数据重复 + 请选择google帐号,便签将与该帐号的google task内容同步。 + 同步便签 + 上次同步于 %1$s + 取消 + 更换账号 + 删除账号 + 设置 + 正在同步中,不能修改同步帐号 + 同步帐号已设置为%1$s + 便签 + 搜索便签 + 正在搜索便签 + 便签中的文字 + 创建提醒 + 导出成功 + 与%1$s同步成功 + 正在获取服务器便签列表... + 登录%1$s... + 正在同步本地便签... + 同步已取消 + 同步失败 + 同步成功 + 同步便签... + 没有关联内容,点击新建便签。 + 访客模式下,便签内容不可见 + \ No newline at end of file diff --git a/app/build/intermediates/incremental/mergeDebugResources/merger.xml b/app/build/intermediates/incremental/mergeDebugResources/merger.xml new file mode 100644 index 0000000..f80158e --- /dev/null +++ b/app/build/intermediates/incremental/mergeDebugResources/merger.xml @@ -0,0 +1,56 @@ + + + -%s + --%s + --%s + --%s + + Messaging + Email + #335b5b5b33sp26sp20sp17sp14spNotesNotes 2x2Notes 4x4No associated note found, click to create associated note.Privacy mode,can not see note content...Add noteDelete reminder successfullySet reminderExpiredyyyyMMddMMMd kk:mmGot itTake a lookCallSend emailBrowse webOpen map/MIUI/notes/notes_%s.txt(%d)New FolderExport textSyncCancel syncingSettingsSearchDeleteMove to folder%d selectedNothing selected, the operation is invalidSelect allDeselect allFont sizeSmallMediumLargeSuperEnter check listLeave check listView folderDelete folderChange folder nameThe folder %1$s exist, please renameShareSend to homeRemind meDelete reminderEncrypt noteDelete encryptionSet importanceSelect folderParent folderNote added to homeConfirm to delete folder and its notes?Delete selected notesConfirm to delete the selected %d notes?Confirm to delete this note?EncryptionEncrypt note successfully, password is %sEncrypt note unsuccessfully, password input is not sameDecrypt note successfullyDecrypt note unsuccessfully, password is wrongRemove encryption successfullySet ImportanceHave moved selected %1$d notes to %2$s folderSD card busy, not available nowExport failed, please check SD cardThe note is not existSorry, can not set clock on empty noteSorry, can not send and empty note to homeExport successfulExport failExport text file (%1$s) to SD (%2$s) directorySyncing notes...Sync is successfulSync is failedSync is canceledSync is successful with account %1$sSync failed, please check network and account settingsSync failed, internal error occursSync is canceledLogging into %1$s...Getting remote note list...Synchronize local notes with Google Task...SettingsSync accountSync notes with google taskLast sync time %1$syyyy-MM-dd hh:mm:ssAdd accountChange sync accountRemove sync accountCancelSync immediatelyCancel syncingCurrent account %1$sAll sync related information will be deleted, which may result in duplicated items sometimeSync notesPlease select a google account. Local notes will be synced with google task.Cannot change the account because sync is in progress%1$s has been set as the sync accountNew note background color randomDeleteCall notesInput nameSearching NotesSearch notesText in your notesNotessetcancel + %1$s result for \"%2$s\" + + %1$s results for \"%2$s\" + + 短信 + 邮件 + 便签便签2x2便签4x4没有关联内容,点击新建便签。访客模式下,便签内容不可见...新建便签成功删除提醒创建提醒已过期yyyyMMddMM月dd日 kk:mm知道了查看呼叫电话发送邮件浏览网页打开地图新建文件夹导出文本同步取消同步设置搜索删除移动到文件夹选中了 %d 项没有选中项,操作无效全选取消全选文字大小正常超大进入清单模式退出清单模式查看文件夹刪除文件夹修改文件夹名称文件夹 %1$s 已存在,请重新命名分享发送到桌面提醒我删除提醒设置密码解除密码设置便签重要性选择文件夹上一级文件夹已添加到桌面删除确认要删除所选的 %d 条便签吗?确认要删除该条便签吗?确认删除文件夹及所包含的便签吗?密码提示便签访问密码设置成功, 密码是 %s便签访问密码设置成功,两次密码输入不一致密码输入正确,即将进入便签密码输入错误,请重新输入解除便签访问密码成功设置重要性已将所选 %1$d 条便签移到 %2$s 文件夹SD卡被占用,不能操作导出文本时发生错误,请检查SD卡要查看的便签不存在不能为空便签设置闹钟提醒不能将空便签发送到桌面导出成功导出失败已将文本文件(%1$s)输出至SD卡(%2$s)目录同步便签...同步成功同步失败同步已取消与%1$s同步成功同步失败,请检查网络和帐号设置同步失败,发生内部错误同步已取消登录%1$s...正在获取服务器便签列表...正在同步本地便签...设置同步账号与google task同步便签记录上次同步于 %1$s添加账号更换账号删除账号取消立即同步取消同步当前帐号 %1$s如更换同步帐号,过去的帐号同步信息将被清空,再次切换的同时可能会造成数据重复同步便签请选择google帐号,便签将与该帐号的google task内容同步。正在同步中,不能修改同步帐号同步帐号已设置为%1$s新建便签背景颜色随机删除通话便签请输入名称正在搜索便签搜索便签便签中的文字便签设置取消 + %1$s 条符合“%2$s”的搜索结果 + + 短信 + 郵件 + 便簽便簽2x2便簽4x4沒有關聯內容,點擊新建便簽。訪客模式下,便籤內容不可見...新建便簽成功刪除提醒創建提醒已過期yyyyMMddMM月dd日 kk:mm知道了查看呼叫電話發送郵件浏覽網頁打開地圖已將所選 %1$d 便籤移到 %2$s 文件夾新建文件夾導出文本同步取消同步設置搜尋刪除移動到文件夾選中了 %d 項沒有選中項,操作無效全選取消全選文字大小正常超大進入清單模式退出清單模式查看文件夾刪除文件夾修改文件夾名稱文件夾 %1$s 已存在,請重新命名分享發送到桌面提醒我刪除提醒選擇文件夾上一級文件夾已添加到桌面刪除确认要刪除所選的 %d 條便籤嗎?确认要删除該條便籤嗎?確認刪除檔夾及所包含的便簽嗎?SD卡被佔用,不能操作導出TXT時發生錯誤,請檢查SD卡要查看的便籤不存在不能爲空便籤設置鬧鐘提醒不能將空便籤發送到桌面導出成功導出失敗已將文本文件(%1$s)導出至SD(%2$s)目錄同步便簽...同步成功同步失敗同步已取消與%1$s同步成功同步失敗,請檢查網絡和帳號設置同步失敗,發生內部錯誤同步已取消登陸%1$s...正在獲取服務器便籤列表...正在同步本地便籤...設置同步賬號与google task同步便簽記錄上次同步于 %1$s添加賬號更換賬號刪除賬號取消立即同步取消同步當前帳號 %1$s如更換同步帳號,過去的帳號同步信息將被清空,再次切換的同時可能會造成數據重復同步便簽請選擇google帳號,便簽將與該帳號的google task內容同步。正在同步中,不能修改同步帳號同步帳號已設置為%1$s新建便籤背景顏色隨機刪除通話便籤請輸入名稱正在搜索便籤搜索便籤便籤中的文字便籤設置取消 + %1$s 條符合”%2$s“的搜尋結果 + \ No newline at end of file diff --git a/app/build/intermediates/incremental/mergeDebugShaders/merger.xml b/app/build/intermediates/incremental/mergeDebugShaders/merger.xml new file mode 100644 index 0000000..fd4407c --- /dev/null +++ b/app/build/intermediates/incremental/mergeDebugShaders/merger.xml @@ -0,0 +1,2 @@ + + \ No newline at end of file diff --git a/app/build/intermediates/incremental/mergeReleaseResources/compile-file-map.properties b/app/build/intermediates/incremental/mergeReleaseResources/compile-file-map.properties new file mode 100644 index 0000000..8fc9292 --- /dev/null +++ b/app/build/intermediates/incremental/mergeReleaseResources/compile-file-map.properties @@ -0,0 +1,96 @@ +#Sat Dec 01 16:03:25 CST 2018 +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_blue_middle.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_blue_middle.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\menu_move.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_menu_move.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_green_middle.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_green_middle.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\xml\\widget_2x_info.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\xml_widget_2x_info.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_folder.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_folder.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\sub_folder.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\menu_sub_folder.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\selected.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_selected.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_list_footer.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_note_list_footer.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\raw-zh-rCN\\introduction=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\raw-zh-rCN_introduction.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_super.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_font_super.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_background.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_background.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\call_note_edit.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\menu_call_note_edit.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\call_record_folder.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\menu_call_record_folder.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\dialog_edit_text.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_dialog_edit_text.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_blue_single.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_blue_single.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_white_up.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_white_up.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_green_single.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_green_single.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\widget_2x.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_widget_2x.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\call_record.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_call_record.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_red.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_edit_title_red.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_green_down.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_green_down.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\title_alert.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_title_alert.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_footer_bg.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_footer_bg.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable\\new_note.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable_new_note.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_yellow.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_edit_title_yellow.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_white.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_edit_title_white.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_red_up.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_red_up.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_green.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_widget_4x_green.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\menu_delete.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_menu_delete.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\raw\\introduction=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\raw_introduction.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\bg_color_btn_mask.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_bg_color_btn_mask.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_small.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_font_small.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_green.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_edit_green.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\new_note_normal.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_new_note_normal.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\bg_btn_set_color.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_bg_btn_set_color.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\delete.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_delete.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_up.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_yellow_up.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_size_selector_bg.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_font_size_selector_bg.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\color\\secondary_text_dark.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\color_secondary_text_dark.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\folder_list_item.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_folder_list_item.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_white.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_widget_4x_white.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_item.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_note_item.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_blue.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_edit_title_blue.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\widget_4x.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_widget_4x.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\settings_header.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_settings_header.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\xml\\searchable.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\xml_searchable.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\note_list.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\menu_note_list.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_red_middle.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_red_middle.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_blue.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_widget_4x_blue.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\dropdown_icon.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_dropdown_icon.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_down.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_yellow_down.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_middle.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_yellow_middle.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\xml\\preferences.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\xml_preferences.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\new_note_pressed.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_new_note_pressed.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\icon_app.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_icon_app.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\note_edit.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\menu_note_edit.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\notification.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_notification.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_red_down.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_red_down.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_list_dropdown_menu.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_note_list_dropdown_menu.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_red_single.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_red_single.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_white_middle.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_white_middle.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_list.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_note_list.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_yellow.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_widget_4x_yellow.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\datetime_picker.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_datetime_picker.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_single.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_yellow_single.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_blue.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_widget_2x_blue.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_blue_up.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_blue_up.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\add_account_text.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_add_account_text.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\title_bar_bg.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_title_bar_bg.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\note_list_dropdown.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\menu_note_list_dropdown.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_edit.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_note_edit.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_green.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_widget_2x_green.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_white_single.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_white_single.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_title_green.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_edit_title_green.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\menu\\note_list_options.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\menu_note_list_options.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\search_result.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_search_result.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_normal.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_font_normal.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_white.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_edit_white.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\color\\primary_text_dark.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\color_primary_text_dark.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\font_large.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_font_large.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_red.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_widget_2x_red.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_white_down.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_white_down.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_blue_down.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_blue_down.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\note_edit_list_item.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_note_edit_list_item.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\xml\\widget_4x_info.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\xml_widget_4x_info.xml.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_yellow.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_widget_2x_yellow.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_red.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_edit_red.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_red.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_widget_4x_red.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\note_edit_color_selector_panel.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_note_edit_color_selector_panel.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_white.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_widget_2x_white.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_yellow.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_edit_yellow.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\clock.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_clock.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\edit_blue.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_edit_blue.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\drawable-hdpi\\list_green_up.9.png=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\drawable-hdpi_list_green_up.9.png.flat +E\:\\NOTE\\src\\Notes-master\\app\\src\\main\\res\\layout\\account_dialog_title.xml=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\res\\merged\\release\\layout_account_dialog_title.xml.flat diff --git a/app/build/intermediates/incremental/mergeReleaseResources/merged.dir/values-zh-rCN/values-zh-rCN.xml b/app/build/intermediates/incremental/mergeReleaseResources/merged.dir/values-zh-rCN/values-zh-rCN.xml new file mode 100644 index 0000000..d65e0cc --- /dev/null +++ b/app/build/intermediates/incremental/mergeReleaseResources/merged.dir/values-zh-rCN/values-zh-rCN.xml @@ -0,0 +1,108 @@ + + + + 短信 + 邮件 + + + %1$s 条符合“%2$s”的搜索结果 + + 确认删除文件夹及所包含的便签吗? + 确认要删除该条便签吗? + 确认要删除所选的 %d 条便签吗? + 删除 + 便签 + 便签2x2 + 便签4x4 + 删除 + 通话便签 + 取消 + 设置 + 成功删除提醒 + 不能为空便签设置闹钟提醒 + 不能将空便签发送到桌面 + 要查看的便签不存在 + 导出文本时发生错误,请检查SD卡 + SD卡被占用,不能操作 + 同步已取消 + 同步失败,发生内部错误 + 同步失败,请检查网络和帐号设置 + 导出失败 + 文件夹 %1$s 已存在,请重新命名 + yyyyMMdd + MM月dd日 kk:mm + 已将文本文件(%1$s)输出至SD卡(%2$s)目录 + 已将所选 %1$d 条便签移到 %2$s 文件夹 + 请输入名称 + 已添加到桌面 + 提醒我 + 新建文件夹 + 删除 + 取消全选 + 导出文本 + 修改文件夹名称 + 刪除文件夹 + 查看文件夹 + + 正常 + 文字大小 + + 超大 + 进入清单模式 + 移动到文件夹 + 上一级文件夹 + 退出清单模式 + 删除提醒 + 搜索 + 全选 + 没有选中项,操作无效 + 选中了 %d 项 + 发送到桌面 + 设置 + 分享 + 同步 + 取消同步 + 选择文件夹 + 已过期 + 发送邮件 + 打开地图 + 呼叫电话 + 浏览网页 + 查看 + 知道了 + 新建便签 + ... + 与google task同步便签记录 + 同步账号 + 添加账号 + 新建便签背景颜色随机 + 取消同步 + 立即同步 + 当前帐号 %1$s + 如更换同步帐号,过去的帐号同步信息将被清空,再次切换的同时可能会造成数据重复 + 请选择google帐号,便签将与该帐号的google task内容同步。 + 同步便签 + 上次同步于 %1$s + 取消 + 更换账号 + 删除账号 + 设置 + 正在同步中,不能修改同步帐号 + 同步帐号已设置为%1$s + 便签 + 搜索便签 + 正在搜索便签 + 便签中的文字 + 创建提醒 + 导出成功 + 与%1$s同步成功 + 正在获取服务器便签列表... + 登录%1$s... + 正在同步本地便签... + 同步已取消 + 同步失败 + 同步成功 + 同步便签... + 没有关联内容,点击新建便签。 + 访客模式下,便签内容不可见 + \ No newline at end of file diff --git a/app/build/intermediates/incremental/mergeReleaseResources/merged.dir/values-zh-rTW/values-zh-rTW.xml b/app/build/intermediates/incremental/mergeReleaseResources/merged.dir/values-zh-rTW/values-zh-rTW.xml new file mode 100644 index 0000000..226b5bc --- /dev/null +++ b/app/build/intermediates/incremental/mergeReleaseResources/merged.dir/values-zh-rTW/values-zh-rTW.xml @@ -0,0 +1,108 @@ + + + + 短信 + 郵件 + + + %1$s 條符合”%2$s“的搜尋結果 + + 確認刪除檔夾及所包含的便簽嗎? + 确认要删除該條便籤嗎? + 确认要刪除所選的 %d 條便籤嗎? + 刪除 + 便簽 + 便簽2x2 + 便簽4x4 + 刪除 + 通話便籤 + 取消 + 設置 + 成功刪除提醒 + 不能爲空便籤設置鬧鐘提醒 + 不能將空便籤發送到桌面 + 要查看的便籤不存在 + 導出TXT時發生錯誤,請檢查SD卡 + SD卡被佔用,不能操作 + 同步已取消 + 同步失敗,發生內部錯誤 + 同步失敗,請檢查網絡和帳號設置 + 導出失敗 + 文件夾 %1$s 已存在,請重新命名 + yyyyMMdd + MM月dd日 kk:mm + 已將文本文件(%1$s)導出至SD(%2$s)目錄 + 已將所選 %1$d 便籤移到 %2$s 文件夾 + 請輸入名稱 + 已添加到桌面 + 提醒我 + 新建文件夾 + 刪除 + 取消全選 + 導出文本 + 修改文件夾名稱 + 刪除文件夾 + 查看文件夾 + + 正常 + 文字大小 + + 超大 + 進入清單模式 + 移動到文件夾 + 上一級文件夾 + 退出清單模式 + 刪除提醒 + 搜尋 + 全選 + 沒有選中項,操作無效 + 選中了 %d 項 + 發送到桌面 + 設置 + 分享 + 同步 + 取消同步 + 選擇文件夾 + 已過期 + 發送郵件 + 打開地圖 + 呼叫電話 + 浏覽網頁 + 查看 + 知道了 + 新建便簽 + ... + 与google task同步便簽記錄 + 同步賬號 + 添加賬號 + 新建便籤背景顏色隨機 + 取消同步 + 立即同步 + 當前帳號 %1$s + 如更換同步帳號,過去的帳號同步信息將被清空,再次切換的同時可能會造成數據重復 + 請選擇google帳號,便簽將與該帳號的google task內容同步。 + 同步便簽 + 上次同步于 %1$s + 取消 + 更換賬號 + 刪除賬號 + 設置 + 正在同步中,不能修改同步帳號 + 同步帳號已設置為%1$s + 便籤 + 搜索便籤 + 正在搜索便籤 + 便籤中的文字 + 創建提醒 + 導出成功 + 與%1$s同步成功 + 正在獲取服務器便籤列表... + 登陸%1$s... + 正在同步本地便籤... + 同步已取消 + 同步失敗 + 同步成功 + 同步便簽... + 沒有關聯內容,點擊新建便簽。 + 訪客模式下,便籤內容不可見 + \ No newline at end of file diff --git a/app/build/intermediates/incremental/mergeReleaseResources/merged.dir/values/values.xml b/app/build/intermediates/incremental/mergeReleaseResources/merged.dir/values/values.xml new file mode 100644 index 0000000..dfa7135 --- /dev/null +++ b/app/build/intermediates/incremental/mergeReleaseResources/merged.dir/values/values.xml @@ -0,0 +1,169 @@ + + + + -%s + --%s + --%s + --%s + + + Messaging + Email + + #335b5b5b + 26sp + 20sp + 17sp + 14sp + 33sp + + %1$s result for \"%2$s\" + + %1$s results for \"%2$s\" + + Confirm to delete folder and its notes? + Confirm to delete this note? + Confirm to delete the selected %d notes? + Delete selected notes + Notes + Notes 2x2 + Notes 4x4 + Delete + Call notes + cancel + set + Delete reminder successfully + Sorry, can not set clock on empty note + Sorry, can not send and empty note to home + The note is not exist + Export failed, please check SD card + SD card busy, not available now + Sync is canceled + Sync failed, internal error occurs + Sync failed, please check network and account settings + Export fail + notes_%s.txt + /MIUI/notes/ + The folder %1$s exist, please rename + yyyyMMdd + MMMd kk:mm + Export text file (%1$s) to SD (%2$s) directory + (%d) + Have moved selected %1$d notes to %2$s folder + Input name + Note added to home + Remind me + New Folder + Delete + Deselect all + Export text + Change folder name + Delete folder + View folder + Large + Medium + Font size + Small + Super + Enter check list + Move to folder + Parent folder + Leave check list + Delete reminder + Search + Select all + Nothing selected, the operation is invalid + %d selected + Send to home + Settings + Share + Sync + Cancel syncing + Select folder + Expired + Send email + Open map + Call + Browse web + Take a look + Got it + Add note + ... + Sync notes with google task + Sync account + Add account + New note background color random + Cancel syncing + Sync immediately + Current account %1$s + All sync related information will be deleted, which may result in duplicated items sometime + Please select a google account. Local notes will be synced with google task. + Sync notes + Last sync time %1$s + yyyy-MM-dd hh:mm:ss + Cancel + Change sync account + Remove sync account + Settings + Cannot change the account because sync is in progress + %1$s has been set as the sync account + Notes + Search notes + Searching Notes + Text in your notes + Set reminder + Export successful + Sync is successful with account %1$s + Getting remote note list... + Logging into %1$s... + Synchronize local notes with Google Task... + Sync is canceled + Sync is failed + Sync is successful + Syncing notes... + No associated note found, click to create associated note. + Privacy mode,can not see note content + + + + + + + + + + + + \ No newline at end of file diff --git a/app/build/intermediates/incremental/mergeReleaseResources/merger.xml b/app/build/intermediates/incremental/mergeReleaseResources/merger.xml new file mode 100644 index 0000000..9982dc2 --- /dev/null +++ b/app/build/intermediates/incremental/mergeReleaseResources/merger.xml @@ -0,0 +1,56 @@ + + + -%s + --%s + --%s + --%s + + Messaging + Email + #335b5b5b33sp26sp20sp17sp14spNotesNotes 2x2Notes 4x4No associated note found, click to create associated note.Privacy mode,can not see note content...Add noteDelete reminder successfullySet reminderExpiredyyyyMMddMMMd kk:mmGot itTake a lookCallSend emailBrowse webOpen map/MIUI/notes/notes_%s.txt(%d)New FolderExport textSyncCancel syncingSettingsSearchDeleteMove to folder%d selectedNothing selected, the operation is invalidSelect allDeselect allFont sizeSmallMediumLargeSuperEnter check listLeave check listView folderDelete folderChange folder nameThe folder %1$s exist, please renameShareSend to homeRemind meDelete reminderSelect folderParent folderNote added to homeConfirm to delete folder and its notes?Delete selected notesConfirm to delete the selected %d notes?Confirm to delete this note?Have moved selected %1$d notes to %2$s folderSD card busy, not available nowExport failed, please check SD cardThe note is not existSorry, can not set clock on empty noteSorry, can not send and empty note to homeExport successfulExport failExport text file (%1$s) to SD (%2$s) directorySyncing notes...Sync is successfulSync is failedSync is canceledSync is successful with account %1$sSync failed, please check network and account settingsSync failed, internal error occursSync is canceledLogging into %1$s...Getting remote note list...Synchronize local notes with Google Task...SettingsSync accountSync notes with google taskLast sync time %1$syyyy-MM-dd hh:mm:ssAdd accountChange sync accountRemove sync accountCancelSync immediatelyCancel syncingCurrent account %1$sAll sync related information will be deleted, which may result in duplicated items sometimeSync notesPlease select a google account. Local notes will be synced with google task.Cannot change the account because sync is in progress%1$s has been set as the sync accountNew note background color randomDeleteCall notesInput nameSearching NotesSearch notesText in your notesNotessetcancel + %1$s result for \"%2$s\" + + %1$s results for \"%2$s\" + + 短信 + 邮件 + 便签便签2x2便签4x4没有关联内容,点击新建便签。访客模式下,便签内容不可见...新建便签成功删除提醒创建提醒已过期yyyyMMddMM月dd日 kk:mm知道了查看呼叫电话发送邮件浏览网页打开地图新建文件夹导出文本同步取消同步设置搜索删除移动到文件夹选中了 %d 项没有选中项,操作无效全选取消全选文字大小正常超大进入清单模式退出清单模式查看文件夹刪除文件夹修改文件夹名称文件夹 %1$s 已存在,请重新命名分享发送到桌面提醒我删除提醒选择文件夹上一级文件夹已添加到桌面删除确认要删除所选的 %d 条便签吗?确认要删除该条便签吗?确认删除文件夹及所包含的便签吗?已将所选 %1$d 条便签移到 %2$s 文件夹SD卡被占用,不能操作导出文本时发生错误,请检查SD卡要查看的便签不存在不能为空便签设置闹钟提醒不能将空便签发送到桌面导出成功导出失败已将文本文件(%1$s)输出至SD卡(%2$s)目录同步便签...同步成功同步失败同步已取消与%1$s同步成功同步失败,请检查网络和帐号设置同步失败,发生内部错误同步已取消登录%1$s...正在获取服务器便签列表...正在同步本地便签...设置同步账号与google task同步便签记录上次同步于 %1$s添加账号更换账号删除账号取消立即同步取消同步当前帐号 %1$s如更换同步帐号,过去的帐号同步信息将被清空,再次切换的同时可能会造成数据重复同步便签请选择google帐号,便签将与该帐号的google task内容同步。正在同步中,不能修改同步帐号同步帐号已设置为%1$s新建便签背景颜色随机删除通话便签请输入名称正在搜索便签搜索便签便签中的文字便签设置取消 + %1$s 条符合“%2$s”的搜索结果 + + 短信 + 郵件 + 便簽便簽2x2便簽4x4沒有關聯內容,點擊新建便簽。訪客模式下,便籤內容不可見...新建便簽成功刪除提醒創建提醒已過期yyyyMMddMM月dd日 kk:mm知道了查看呼叫電話發送郵件浏覽網頁打開地圖已將所選 %1$d 便籤移到 %2$s 文件夾新建文件夾導出文本同步取消同步設置搜尋刪除移動到文件夾選中了 %d 項沒有選中項,操作無效全選取消全選文字大小正常超大進入清單模式退出清單模式查看文件夾刪除文件夾修改文件夾名稱文件夾 %1$s 已存在,請重新命名分享發送到桌面提醒我刪除提醒選擇文件夾上一級文件夾已添加到桌面刪除确认要刪除所選的 %d 條便籤嗎?确认要删除該條便籤嗎?確認刪除檔夾及所包含的便簽嗎?SD卡被佔用,不能操作導出TXT時發生錯誤,請檢查SD卡要查看的便籤不存在不能爲空便籤設置鬧鐘提醒不能將空便籤發送到桌面導出成功導出失敗已將文本文件(%1$s)導出至SD(%2$s)目錄同步便簽...同步成功同步失敗同步已取消與%1$s同步成功同步失敗,請檢查網絡和帳號設置同步失敗,發生內部錯誤同步已取消登陸%1$s...正在獲取服務器便籤列表...正在同步本地便籤...設置同步賬號与google task同步便簽記錄上次同步于 %1$s添加賬號更換賬號刪除賬號取消立即同步取消同步當前帳號 %1$s如更換同步帳號,過去的帳號同步信息將被清空,再次切換的同時可能會造成數據重復同步便簽請選擇google帳號,便簽將與該帳號的google task內容同步。正在同步中,不能修改同步帳號同步帳號已設置為%1$s新建便籤背景顏色隨機刪除通話便籤請輸入名稱正在搜索便籤搜索便籤便籤中的文字便籤設置取消 + %1$s 條符合”%2$s“的搜尋結果 + \ No newline at end of file diff --git a/app/build/intermediates/incremental/packageDebug/tmp/debug/dex-renamer-state.txt b/app/build/intermediates/incremental/packageDebug/tmp/debug/dex-renamer-state.txt new file mode 100644 index 0000000..89a337c --- /dev/null +++ b/app/build/intermediates/incremental/packageDebug/tmp/debug/dex-renamer-state.txt @@ -0,0 +1,4 @@ +#Tue Jan 29 17:40:42 CST 2019 +base.0=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\transforms\\dexMerger\\debug\\37 +path.0=classes.dex +renamed.0=classes.dex diff --git a/app/build/intermediates/incremental/packageDebug/tmp/debug/file-input-save-data.txt b/app/build/intermediates/incremental/packageDebug/tmp/debug/file-input-save-data.txt new file mode 100644 index 0000000..2e7115c --- /dev/null +++ b/app/build/intermediates/incremental/packageDebug/tmp/debug/file-input-save-data.txt @@ -0,0 +1,7 @@ +#Internal package file, do not edit. +#Wed Jan 23 11:14:09 CST 2019 +0.baseType=DIRECTORY +0.base=E\:\\NOTE\\src\\Notes-master\\app\\build\\intermediates\\transforms\\dexMerger\\debug\\37 +0.path=classes.dex +0.set=DEX +count=1 diff --git a/app/build/intermediates/incremental/packageDebug/tmp/debug/zip-cache/INz_b2RvA4Yav7s4ErEtviIPKXM= b/app/build/intermediates/incremental/packageDebug/tmp/debug/zip-cache/INz_b2RvA4Yav7s4ErEtviIPKXM= new file mode 100644 index 0000000..ce50462 Binary files /dev/null and b/app/build/intermediates/incremental/packageDebug/tmp/debug/zip-cache/INz_b2RvA4Yav7s4ErEtviIPKXM= differ diff --git a/app/build/intermediates/javaPrecompile/androidTest/debug/annotationProcessors.json b/app/build/intermediates/javaPrecompile/androidTest/debug/annotationProcessors.json new file mode 100644 index 0000000..0637a08 --- /dev/null +++ b/app/build/intermediates/javaPrecompile/androidTest/debug/annotationProcessors.json @@ -0,0 +1 @@ +[] \ No newline at end of file diff --git a/app/build/intermediates/javaPrecompile/debug/annotationProcessors.json b/app/build/intermediates/javaPrecompile/debug/annotationProcessors.json new file mode 100644 index 0000000..0637a08 --- /dev/null +++ b/app/build/intermediates/javaPrecompile/debug/annotationProcessors.json @@ -0,0 +1 @@ +[] \ No newline at end of file diff --git a/app/build/intermediates/javaPrecompile/release/annotationProcessors.json b/app/build/intermediates/javaPrecompile/release/annotationProcessors.json new file mode 100644 index 0000000..0637a08 --- /dev/null +++ b/app/build/intermediates/javaPrecompile/release/annotationProcessors.json @@ -0,0 +1 @@ +[] \ No newline at end of file diff --git a/app/build/intermediates/javaPrecompile/test/debug/annotationProcessors.json b/app/build/intermediates/javaPrecompile/test/debug/annotationProcessors.json new file mode 100644 index 0000000..0637a08 --- /dev/null +++ b/app/build/intermediates/javaPrecompile/test/debug/annotationProcessors.json @@ -0,0 +1 @@ +[] \ No newline at end of file diff --git a/app/build/intermediates/manifest/androidTest/debug/AndroidManifest.xml b/app/build/intermediates/manifest/androidTest/debug/AndroidManifest.xml new file mode 100644 index 0000000..485ad0f --- /dev/null +++ b/app/build/intermediates/manifest/androidTest/debug/AndroidManifest.xml @@ -0,0 +1,16 @@ + + + + + + + + + + + diff --git a/app/build/intermediates/manifest/androidTest/debug/output.json b/app/build/intermediates/manifest/androidTest/debug/output.json new file mode 100644 index 0000000..1aafc2c --- /dev/null +++ b/app/build/intermediates/manifest/androidTest/debug/output.json @@ -0,0 +1 @@ +[{"outputType":{"type":"MERGED_MANIFESTS"},"apkInfo":{"type":"MAIN","splits":[],"versionCode":-1,"enabled":true,"outputFile":"app-debug-androidTest.apk","fullName":"debugAndroidTest","baseName":"debug-androidTest"},"path":"AndroidManifest.xml","properties":{}}] \ No newline at end of file diff --git a/app/build/intermediates/manifests/density/debug/output.json b/app/build/intermediates/manifests/density/debug/output.json new file mode 100644 index 0000000..0637a08 --- /dev/null +++ b/app/build/intermediates/manifests/density/debug/output.json @@ -0,0 +1 @@ +[] \ No newline at end of file diff --git a/app/build/intermediates/manifests/density/release/output.json b/app/build/intermediates/manifests/density/release/output.json new file mode 100644 index 0000000..0637a08 --- /dev/null +++ b/app/build/intermediates/manifests/density/release/output.json @@ -0,0 +1 @@ +[] \ No newline at end of file diff --git a/app/build/intermediates/manifests/full/debug/AndroidManifest.xml b/app/build/intermediates/manifests/full/debug/AndroidManifest.xml new file mode 100644 index 0000000..f237bf5 --- /dev/null +++ b/app/build/intermediates/manifests/full/debug/AndroidManifest.xml @@ -0,0 +1,151 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/build/intermediates/manifests/full/debug/output.json b/app/build/intermediates/manifests/full/debug/output.json new file mode 100644 index 0000000..a18098f --- /dev/null +++ b/app/build/intermediates/manifests/full/debug/output.json @@ -0,0 +1 @@ +[{"outputType":{"type":"MERGED_MANIFESTS"},"apkInfo":{"type":"MAIN","splits":[],"versionCode":1,"versionName":"0.1","enabled":true,"outputFile":"app-debug.apk","fullName":"debug","baseName":"debug"},"path":"AndroidManifest.xml","properties":{"packageId":"net.micode.notes","split":"","minSdkVersion":"14"}}] \ No newline at end of file diff --git a/app/build/intermediates/manifests/full/release/AndroidManifest.xml b/app/build/intermediates/manifests/full/release/AndroidManifest.xml new file mode 100644 index 0000000..b3424d2 --- /dev/null +++ b/app/build/intermediates/manifests/full/release/AndroidManifest.xml @@ -0,0 +1,149 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/build/intermediates/manifests/full/release/output.json b/app/build/intermediates/manifests/full/release/output.json new file mode 100644 index 0000000..cfee2f1 --- /dev/null +++ b/app/build/intermediates/manifests/full/release/output.json @@ -0,0 +1 @@ +[{"outputType":{"type":"MERGED_MANIFESTS"},"apkInfo":{"type":"MAIN","splits":[],"versionCode":1,"versionName":"0.1","enabled":true,"outputFile":"app-release-unsigned.apk","fullName":"release","baseName":"release"},"path":"AndroidManifest.xml","properties":{"packageId":"net.micode.notes","split":"","minSdkVersion":"14"}}] \ No newline at end of file diff --git a/app/build/intermediates/manifests/instant-run/debug/output.json b/app/build/intermediates/manifests/instant-run/debug/output.json new file mode 100644 index 0000000..a9c4512 --- /dev/null +++ b/app/build/intermediates/manifests/instant-run/debug/output.json @@ -0,0 +1 @@ +[{"outputType":{"type":"INSTANT_RUN_MERGED_MANIFESTS"},"apkInfo":{"type":"MAIN","splits":[],"versionCode":1,"versionName":"0.1","enabled":true,"outputFile":"app-debug.apk","fullName":"debug","baseName":"debug"},"path":"AndroidManifest.xml","properties":{"packageId":"net.micode.notes","split":"","minSdkVersion":"14"}}] \ No newline at end of file diff --git a/app/build/intermediates/manifests/instant-run/release/output.json b/app/build/intermediates/manifests/instant-run/release/output.json new file mode 100644 index 0000000..38e1a28 --- /dev/null +++ b/app/build/intermediates/manifests/instant-run/release/output.json @@ -0,0 +1 @@ +[{"outputType":{"type":"INSTANT_RUN_MERGED_MANIFESTS"},"apkInfo":{"type":"MAIN","splits":[],"versionCode":1,"versionName":"0.1","enabled":true,"outputFile":"app-release-unsigned.apk","fullName":"release","baseName":"release"},"path":"AndroidManifest.xml","properties":{"packageId":"net.micode.notes","split":"","minSdkVersion":"14"}}] \ No newline at end of file diff --git a/app/build/intermediates/res/androidTest/debug/output.json b/app/build/intermediates/res/androidTest/debug/output.json new file mode 100644 index 0000000..dcfa9d3 --- /dev/null +++ b/app/build/intermediates/res/androidTest/debug/output.json @@ -0,0 +1 @@ +[{"outputType":{"type":"PROCESSED_RES"},"apkInfo":{"type":"MAIN","splits":[],"versionCode":-1,"enabled":true,"outputFile":"app-debug-androidTest.apk","fullName":"debugAndroidTest","baseName":"debug-androidTest"},"path":"resources-debugAndroidTest.ap_","properties":{}}] \ No newline at end of file diff --git a/app/build/intermediates/res/androidTest/debug/resources-debugAndroidTest.ap_ b/app/build/intermediates/res/androidTest/debug/resources-debugAndroidTest.ap_ new file mode 100644 index 0000000..84d56d5 Binary files /dev/null and b/app/build/intermediates/res/androidTest/debug/resources-debugAndroidTest.ap_ differ diff --git a/app/build/intermediates/res/debug/output.json b/app/build/intermediates/res/debug/output.json new file mode 100644 index 0000000..a8453be --- /dev/null +++ b/app/build/intermediates/res/debug/output.json @@ -0,0 +1 @@ +[{"outputType":{"type":"PROCESSED_RES"},"apkInfo":{"type":"MAIN","splits":[],"versionCode":1,"versionName":"0.1","enabled":true,"outputFile":"app-debug.apk","fullName":"debug","baseName":"debug"},"path":"resources-debug.ap_","properties":{"packageId":"net.micode.notes","split":"","minSdkVersion":"14"}}] \ No newline at end of file diff --git a/app/build/intermediates/res/debug/resources-debug.ap_ b/app/build/intermediates/res/debug/resources-debug.ap_ new file mode 100644 index 0000000..ce50462 Binary files /dev/null and b/app/build/intermediates/res/debug/resources-debug.ap_ differ diff --git a/app/build/intermediates/res/merged/debug/color_primary_text_dark.xml.flat b/app/build/intermediates/res/merged/debug/color_primary_text_dark.xml.flat new file mode 100644 index 0000000..d1ac26f Binary files /dev/null and b/app/build/intermediates/res/merged/debug/color_primary_text_dark.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/color_secondary_text_dark.xml.flat b/app/build/intermediates/res/merged/debug/color_secondary_text_dark.xml.flat new file mode 100644 index 0000000..a946f1f Binary files /dev/null and b/app/build/intermediates/res/merged/debug/color_secondary_text_dark.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_attention0.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_attention0.png.flat new file mode 100644 index 0000000..87215d0 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_attention0.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_attention1.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_attention1.png.flat new file mode 100644 index 0000000..56cb9ee Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_attention1.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_attention2.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_attention2.png.flat new file mode 100644 index 0000000..1033f51 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_attention2.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_attention3.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_attention3.png.flat new file mode 100644 index 0000000..0cdda13 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_attention3.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_attention4.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_attention4.png.flat new file mode 100644 index 0000000..1e17c85 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_attention4.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_attention5.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_attention5.png.flat new file mode 100644 index 0000000..ac51f66 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_attention5.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_bg_btn_set_color.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_bg_btn_set_color.png.flat new file mode 100644 index 0000000..861641e Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_bg_btn_set_color.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_bg_color_btn_mask.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_bg_color_btn_mask.png.flat new file mode 100644 index 0000000..496b8e5 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_bg_color_btn_mask.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_call_record.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_call_record.png.flat new file mode 100644 index 0000000..7d22d76 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_call_record.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_cancel.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_cancel.png.flat new file mode 100644 index 0000000..f3d8eb5 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_cancel.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_clock.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_clock.png.flat new file mode 100644 index 0000000..91728d6 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_clock.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_delete.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_delete.png.flat new file mode 100644 index 0000000..a6c7606 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_delete.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_dropdown_icon.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_dropdown_icon.9.png.flat new file mode 100644 index 0000000..3334b82 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_dropdown_icon.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_blue.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_blue.9.png.flat new file mode 100644 index 0000000..b5b939f Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_blue.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_green.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_green.9.png.flat new file mode 100644 index 0000000..cd6ee5c Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_green.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_red.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_red.9.png.flat new file mode 100644 index 0000000..2504eac Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_red.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_blue.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_blue.9.png.flat new file mode 100644 index 0000000..bd8f30b Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_blue.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_green.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_green.9.png.flat new file mode 100644 index 0000000..9e0bb88 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_green.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_red.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_red.9.png.flat new file mode 100644 index 0000000..e92ec71 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_red.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_white.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_white.9.png.flat new file mode 100644 index 0000000..4590fb6 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_white.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_yellow.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_yellow.9.png.flat new file mode 100644 index 0000000..23ef29a Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_yellow.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_white.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_white.9.png.flat new file mode 100644 index 0000000..0b05ef0 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_white.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_yellow.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_yellow.9.png.flat new file mode 100644 index 0000000..1f0ded2 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_yellow.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_font_large.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_font_large.png.flat new file mode 100644 index 0000000..43232e7 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_font_large.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_font_normal.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_font_normal.png.flat new file mode 100644 index 0000000..574d5d7 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_font_normal.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_font_size_selector_bg.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_font_size_selector_bg.9.png.flat new file mode 100644 index 0000000..7863b08 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_font_size_selector_bg.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_font_small.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_font_small.png.flat new file mode 100644 index 0000000..bc40445 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_font_small.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_font_super.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_font_super.png.flat new file mode 100644 index 0000000..ac02357 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_font_super.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_icon_app.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_icon_app.png.flat new file mode 100644 index 0000000..f09fb31 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_icon_app.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_background.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_background.png.flat new file mode 100644 index 0000000..1aa961d Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_background.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_down.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_down.9.png.flat new file mode 100644 index 0000000..3b0d8e2 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_down.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_middle.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_middle.9.png.flat new file mode 100644 index 0000000..f5a9ae1 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_middle.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_single.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_single.9.png.flat new file mode 100644 index 0000000..7807b24 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_single.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_up.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_up.9.png.flat new file mode 100644 index 0000000..3759535 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_up.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_folder.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_folder.9.png.flat new file mode 100644 index 0000000..ffae26d Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_folder.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_footer_bg.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_footer_bg.9.png.flat new file mode 100644 index 0000000..d37bf53 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_footer_bg.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_down.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_down.9.png.flat new file mode 100644 index 0000000..2b7feed Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_down.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_middle.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_middle.9.png.flat new file mode 100644 index 0000000..7e20263 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_middle.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_single.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_single.9.png.flat new file mode 100644 index 0000000..c77674c Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_single.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_up.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_up.9.png.flat new file mode 100644 index 0000000..7048ce9 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_up.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_down.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_down.9.png.flat new file mode 100644 index 0000000..31d87d6 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_down.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_middle.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_middle.9.png.flat new file mode 100644 index 0000000..3a02ea2 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_middle.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_single.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_single.9.png.flat new file mode 100644 index 0000000..2aea873 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_single.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_up.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_up.9.png.flat new file mode 100644 index 0000000..863bc1e Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_up.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_down.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_down.9.png.flat new file mode 100644 index 0000000..00de928 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_down.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_middle.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_middle.9.png.flat new file mode 100644 index 0000000..0d88326 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_middle.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_single.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_single.9.png.flat new file mode 100644 index 0000000..727e79b Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_single.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_up.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_up.9.png.flat new file mode 100644 index 0000000..a19933f Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_up.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_down.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_down.9.png.flat new file mode 100644 index 0000000..50dd3e8 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_down.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_middle.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_middle.9.png.flat new file mode 100644 index 0000000..44afae8 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_middle.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_single.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_single.9.png.flat new file mode 100644 index 0000000..6e5f5b8 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_single.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_up.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_up.9.png.flat new file mode 100644 index 0000000..d088c77 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_up.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_lock.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_lock.png.flat new file mode 100644 index 0000000..1392276 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_lock.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_menu_delete.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_menu_delete.png.flat new file mode 100644 index 0000000..cb4d43c Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_menu_delete.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_menu_move.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_menu_move.png.flat new file mode 100644 index 0000000..343053a Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_menu_move.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_new_note_normal.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_new_note_normal.png.flat new file mode 100644 index 0000000..fd356ad Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_new_note_normal.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_new_note_pressed.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_new_note_pressed.png.flat new file mode 100644 index 0000000..afbce89 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_new_note_pressed.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_note_edit_color_selector_panel.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_note_edit_color_selector_panel.png.flat new file mode 100644 index 0000000..f17c487 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_note_edit_color_selector_panel.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_notification.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_notification.png.flat new file mode 100644 index 0000000..fb36db9 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_notification.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_search_result.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_search_result.png.flat new file mode 100644 index 0000000..51fecd9 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_search_result.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_selected.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_selected.png.flat new file mode 100644 index 0000000..489e120 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_selected.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_title_alert.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_title_alert.png.flat new file mode 100644 index 0000000..fc68d75 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_title_alert.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_title_bar_bg.9.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_title_bar_bg.9.png.flat new file mode 100644 index 0000000..48b764c Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_title_bar_bg.9.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_blue.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_blue.png.flat new file mode 100644 index 0000000..e08a054 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_blue.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_green.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_green.png.flat new file mode 100644 index 0000000..f4890ab Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_green.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_red.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_red.png.flat new file mode 100644 index 0000000..8d7301b Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_red.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_white.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_white.png.flat new file mode 100644 index 0000000..7c7863e Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_white.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_yellow.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_yellow.png.flat new file mode 100644 index 0000000..4fee3f8 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_yellow.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_blue.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_blue.png.flat new file mode 100644 index 0000000..1a7f716 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_blue.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_green.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_green.png.flat new file mode 100644 index 0000000..168f906 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_green.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_red.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_red.png.flat new file mode 100644 index 0000000..33980c5 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_red.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_white.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_white.png.flat new file mode 100644 index 0000000..41d925d Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_white.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_yellow.png.flat b/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_yellow.png.flat new file mode 100644 index 0000000..7934290 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_yellow.png.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable_new_note.xml.flat b/app/build/intermediates/res/merged/debug/drawable_new_note.xml.flat new file mode 100644 index 0000000..51144b6 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable_new_note.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable_selector_grid.xml.flat b/app/build/intermediates/res/merged/debug/drawable_selector_grid.xml.flat new file mode 100644 index 0000000..2eb6f52 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable_selector_grid.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/drawable_selector_key_del.xml.flat b/app/build/intermediates/res/merged/debug/drawable_selector_key_del.xml.flat new file mode 100644 index 0000000..cb48b97 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/drawable_selector_key_del.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_account_dialog_title.xml.flat b/app/build/intermediates/res/merged/debug/layout_account_dialog_title.xml.flat new file mode 100644 index 0000000..1590dad Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_account_dialog_title.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_add_account_text.xml.flat b/app/build/intermediates/res/merged/debug/layout_add_account_text.xml.flat new file mode 100644 index 0000000..a77df14 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_add_account_text.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_current_password_head.xml.flat b/app/build/intermediates/res/merged/debug/layout_current_password_head.xml.flat new file mode 100644 index 0000000..fc27f9a Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_current_password_head.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_datetime_picker.xml.flat b/app/build/intermediates/res/merged/debug/layout_datetime_picker.xml.flat new file mode 100644 index 0000000..10ba5a0 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_datetime_picker.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_dialog_edit_text.xml.flat b/app/build/intermediates/res/merged/debug/layout_dialog_edit_text.xml.flat new file mode 100644 index 0000000..74f8b88 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_dialog_edit_text.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_folder_list_item.xml.flat b/app/build/intermediates/res/merged/debug/layout_folder_list_item.xml.flat new file mode 100644 index 0000000..a869b26 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_folder_list_item.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_homepage.xml.flat b/app/build/intermediates/res/merged/debug/layout_homepage.xml.flat new file mode 100644 index 0000000..006fae5 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_homepage.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_item_grid.xml.flat b/app/build/intermediates/res/merged/debug/layout_item_grid.xml.flat new file mode 100644 index 0000000..af66bde Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_item_grid.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_layout.xml.flat b/app/build/intermediates/res/merged/debug/layout_layout.xml.flat new file mode 100644 index 0000000..aaaf319 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_layout.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_layout2.xml.flat b/app/build/intermediates/res/merged/debug/layout_layout2.xml.flat new file mode 100644 index 0000000..e34916c Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_layout2.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_new_password_head.xml.flat b/app/build/intermediates/res/merged/debug/layout_new_password_head.xml.flat new file mode 100644 index 0000000..e966c3c Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_new_password_head.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_note_decryption.xml.flat b/app/build/intermediates/res/merged/debug/layout_note_decryption.xml.flat new file mode 100644 index 0000000..f44dc65 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_note_decryption.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_note_edit.xml.flat b/app/build/intermediates/res/merged/debug/layout_note_edit.xml.flat new file mode 100644 index 0000000..c62ae04 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_note_edit.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_note_edit_list_item.xml.flat b/app/build/intermediates/res/merged/debug/layout_note_edit_list_item.xml.flat new file mode 100644 index 0000000..61ca687 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_note_edit_list_item.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_note_encryption.xml.flat b/app/build/intermediates/res/merged/debug/layout_note_encryption.xml.flat new file mode 100644 index 0000000..0a74219 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_note_encryption.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_note_encryption_repeat.xml.flat b/app/build/intermediates/res/merged/debug/layout_note_encryption_repeat.xml.flat new file mode 100644 index 0000000..78e3c16 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_note_encryption_repeat.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_note_importance.xml.flat b/app/build/intermediates/res/merged/debug/layout_note_importance.xml.flat new file mode 100644 index 0000000..c97e9ef Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_note_importance.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_note_item.xml.flat b/app/build/intermediates/res/merged/debug/layout_note_item.xml.flat new file mode 100644 index 0000000..20649ec Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_note_item.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_note_list.xml.flat b/app/build/intermediates/res/merged/debug/layout_note_list.xml.flat new file mode 100644 index 0000000..0aaf261 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_note_list.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_note_list_dropdown_menu.xml.flat b/app/build/intermediates/res/merged/debug/layout_note_list_dropdown_menu.xml.flat new file mode 100644 index 0000000..e99cd69 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_note_list_dropdown_menu.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_note_list_footer.xml.flat b/app/build/intermediates/res/merged/debug/layout_note_list_footer.xml.flat new file mode 100644 index 0000000..23a2199 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_note_list_footer.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_password_item.xml.flat b/app/build/intermediates/res/merged/debug/layout_password_item.xml.flat new file mode 100644 index 0000000..3859bb4 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_password_item.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_repeat_password_head.xml.flat b/app/build/intermediates/res/merged/debug/layout_repeat_password_head.xml.flat new file mode 100644 index 0000000..d4e13ce Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_repeat_password_head.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_settings_header.xml.flat b/app/build/intermediates/res/merged/debug/layout_settings_header.xml.flat new file mode 100644 index 0000000..f979f6c Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_settings_header.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_widget_2x.xml.flat b/app/build/intermediates/res/merged/debug/layout_widget_2x.xml.flat new file mode 100644 index 0000000..2be3f67 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_widget_2x.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/layout_widget_4x.xml.flat b/app/build/intermediates/res/merged/debug/layout_widget_4x.xml.flat new file mode 100644 index 0000000..82ddbd4 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/layout_widget_4x.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/menu_call_note_edit.xml.flat b/app/build/intermediates/res/merged/debug/menu_call_note_edit.xml.flat new file mode 100644 index 0000000..4337509 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/menu_call_note_edit.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/menu_call_record_folder.xml.flat b/app/build/intermediates/res/merged/debug/menu_call_record_folder.xml.flat new file mode 100644 index 0000000..a141a20 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/menu_call_record_folder.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/menu_note_edit.xml.flat b/app/build/intermediates/res/merged/debug/menu_note_edit.xml.flat new file mode 100644 index 0000000..ecdcfbb Binary files /dev/null and b/app/build/intermediates/res/merged/debug/menu_note_edit.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/menu_note_list.xml.flat b/app/build/intermediates/res/merged/debug/menu_note_list.xml.flat new file mode 100644 index 0000000..9edbee0 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/menu_note_list.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/menu_note_list_dropdown.xml.flat b/app/build/intermediates/res/merged/debug/menu_note_list_dropdown.xml.flat new file mode 100644 index 0000000..c4129e6 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/menu_note_list_dropdown.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/menu_note_list_options.xml.flat b/app/build/intermediates/res/merged/debug/menu_note_list_options.xml.flat new file mode 100644 index 0000000..3f65fb7 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/menu_note_list_options.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/menu_sub_folder.xml.flat b/app/build/intermediates/res/merged/debug/menu_sub_folder.xml.flat new file mode 100644 index 0000000..37f498b Binary files /dev/null and b/app/build/intermediates/res/merged/debug/menu_sub_folder.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/raw-zh-rCN_introduction.flat b/app/build/intermediates/res/merged/debug/raw-zh-rCN_introduction.flat new file mode 100644 index 0000000..d511d1b Binary files /dev/null and b/app/build/intermediates/res/merged/debug/raw-zh-rCN_introduction.flat differ diff --git a/app/build/intermediates/res/merged/debug/raw_introduction.flat b/app/build/intermediates/res/merged/debug/raw_introduction.flat new file mode 100644 index 0000000..690c18c Binary files /dev/null and b/app/build/intermediates/res/merged/debug/raw_introduction.flat differ diff --git a/app/build/intermediates/res/merged/debug/values-zh-rCN_values-zh-rCN.arsc.flat b/app/build/intermediates/res/merged/debug/values-zh-rCN_values-zh-rCN.arsc.flat new file mode 100644 index 0000000..a2c36e1 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/values-zh-rCN_values-zh-rCN.arsc.flat differ diff --git a/app/build/intermediates/res/merged/debug/values-zh-rTW_values-zh-rTW.arsc.flat b/app/build/intermediates/res/merged/debug/values-zh-rTW_values-zh-rTW.arsc.flat new file mode 100644 index 0000000..b0fea13 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/values-zh-rTW_values-zh-rTW.arsc.flat differ diff --git a/app/build/intermediates/res/merged/debug/values_values.arsc.flat b/app/build/intermediates/res/merged/debug/values_values.arsc.flat new file mode 100644 index 0000000..cc938d3 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/values_values.arsc.flat differ diff --git a/app/build/intermediates/res/merged/debug/xml_preferences.xml.flat b/app/build/intermediates/res/merged/debug/xml_preferences.xml.flat new file mode 100644 index 0000000..b7d0922 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/xml_preferences.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/xml_searchable.xml.flat b/app/build/intermediates/res/merged/debug/xml_searchable.xml.flat new file mode 100644 index 0000000..4c49aa3 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/xml_searchable.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/xml_widget_2x_info.xml.flat b/app/build/intermediates/res/merged/debug/xml_widget_2x_info.xml.flat new file mode 100644 index 0000000..392bd99 Binary files /dev/null and b/app/build/intermediates/res/merged/debug/xml_widget_2x_info.xml.flat differ diff --git a/app/build/intermediates/res/merged/debug/xml_widget_4x_info.xml.flat b/app/build/intermediates/res/merged/debug/xml_widget_4x_info.xml.flat new file mode 100644 index 0000000..70b86ca Binary files /dev/null and b/app/build/intermediates/res/merged/debug/xml_widget_4x_info.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/color_primary_text_dark.xml.flat b/app/build/intermediates/res/merged/release/color_primary_text_dark.xml.flat new file mode 100644 index 0000000..d1ac26f Binary files /dev/null and b/app/build/intermediates/res/merged/release/color_primary_text_dark.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/color_secondary_text_dark.xml.flat b/app/build/intermediates/res/merged/release/color_secondary_text_dark.xml.flat new file mode 100644 index 0000000..a946f1f Binary files /dev/null and b/app/build/intermediates/res/merged/release/color_secondary_text_dark.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_bg_btn_set_color.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_bg_btn_set_color.png.flat new file mode 100644 index 0000000..a746d4f Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_bg_btn_set_color.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_bg_color_btn_mask.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_bg_color_btn_mask.png.flat new file mode 100644 index 0000000..8d4d98b Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_bg_color_btn_mask.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_call_record.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_call_record.png.flat new file mode 100644 index 0000000..305e3e7 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_call_record.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_clock.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_clock.png.flat new file mode 100644 index 0000000..a8b4aee Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_clock.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_delete.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_delete.png.flat new file mode 100644 index 0000000..54f6c6c Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_delete.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_dropdown_icon.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_dropdown_icon.9.png.flat new file mode 100644 index 0000000..3334b82 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_dropdown_icon.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_edit_blue.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_edit_blue.9.png.flat new file mode 100644 index 0000000..b5b939f Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_edit_blue.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_edit_green.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_edit_green.9.png.flat new file mode 100644 index 0000000..cd6ee5c Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_edit_green.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_edit_red.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_edit_red.9.png.flat new file mode 100644 index 0000000..2504eac Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_edit_red.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_edit_title_blue.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_edit_title_blue.9.png.flat new file mode 100644 index 0000000..bd8f30b Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_edit_title_blue.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_edit_title_green.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_edit_title_green.9.png.flat new file mode 100644 index 0000000..9e0bb88 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_edit_title_green.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_edit_title_red.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_edit_title_red.9.png.flat new file mode 100644 index 0000000..e92ec71 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_edit_title_red.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_edit_title_white.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_edit_title_white.9.png.flat new file mode 100644 index 0000000..4590fb6 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_edit_title_white.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_edit_title_yellow.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_edit_title_yellow.9.png.flat new file mode 100644 index 0000000..23ef29a Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_edit_title_yellow.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_edit_white.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_edit_white.9.png.flat new file mode 100644 index 0000000..0b05ef0 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_edit_white.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_edit_yellow.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_edit_yellow.9.png.flat new file mode 100644 index 0000000..1f0ded2 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_edit_yellow.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_font_large.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_font_large.png.flat new file mode 100644 index 0000000..3d71cfb Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_font_large.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_font_normal.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_font_normal.png.flat new file mode 100644 index 0000000..4e27cbc Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_font_normal.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_font_size_selector_bg.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_font_size_selector_bg.9.png.flat new file mode 100644 index 0000000..7863b08 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_font_size_selector_bg.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_font_small.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_font_small.png.flat new file mode 100644 index 0000000..ba0e1fd Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_font_small.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_font_super.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_font_super.png.flat new file mode 100644 index 0000000..1413269 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_font_super.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_icon_app.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_icon_app.png.flat new file mode 100644 index 0000000..971d5f4 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_icon_app.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_background.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_background.png.flat new file mode 100644 index 0000000..01da3fc Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_background.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_blue_down.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_blue_down.9.png.flat new file mode 100644 index 0000000..3b0d8e2 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_blue_down.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_blue_middle.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_blue_middle.9.png.flat new file mode 100644 index 0000000..f5a9ae1 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_blue_middle.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_blue_single.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_blue_single.9.png.flat new file mode 100644 index 0000000..7807b24 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_blue_single.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_blue_up.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_blue_up.9.png.flat new file mode 100644 index 0000000..3759535 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_blue_up.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_folder.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_folder.9.png.flat new file mode 100644 index 0000000..ffae26d Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_folder.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_footer_bg.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_footer_bg.9.png.flat new file mode 100644 index 0000000..d37bf53 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_footer_bg.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_green_down.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_green_down.9.png.flat new file mode 100644 index 0000000..2b7feed Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_green_down.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_green_middle.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_green_middle.9.png.flat new file mode 100644 index 0000000..7e20263 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_green_middle.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_green_single.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_green_single.9.png.flat new file mode 100644 index 0000000..c77674c Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_green_single.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_green_up.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_green_up.9.png.flat new file mode 100644 index 0000000..7048ce9 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_green_up.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_red_down.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_red_down.9.png.flat new file mode 100644 index 0000000..31d87d6 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_red_down.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_red_middle.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_red_middle.9.png.flat new file mode 100644 index 0000000..3a02ea2 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_red_middle.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_red_single.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_red_single.9.png.flat new file mode 100644 index 0000000..2aea873 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_red_single.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_red_up.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_red_up.9.png.flat new file mode 100644 index 0000000..863bc1e Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_red_up.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_white_down.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_white_down.9.png.flat new file mode 100644 index 0000000..00de928 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_white_down.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_white_middle.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_white_middle.9.png.flat new file mode 100644 index 0000000..0d88326 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_white_middle.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_white_single.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_white_single.9.png.flat new file mode 100644 index 0000000..727e79b Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_white_single.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_white_up.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_white_up.9.png.flat new file mode 100644 index 0000000..a19933f Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_white_up.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_yellow_down.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_yellow_down.9.png.flat new file mode 100644 index 0000000..50dd3e8 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_yellow_down.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_yellow_middle.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_yellow_middle.9.png.flat new file mode 100644 index 0000000..44afae8 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_yellow_middle.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_yellow_single.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_yellow_single.9.png.flat new file mode 100644 index 0000000..6e5f5b8 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_yellow_single.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_list_yellow_up.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_list_yellow_up.9.png.flat new file mode 100644 index 0000000..d088c77 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_list_yellow_up.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_menu_delete.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_menu_delete.png.flat new file mode 100644 index 0000000..122761f Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_menu_delete.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_menu_move.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_menu_move.png.flat new file mode 100644 index 0000000..9061391 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_menu_move.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_new_note_normal.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_new_note_normal.png.flat new file mode 100644 index 0000000..a7237ab Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_new_note_normal.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_new_note_pressed.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_new_note_pressed.png.flat new file mode 100644 index 0000000..c99fb54 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_new_note_pressed.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_note_edit_color_selector_panel.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_note_edit_color_selector_panel.png.flat new file mode 100644 index 0000000..6978df5 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_note_edit_color_selector_panel.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_notification.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_notification.png.flat new file mode 100644 index 0000000..859abdf Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_notification.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_search_result.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_search_result.png.flat new file mode 100644 index 0000000..0785bdc Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_search_result.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_selected.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_selected.png.flat new file mode 100644 index 0000000..ba34235 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_selected.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_title_alert.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_title_alert.png.flat new file mode 100644 index 0000000..02beeb6 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_title_alert.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_title_bar_bg.9.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_title_bar_bg.9.png.flat new file mode 100644 index 0000000..48b764c Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_title_bar_bg.9.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_widget_2x_blue.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_widget_2x_blue.png.flat new file mode 100644 index 0000000..e08a054 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_widget_2x_blue.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_widget_2x_green.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_widget_2x_green.png.flat new file mode 100644 index 0000000..f4890ab Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_widget_2x_green.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_widget_2x_red.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_widget_2x_red.png.flat new file mode 100644 index 0000000..8d7301b Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_widget_2x_red.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_widget_2x_white.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_widget_2x_white.png.flat new file mode 100644 index 0000000..7c7863e Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_widget_2x_white.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_widget_2x_yellow.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_widget_2x_yellow.png.flat new file mode 100644 index 0000000..4fee3f8 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_widget_2x_yellow.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_widget_4x_blue.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_widget_4x_blue.png.flat new file mode 100644 index 0000000..1a7f716 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_widget_4x_blue.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_widget_4x_green.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_widget_4x_green.png.flat new file mode 100644 index 0000000..168f906 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_widget_4x_green.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_widget_4x_red.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_widget_4x_red.png.flat new file mode 100644 index 0000000..33980c5 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_widget_4x_red.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_widget_4x_white.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_widget_4x_white.png.flat new file mode 100644 index 0000000..41d925d Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_widget_4x_white.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable-hdpi_widget_4x_yellow.png.flat b/app/build/intermediates/res/merged/release/drawable-hdpi_widget_4x_yellow.png.flat new file mode 100644 index 0000000..7934290 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable-hdpi_widget_4x_yellow.png.flat differ diff --git a/app/build/intermediates/res/merged/release/drawable_new_note.xml.flat b/app/build/intermediates/res/merged/release/drawable_new_note.xml.flat new file mode 100644 index 0000000..51144b6 Binary files /dev/null and b/app/build/intermediates/res/merged/release/drawable_new_note.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/layout_account_dialog_title.xml.flat b/app/build/intermediates/res/merged/release/layout_account_dialog_title.xml.flat new file mode 100644 index 0000000..1590dad Binary files /dev/null and b/app/build/intermediates/res/merged/release/layout_account_dialog_title.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/layout_add_account_text.xml.flat b/app/build/intermediates/res/merged/release/layout_add_account_text.xml.flat new file mode 100644 index 0000000..a77df14 Binary files /dev/null and b/app/build/intermediates/res/merged/release/layout_add_account_text.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/layout_datetime_picker.xml.flat b/app/build/intermediates/res/merged/release/layout_datetime_picker.xml.flat new file mode 100644 index 0000000..10ba5a0 Binary files /dev/null and b/app/build/intermediates/res/merged/release/layout_datetime_picker.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/layout_dialog_edit_text.xml.flat b/app/build/intermediates/res/merged/release/layout_dialog_edit_text.xml.flat new file mode 100644 index 0000000..74f8b88 Binary files /dev/null and b/app/build/intermediates/res/merged/release/layout_dialog_edit_text.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/layout_folder_list_item.xml.flat b/app/build/intermediates/res/merged/release/layout_folder_list_item.xml.flat new file mode 100644 index 0000000..a869b26 Binary files /dev/null and b/app/build/intermediates/res/merged/release/layout_folder_list_item.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/layout_note_edit.xml.flat b/app/build/intermediates/res/merged/release/layout_note_edit.xml.flat new file mode 100644 index 0000000..b97b36b Binary files /dev/null and b/app/build/intermediates/res/merged/release/layout_note_edit.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/layout_note_edit_list_item.xml.flat b/app/build/intermediates/res/merged/release/layout_note_edit_list_item.xml.flat new file mode 100644 index 0000000..61ca687 Binary files /dev/null and b/app/build/intermediates/res/merged/release/layout_note_edit_list_item.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/layout_note_item.xml.flat b/app/build/intermediates/res/merged/release/layout_note_item.xml.flat new file mode 100644 index 0000000..be599cb Binary files /dev/null and b/app/build/intermediates/res/merged/release/layout_note_item.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/layout_note_list.xml.flat b/app/build/intermediates/res/merged/release/layout_note_list.xml.flat new file mode 100644 index 0000000..5b75fa0 Binary files /dev/null and b/app/build/intermediates/res/merged/release/layout_note_list.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/layout_note_list_dropdown_menu.xml.flat b/app/build/intermediates/res/merged/release/layout_note_list_dropdown_menu.xml.flat new file mode 100644 index 0000000..e99cd69 Binary files /dev/null and b/app/build/intermediates/res/merged/release/layout_note_list_dropdown_menu.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/layout_note_list_footer.xml.flat b/app/build/intermediates/res/merged/release/layout_note_list_footer.xml.flat new file mode 100644 index 0000000..23a2199 Binary files /dev/null and b/app/build/intermediates/res/merged/release/layout_note_list_footer.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/layout_settings_header.xml.flat b/app/build/intermediates/res/merged/release/layout_settings_header.xml.flat new file mode 100644 index 0000000..f979f6c Binary files /dev/null and b/app/build/intermediates/res/merged/release/layout_settings_header.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/layout_widget_2x.xml.flat b/app/build/intermediates/res/merged/release/layout_widget_2x.xml.flat new file mode 100644 index 0000000..2be3f67 Binary files /dev/null and b/app/build/intermediates/res/merged/release/layout_widget_2x.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/layout_widget_4x.xml.flat b/app/build/intermediates/res/merged/release/layout_widget_4x.xml.flat new file mode 100644 index 0000000..82ddbd4 Binary files /dev/null and b/app/build/intermediates/res/merged/release/layout_widget_4x.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/menu_call_note_edit.xml.flat b/app/build/intermediates/res/merged/release/menu_call_note_edit.xml.flat new file mode 100644 index 0000000..4337509 Binary files /dev/null and b/app/build/intermediates/res/merged/release/menu_call_note_edit.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/menu_call_record_folder.xml.flat b/app/build/intermediates/res/merged/release/menu_call_record_folder.xml.flat new file mode 100644 index 0000000..a141a20 Binary files /dev/null and b/app/build/intermediates/res/merged/release/menu_call_record_folder.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/menu_note_edit.xml.flat b/app/build/intermediates/res/merged/release/menu_note_edit.xml.flat new file mode 100644 index 0000000..077e210 Binary files /dev/null and b/app/build/intermediates/res/merged/release/menu_note_edit.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/menu_note_list.xml.flat b/app/build/intermediates/res/merged/release/menu_note_list.xml.flat new file mode 100644 index 0000000..9edbee0 Binary files /dev/null and b/app/build/intermediates/res/merged/release/menu_note_list.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/menu_note_list_dropdown.xml.flat b/app/build/intermediates/res/merged/release/menu_note_list_dropdown.xml.flat new file mode 100644 index 0000000..c4129e6 Binary files /dev/null and b/app/build/intermediates/res/merged/release/menu_note_list_dropdown.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/menu_note_list_options.xml.flat b/app/build/intermediates/res/merged/release/menu_note_list_options.xml.flat new file mode 100644 index 0000000..3f65fb7 Binary files /dev/null and b/app/build/intermediates/res/merged/release/menu_note_list_options.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/menu_sub_folder.xml.flat b/app/build/intermediates/res/merged/release/menu_sub_folder.xml.flat new file mode 100644 index 0000000..37f498b Binary files /dev/null and b/app/build/intermediates/res/merged/release/menu_sub_folder.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/raw-zh-rCN_introduction.flat b/app/build/intermediates/res/merged/release/raw-zh-rCN_introduction.flat new file mode 100644 index 0000000..d511d1b Binary files /dev/null and b/app/build/intermediates/res/merged/release/raw-zh-rCN_introduction.flat differ diff --git a/app/build/intermediates/res/merged/release/raw_introduction.flat b/app/build/intermediates/res/merged/release/raw_introduction.flat new file mode 100644 index 0000000..690c18c Binary files /dev/null and b/app/build/intermediates/res/merged/release/raw_introduction.flat differ diff --git a/app/build/intermediates/res/merged/release/values-zh-rCN_values-zh-rCN.arsc.flat b/app/build/intermediates/res/merged/release/values-zh-rCN_values-zh-rCN.arsc.flat new file mode 100644 index 0000000..06f5484 Binary files /dev/null and b/app/build/intermediates/res/merged/release/values-zh-rCN_values-zh-rCN.arsc.flat differ diff --git a/app/build/intermediates/res/merged/release/values-zh-rTW_values-zh-rTW.arsc.flat b/app/build/intermediates/res/merged/release/values-zh-rTW_values-zh-rTW.arsc.flat new file mode 100644 index 0000000..358cef8 Binary files /dev/null and b/app/build/intermediates/res/merged/release/values-zh-rTW_values-zh-rTW.arsc.flat differ diff --git a/app/build/intermediates/res/merged/release/values_values.arsc.flat b/app/build/intermediates/res/merged/release/values_values.arsc.flat new file mode 100644 index 0000000..5b18c42 Binary files /dev/null and b/app/build/intermediates/res/merged/release/values_values.arsc.flat differ diff --git a/app/build/intermediates/res/merged/release/xml_preferences.xml.flat b/app/build/intermediates/res/merged/release/xml_preferences.xml.flat new file mode 100644 index 0000000..b7d0922 Binary files /dev/null and b/app/build/intermediates/res/merged/release/xml_preferences.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/xml_searchable.xml.flat b/app/build/intermediates/res/merged/release/xml_searchable.xml.flat new file mode 100644 index 0000000..4c49aa3 Binary files /dev/null and b/app/build/intermediates/res/merged/release/xml_searchable.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/xml_widget_2x_info.xml.flat b/app/build/intermediates/res/merged/release/xml_widget_2x_info.xml.flat new file mode 100644 index 0000000..392bd99 Binary files /dev/null and b/app/build/intermediates/res/merged/release/xml_widget_2x_info.xml.flat differ diff --git a/app/build/intermediates/res/merged/release/xml_widget_4x_info.xml.flat b/app/build/intermediates/res/merged/release/xml_widget_4x_info.xml.flat new file mode 100644 index 0000000..70b86ca Binary files /dev/null and b/app/build/intermediates/res/merged/release/xml_widget_4x_info.xml.flat differ diff --git a/app/build/intermediates/res/release/output.json b/app/build/intermediates/res/release/output.json new file mode 100644 index 0000000..1211154 --- /dev/null +++ b/app/build/intermediates/res/release/output.json @@ -0,0 +1 @@ +[{"outputType":{"type":"PROCESSED_RES"},"apkInfo":{"type":"MAIN","splits":[],"versionCode":1,"versionName":"0.1","enabled":true,"outputFile":"app-release-unsigned.apk","fullName":"release","baseName":"release"},"path":"resources-release.ap_","properties":{"packageId":"net.micode.notes","split":"","minSdkVersion":"14"}}] \ No newline at end of file diff --git a/app/build/intermediates/res/release/resources-release.ap_ b/app/build/intermediates/res/release/resources-release.ap_ new file mode 100644 index 0000000..81803ea Binary files /dev/null and b/app/build/intermediates/res/release/resources-release.ap_ differ diff --git a/app/build/intermediates/splits-support/androidTest/debug/apk-list/apk-list.gson b/app/build/intermediates/splits-support/androidTest/debug/apk-list/apk-list.gson new file mode 100644 index 0000000..857875b --- /dev/null +++ b/app/build/intermediates/splits-support/androidTest/debug/apk-list/apk-list.gson @@ -0,0 +1 @@ +[{"type":"MAIN","splits":[],"versionCode":-1,"enabled":true,"outputFile":"app-debug-androidTest.apk","fullName":"debugAndroidTest","baseName":"debug-androidTest"}] \ No newline at end of file diff --git a/app/build/intermediates/splits-support/debug/apk-list/apk-list.gson b/app/build/intermediates/splits-support/debug/apk-list/apk-list.gson new file mode 100644 index 0000000..6360b7c --- /dev/null +++ b/app/build/intermediates/splits-support/debug/apk-list/apk-list.gson @@ -0,0 +1 @@ +[{"type":"MAIN","splits":[],"versionCode":1,"versionName":"0.1","enabled":true,"outputFile":"app-debug.apk","fullName":"debug","baseName":"debug"}] \ No newline at end of file diff --git a/app/build/intermediates/splits-support/debug/split-list/split-list.gson b/app/build/intermediates/splits-support/debug/split-list/split-list.gson new file mode 100644 index 0000000..a111e0b --- /dev/null +++ b/app/build/intermediates/splits-support/debug/split-list/split-list.gson @@ -0,0 +1 @@ +[{"splitType":"DENSITY","filters":[]},{"splitType":"LANGUAGE","filters":[]},{"splitType":"ABI","filters":[]},{"splitType":"ResConfigs","filters":[]}] \ No newline at end of file diff --git a/app/build/intermediates/splits-support/release/apk-list/apk-list.gson b/app/build/intermediates/splits-support/release/apk-list/apk-list.gson new file mode 100644 index 0000000..991332a --- /dev/null +++ b/app/build/intermediates/splits-support/release/apk-list/apk-list.gson @@ -0,0 +1 @@ +[{"type":"MAIN","splits":[],"versionCode":1,"versionName":"0.1","enabled":true,"outputFile":"app-release-unsigned.apk","fullName":"release","baseName":"release"}] \ No newline at end of file diff --git a/app/build/intermediates/splits-support/release/split-list/split-list.gson b/app/build/intermediates/splits-support/release/split-list/split-list.gson new file mode 100644 index 0000000..a111e0b --- /dev/null +++ b/app/build/intermediates/splits-support/release/split-list/split-list.gson @@ -0,0 +1 @@ +[{"splitType":"DENSITY","filters":[]},{"splitType":"LANGUAGE","filters":[]},{"splitType":"ABI","filters":[]},{"splitType":"ResConfigs","filters":[]}] \ No newline at end of file diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/BuildConfig.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/BuildConfig.dex new file mode 100644 index 0000000..d8d1479 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/BuildConfig.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$array.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$array.dex new file mode 100644 index 0000000..72cfb2c Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$array.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$color.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$color.dex new file mode 100644 index 0000000..8b267e0 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$color.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$dimen.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$dimen.dex new file mode 100644 index 0000000..c2a324d Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$dimen.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$drawable.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$drawable.dex new file mode 100644 index 0000000..ef08a37 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$drawable.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$id.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$id.dex new file mode 100644 index 0000000..386771e Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$id.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$layout.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$layout.dex new file mode 100644 index 0000000..5c69aaf Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$layout.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$menu.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$menu.dex new file mode 100644 index 0000000..a31ad53 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$menu.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$plurals.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$plurals.dex new file mode 100644 index 0000000..0dfdef3 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$plurals.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$raw.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$raw.dex new file mode 100644 index 0000000..b6eda19 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$raw.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$string.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$string.dex new file mode 100644 index 0000000..22e912b Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$string.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$style.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$style.dex new file mode 100644 index 0000000..712e4b1 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$style.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$xml.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$xml.dex new file mode 100644 index 0000000..59dfe17 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R$xml.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R.dex new file mode 100644 index 0000000..10d07b2 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/R.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Contact.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Contact.dex new file mode 100644 index 0000000..17329b7 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Contact.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Notes$CallNote.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Notes$CallNote.dex new file mode 100644 index 0000000..712cf3a Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Notes$CallNote.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Notes$DataColumns.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Notes$DataColumns.dex new file mode 100644 index 0000000..d187917 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Notes$DataColumns.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Notes$DataConstants.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Notes$DataConstants.dex new file mode 100644 index 0000000..e718373 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Notes$DataConstants.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Notes$NoteColumns.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Notes$NoteColumns.dex new file mode 100644 index 0000000..212d2ea Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Notes$NoteColumns.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Notes$TextNote.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Notes$TextNote.dex new file mode 100644 index 0000000..f95de34 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Notes$TextNote.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Notes.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Notes.dex new file mode 100644 index 0000000..777a22f Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/Notes.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/NotesDatabaseHelper$TABLE.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/NotesDatabaseHelper$TABLE.dex new file mode 100644 index 0000000..d321c25 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/NotesDatabaseHelper$TABLE.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/NotesDatabaseHelper.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/NotesDatabaseHelper.dex new file mode 100644 index 0000000..81559b1 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/NotesDatabaseHelper.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/NotesProvider.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/NotesProvider.dex new file mode 100644 index 0000000..73c656c Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/data/NotesProvider.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/data/MetaData.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/data/MetaData.dex new file mode 100644 index 0000000..c3d83dc Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/data/MetaData.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/data/Node.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/data/Node.dex new file mode 100644 index 0000000..7f30f6a Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/data/Node.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/data/SqlData.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/data/SqlData.dex new file mode 100644 index 0000000..4b8687c Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/data/SqlData.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/data/SqlNote.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/data/SqlNote.dex new file mode 100644 index 0000000..5afbf6f Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/data/SqlNote.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/data/Task.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/data/Task.dex new file mode 100644 index 0000000..f8d55fb Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/data/Task.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/data/TaskList.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/data/TaskList.dex new file mode 100644 index 0000000..8ffa47b Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/data/TaskList.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/exception/ActionFailureException.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/exception/ActionFailureException.dex new file mode 100644 index 0000000..d2b901b Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/exception/ActionFailureException.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/exception/NetworkFailureException.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/exception/NetworkFailureException.dex new file mode 100644 index 0000000..ad0eb1e Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/exception/NetworkFailureException.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskASyncTask$1.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskASyncTask$1.dex new file mode 100644 index 0000000..073f497 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskASyncTask$1.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.dex new file mode 100644 index 0000000..5266a05 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskASyncTask.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskASyncTask.dex new file mode 100644 index 0000000..f029383 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskASyncTask.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskClient.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskClient.dex new file mode 100644 index 0000000..20f7161 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskClient.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskManager.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskManager.dex new file mode 100644 index 0000000..f471ee9 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskManager.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskSyncService$1.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskSyncService$1.dex new file mode 100644 index 0000000..a306a1d Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskSyncService$1.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskSyncService.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskSyncService.dex new file mode 100644 index 0000000..0010703 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/gtask/remote/GTaskSyncService.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/model/Note$NoteData.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/model/Note$NoteData.dex new file mode 100644 index 0000000..6315ebc Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/model/Note$NoteData.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/model/Note.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/model/Note.dex new file mode 100644 index 0000000..2a416a7 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/model/Note.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.dex new file mode 100644 index 0000000..3d2def9 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/model/WorkingNote.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/model/WorkingNote.dex new file mode 100644 index 0000000..d10d064 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/model/WorkingNote.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/BackupUtils$TextExport.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/BackupUtils$TextExport.dex new file mode 100644 index 0000000..134744c Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/BackupUtils$TextExport.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/BackupUtils.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/BackupUtils.dex new file mode 100644 index 0000000..f5d6cbc Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/BackupUtils.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/DataUtils.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/DataUtils.dex new file mode 100644 index 0000000..6c8cd7c Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/DataUtils.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/GTaskStringUtils.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/GTaskStringUtils.dex new file mode 100644 index 0000000..b0a39d4 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/GTaskStringUtils.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/ResourceParser$NoteBgResources.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/ResourceParser$NoteBgResources.dex new file mode 100644 index 0000000..973c3c3 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/ResourceParser$NoteBgResources.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/ResourceParser$NoteItemBgResources.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/ResourceParser$NoteItemBgResources.dex new file mode 100644 index 0000000..b2deff4 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/ResourceParser$NoteItemBgResources.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/ResourceParser$TextAppearanceResources.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/ResourceParser$TextAppearanceResources.dex new file mode 100644 index 0000000..4e7ac56 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/ResourceParser$TextAppearanceResources.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/ResourceParser$WidgetBgResources.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/ResourceParser$WidgetBgResources.dex new file mode 100644 index 0000000..7d2786f Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/ResourceParser$WidgetBgResources.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/ResourceParser.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/ResourceParser.dex new file mode 100644 index 0000000..95fa1b0 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/tool/ResourceParser.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/AlarmAlertActivity.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/AlarmAlertActivity.dex new file mode 100644 index 0000000..1668dc1 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/AlarmAlertActivity.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/AlarmInitReceiver.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/AlarmInitReceiver.dex new file mode 100644 index 0000000..821efce Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/AlarmInitReceiver.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/AlarmReceiver.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/AlarmReceiver.dex new file mode 100644 index 0000000..e9e16ab Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/AlarmReceiver.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePicker$1.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePicker$1.dex new file mode 100644 index 0000000..c3ab146 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePicker$1.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePicker$2.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePicker$2.dex new file mode 100644 index 0000000..4278ecc Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePicker$2.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePicker$3.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePicker$3.dex new file mode 100644 index 0000000..c8fc2fb Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePicker$3.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePicker$4.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePicker$4.dex new file mode 100644 index 0000000..70dbfdc Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePicker$4.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.dex new file mode 100644 index 0000000..7402c2e Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePicker.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePicker.dex new file mode 100644 index 0000000..9706c53 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePicker.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePickerDialog$1.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePickerDialog$1.dex new file mode 100644 index 0000000..fb6cb74 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePickerDialog$1.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.dex new file mode 100644 index 0000000..72401da Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePickerDialog.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePickerDialog.dex new file mode 100644 index 0000000..9360ac5 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DateTimePickerDialog.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DropdownMenu$1.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DropdownMenu$1.dex new file mode 100644 index 0000000..00b5e7b Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DropdownMenu$1.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DropdownMenu.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DropdownMenu.dex new file mode 100644 index 0000000..5370aa9 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/DropdownMenu.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/FoldersListAdapter$FolderListItem.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/FoldersListAdapter$FolderListItem.dex new file mode 100644 index 0000000..577ddca Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/FoldersListAdapter$FolderListItem.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/FoldersListAdapter.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/FoldersListAdapter.dex new file mode 100644 index 0000000..46a58bc Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/FoldersListAdapter.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$1.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$1.dex new file mode 100644 index 0000000..72ee2f7 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$1.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$10.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$10.dex new file mode 100644 index 0000000..02f6bd2 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$10.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$11.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$11.dex new file mode 100644 index 0000000..de89ea4 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$11.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$12.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$12.dex new file mode 100644 index 0000000..8719d56 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$12.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$2$1.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$2$1.dex new file mode 100644 index 0000000..33669cb Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$2$1.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$2.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$2.dex new file mode 100644 index 0000000..7a496fa Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$2.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$3.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$3.dex new file mode 100644 index 0000000..afa200a Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$3.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$4.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$4.dex new file mode 100644 index 0000000..c48a725 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$4.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$5.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$5.dex new file mode 100644 index 0000000..573cd1f Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$5.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$6.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$6.dex new file mode 100644 index 0000000..0692a5f Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$6.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$7.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$7.dex new file mode 100644 index 0000000..3b17d56 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$7.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$8$1.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$8$1.dex new file mode 100644 index 0000000..7c56f02 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$8$1.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$8.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$8.dex new file mode 100644 index 0000000..720a253 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$8.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$9.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$9.dex new file mode 100644 index 0000000..cee9624 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$9.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.dex new file mode 100644 index 0000000..c1068ba Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$RatingBarLayout$1.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$RatingBarLayout$1.dex new file mode 100644 index 0000000..2ba9db8 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$RatingBarLayout$1.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$RatingBarLayout.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$RatingBarLayout.dex new file mode 100644 index 0000000..c55e29d Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity$RatingBarLayout.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity.dex new file mode 100644 index 0000000..1898e97 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditActivity.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditText$1.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditText$1.dex new file mode 100644 index 0000000..fba0e2a Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditText$1.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.dex new file mode 100644 index 0000000..f5b7add Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditText.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditText.dex new file mode 100644 index 0000000..f7003a6 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteEditText.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteItemData.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteItemData.dex new file mode 100644 index 0000000..74bc1d6 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NoteItemData.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$1.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$1.dex new file mode 100644 index 0000000..7980d0d Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$1.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$2.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$2.dex new file mode 100644 index 0000000..efc0c55 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$2.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$3.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$3.dex new file mode 100644 index 0000000..55fa390 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$3.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$4.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$4.dex new file mode 100644 index 0000000..e7b00c7 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$4.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$5.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$5.dex new file mode 100644 index 0000000..372081e Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$5.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$6.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$6.dex new file mode 100644 index 0000000..5b78762 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$6.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$7.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$7.dex new file mode 100644 index 0000000..a75f543 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$7.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$8.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$8.dex new file mode 100644 index 0000000..b66bf16 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$8.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$9.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$9.dex new file mode 100644 index 0000000..495421f Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$9.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.dex new file mode 100644 index 0000000..cbf7ba7 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$ListEditState.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$ListEditState.dex new file mode 100644 index 0000000..d79a619 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$ListEditState.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$ModeCallback$1.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$ModeCallback$1.dex new file mode 100644 index 0000000..9f450e8 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$ModeCallback$1.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$ModeCallback$2.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$ModeCallback$2.dex new file mode 100644 index 0000000..d335a0c Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$ModeCallback$2.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$ModeCallback.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$ModeCallback.dex new file mode 100644 index 0000000..f8af81d Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$ModeCallback.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.dex new file mode 100644 index 0000000..ee0b411 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.dex new file mode 100644 index 0000000..cc086b1 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity.dex new file mode 100644 index 0000000..af0e03a Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListActivity.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.dex new file mode 100644 index 0000000..f5ba12e Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListAdapter.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListAdapter.dex new file mode 100644 index 0000000..aaead2e Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListAdapter.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListItem.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListItem.dex new file mode 100644 index 0000000..23caef3 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesListItem.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$1.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$1.dex new file mode 100644 index 0000000..b7acdbb Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$1.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$2.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$2.dex new file mode 100644 index 0000000..49a1276 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$2.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$3.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$3.dex new file mode 100644 index 0000000..55c3c78 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$3.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$4.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$4.dex new file mode 100644 index 0000000..6c2425d Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$4.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$5.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$5.dex new file mode 100644 index 0000000..9e3c18d Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$5.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$6.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$6.dex new file mode 100644 index 0000000..1db6419 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$6.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$7.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$7.dex new file mode 100644 index 0000000..ecbf44a Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$7.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$8.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$8.dex new file mode 100644 index 0000000..cc1c848 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$8.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.dex new file mode 100644 index 0000000..3eedc6a Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity.dex new file mode 100644 index 0000000..8c5dde6 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/NotesPreferenceActivity.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/OnPasswordInputFinish.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/OnPasswordInputFinish.dex new file mode 100644 index 0000000..fbafefc Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/OnPasswordInputFinish.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/PasswordView$1.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/PasswordView$1.dex new file mode 100644 index 0000000..df0998e Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/PasswordView$1.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/PasswordView$2.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/PasswordView$2.dex new file mode 100644 index 0000000..ea3f85f Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/PasswordView$2.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/PasswordView$3.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/PasswordView$3.dex new file mode 100644 index 0000000..0e9d0f3 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/PasswordView$3.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/PasswordView$ViewHolder.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/PasswordView$ViewHolder.dex new file mode 100644 index 0000000..50b562e Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/PasswordView$ViewHolder.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/PasswordView.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/PasswordView.dex new file mode 100644 index 0000000..2537df8 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/ui/PasswordView.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/widget/NoteWidgetProvider.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/widget/NoteWidgetProvider.dex new file mode 100644 index 0000000..6289d0b Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/widget/NoteWidgetProvider.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/widget/NoteWidgetProvider_2x.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/widget/NoteWidgetProvider_2x.dex new file mode 100644 index 0000000..7a85e39 Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/widget/NoteWidgetProvider_2x.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/widget/NoteWidgetProvider_4x.dex b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/widget/NoteWidgetProvider_4x.dex new file mode 100644 index 0000000..9c5160b Binary files /dev/null and b/app/build/intermediates/transforms/dexBuilder/debug/41/net/micode/notes/widget/NoteWidgetProvider_4x.dex differ diff --git a/app/build/intermediates/transforms/dexBuilder/debug/__content__.json b/app/build/intermediates/transforms/dexBuilder/debug/__content__.json new file mode 100644 index 0000000..02b3521 --- /dev/null +++ b/app/build/intermediates/transforms/dexBuilder/debug/__content__.json @@ -0,0 +1 @@ +[{"name":"98e12000108a377f6564a7ee34a911b164608161","index":41,"scopes":["PROJECT"],"types":["DEX_ARCHIVE"],"format":"DIRECTORY","present":true}] \ No newline at end of file diff --git a/app/build/intermediates/transforms/dexMerger/debug/37/classes.dex b/app/build/intermediates/transforms/dexMerger/debug/37/classes.dex new file mode 100644 index 0000000..3f667e3 Binary files /dev/null and b/app/build/intermediates/transforms/dexMerger/debug/37/classes.dex differ diff --git a/app/build/intermediates/transforms/dexMerger/debug/__content__.json b/app/build/intermediates/transforms/dexMerger/debug/__content__.json new file mode 100644 index 0000000..894ff68 --- /dev/null +++ b/app/build/intermediates/transforms/dexMerger/debug/__content__.json @@ -0,0 +1 @@ +[{"name":"main","index":37,"scopes":["SUB_PROJECTS","PROJECT","EXTERNAL_LIBRARIES"],"types":["DEX"],"format":"DIRECTORY","present":true}] \ No newline at end of file diff --git a/app/build/intermediates/transforms/externalLibsDexMerger/debug/__content__.json b/app/build/intermediates/transforms/externalLibsDexMerger/debug/__content__.json new file mode 100644 index 0000000..30a17cd --- /dev/null +++ b/app/build/intermediates/transforms/externalLibsDexMerger/debug/__content__.json @@ -0,0 +1 @@ +[{"name":"main","index":0,"scopes":["EXTERNAL_LIBRARIES"],"types":["DEX_ARCHIVE"],"format":"DIRECTORY","present":true}] \ No newline at end of file diff --git a/app/build/intermediates/transforms/mergeJavaRes/debug/0.jar b/app/build/intermediates/transforms/mergeJavaRes/debug/0.jar new file mode 100644 index 0000000..15cb0ec Binary files /dev/null and b/app/build/intermediates/transforms/mergeJavaRes/debug/0.jar differ diff --git a/app/build/intermediates/transforms/mergeJavaRes/debug/__content__.json b/app/build/intermediates/transforms/mergeJavaRes/debug/__content__.json new file mode 100644 index 0000000..1e6f3db --- /dev/null +++ b/app/build/intermediates/transforms/mergeJavaRes/debug/__content__.json @@ -0,0 +1 @@ +[{"name":"resources","index":0,"scopes":["PROJECT","EXTERNAL_LIBRARIES","SUB_PROJECTS"],"types":["RESOURCES"],"format":"JAR","present":true}] \ No newline at end of file diff --git a/app/build/intermediates/transforms/mergeJniLibs/debug/__content__.json b/app/build/intermediates/transforms/mergeJniLibs/debug/__content__.json new file mode 100644 index 0000000..12a45f5 --- /dev/null +++ b/app/build/intermediates/transforms/mergeJniLibs/debug/__content__.json @@ -0,0 +1 @@ +[{"name":"resources","index":1,"scopes":["PROJECT","SUB_PROJECTS","EXTERNAL_LIBRARIES"],"types":["NATIVE_LIBS"],"format":"DIRECTORY","present":false}] \ No newline at end of file diff --git a/app/build/outputs/apk/debug/app-debug.apk b/app/build/outputs/apk/debug/app-debug.apk new file mode 100644 index 0000000..dfa06fe Binary files /dev/null and b/app/build/outputs/apk/debug/app-debug.apk differ diff --git a/app/build/outputs/apk/debug/output.json b/app/build/outputs/apk/debug/output.json new file mode 100644 index 0000000..967e04f --- /dev/null +++ b/app/build/outputs/apk/debug/output.json @@ -0,0 +1 @@ +[{"outputType":{"type":"APK"},"apkInfo":{"type":"MAIN","splits":[],"versionCode":1,"versionName":"0.1","enabled":true,"outputFile":"app-debug.apk","fullName":"debug","baseName":"debug"},"path":"app-debug.apk","properties":{}}] \ No newline at end of file diff --git a/app/build/outputs/logs/manifest-merger-debug-report.txt b/app/build/outputs/logs/manifest-merger-debug-report.txt new file mode 100644 index 0000000..68b085c --- /dev/null +++ b/app/build/outputs/logs/manifest-merger-debug-report.txt @@ -0,0 +1,235 @@ +-- Merging decision tree log --- +manifest +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:18:1-150:12 +INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:18:1-150:12 +INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:18:1-150:12 +INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:18:1-150:12 +INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:18:1-150:12 +INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:18:1-150:12 +INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:18:1-150:12 + package + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:19:5-31 + INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml + INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml + android:versionName + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:21:5-30 + INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml + INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml + xmlns:android + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:18:11-69 + android:versionCode + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:20:5-28 + INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml + INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml +uses-sdk +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:23:5-44 +INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:23:5-44 +INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:23:5-44 +INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:23:5-44 +INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:23:5-44 + android:targetSdkVersion + INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:23:5-44 + INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml + android:minSdkVersion + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:23:15-41 + INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml + INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml +uses-permission#android.permission.WRITE_EXTERNAL_STORAGE +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:25:5-81 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:25:22-78 +uses-permission#com.android.launcher.permission.INSTALL_SHORTCUT +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:26:5-88 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:26:22-85 +uses-permission#android.permission.INTERNET +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:27:5-67 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:27:22-64 +uses-permission#android.permission.READ_CONTACTS +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:28:5-72 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:28:22-69 +uses-permission#android.permission.MANAGE_ACCOUNTS +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:29:5-74 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:29:22-71 +uses-permission#android.permission.AUTHENTICATE_ACCOUNTS +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:30:5-80 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:30:22-77 +uses-permission#android.permission.GET_ACCOUNTS +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:31:5-71 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:31:22-68 +uses-permission#android.permission.USE_CREDENTIALS +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:32:5-74 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:32:22-71 +uses-permission#android.permission.RECEIVE_BOOT_COMPLETED +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:33:5-81 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:33:22-78 +application +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:35:5-149:19 + android:label + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:37:9-41 + android:icon + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:36:9-42 +activity#net.micode.notes.ui.NotesListActivity +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:38:9-51:20 + android:label + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:41:13-45 + android:launchMode + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:42:13-43 + android:windowSoftInputMode + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:45:13-52 + android:uiOptions + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:44:13-57 + android:configChanges + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:40:13-74 + android:theme + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:43:13-45 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:39:13-49 +intent-filter#action:name:android.intent.action.MAIN+category:name:android.intent.category.LAUNCHER +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:47:13-50:29 +action#android.intent.action.MAIN +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:48:17-69 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:48:25-66 +category#android.intent.category.LAUNCHER +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:49:17-77 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:49:27-74 +activity#net.micode.notes.ui.NoteEditActivity +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:53:9-81:20 + android:launchMode + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:56:13-43 + android:configChanges + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:55:13-74 + android:theme + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:57:13-45 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:54:13-48 +intent-filter#action:name:android.intent.action.VIEW+category:name:android.intent.category.DEFAULT+data:mimeType:vnd.android.cursor.item/call_note+data:mimeType:vnd.android.cursor.item/text_note +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:59:13-64:29 +action#android.intent.action.VIEW +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:60:17-69 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:60:25-66 +category#android.intent.category.DEFAULT +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:61:17-76 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:61:27-73 +data +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:62:17-78 + android:mimeType + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:62:23-75 +intent-filter#action:name:android.intent.action.INSERT_OR_EDIT+category:name:android.intent.category.DEFAULT+data:mimeType:vnd.android.cursor.item/call_note+data:mimeType:vnd.android.cursor.item/text_note +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:66:13-71:29 +action#android.intent.action.INSERT_OR_EDIT +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:67:17-79 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:67:25-76 +intent-filter#action:name:android.intent.action.SEARCH+category:name:android.intent.category.DEFAULT +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:73:13-76:29 +action#android.intent.action.SEARCH +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:74:17-71 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:74:25-68 +meta-data#android.app.searchable +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:78:13-80:54 + android:resource + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:80:17-51 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:79:17-54 +provider#net.micode.notes.data.NotesProvider +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:83:9-86:43 + android:authorities + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:85:13-47 + android:multiprocess + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:86:13-40 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:84:13-63 +receiver#net.micode.notes.widget.NoteWidgetProvider_2x +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:88:9-100:20 + android:label + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:90:13-50 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:89:13-57 +intent-filter#action:name:android.appwidget.action.APPWIDGET_DELETED+action:name:android.appwidget.action.APPWIDGET_UPDATE+action:name:android.intent.action.PRIVACY_MODE_CHANGED +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:91:13-95:29 +action#android.appwidget.action.APPWIDGET_UPDATE +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:92:17-84 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:92:25-81 +action#android.appwidget.action.APPWIDGET_DELETED +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:93:17-85 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:93:25-82 +action#android.intent.action.PRIVACY_MODE_CHANGED +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:94:17-85 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:94:25-82 +meta-data#android.appwidget.provider +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:97:13-99:58 + android:resource + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:99:17-55 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:98:17-58 +receiver#net.micode.notes.widget.NoteWidgetProvider_4x +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:101:9-114:20 + android:label + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:103:13-50 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:102:13-57 +receiver#net.micode.notes.ui.AlarmInitReceiver +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:116:9-120:20 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:116:19-55 +intent-filter#action:name:android.intent.action.BOOT_COMPLETED +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:117:13-119:29 +action#android.intent.action.BOOT_COMPLETED +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:118:17-79 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:118:25-76 +receiver#net.micode.notes.ui.AlarmReceiver +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:122:9-125:20 + android:process + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:124:13-38 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:123:13-61 +activity#net.micode.notes.ui.AlarmAlertActivity +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:127:9-132:20 + android:label + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:129:13-45 + android:launchMode + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:130:13-48 + android:theme + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:131:13-75 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:128:13-50 +activity#net.micode.notes.ui.NotesPreferenceActivity +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:134:9-139:20 + android:label + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:136:13-54 + android:launchMode + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:137:13-43 + android:theme + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:138:13-60 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:135:13-71 +service#net.micode.notes.gtask.remote.GTaskSyncService +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:141:9-144:19 + android:exported + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:143:13-37 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:142:13-74 +meta-data#android.app.default_searchable +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:146:9-148:52 + android:value + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:148:13-49 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:147:13-58 diff --git a/app/build/outputs/logs/manifest-merger-release-report.txt b/app/build/outputs/logs/manifest-merger-release-report.txt new file mode 100644 index 0000000..68b085c --- /dev/null +++ b/app/build/outputs/logs/manifest-merger-release-report.txt @@ -0,0 +1,235 @@ +-- Merging decision tree log --- +manifest +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:18:1-150:12 +INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:18:1-150:12 +INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:18:1-150:12 +INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:18:1-150:12 +INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:18:1-150:12 +INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:18:1-150:12 +INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:18:1-150:12 + package + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:19:5-31 + INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml + INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml + android:versionName + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:21:5-30 + INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml + INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml + xmlns:android + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:18:11-69 + android:versionCode + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:20:5-28 + INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml + INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml +uses-sdk +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:23:5-44 +INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:23:5-44 +INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:23:5-44 +INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:23:5-44 +INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:23:5-44 + android:targetSdkVersion + INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:23:5-44 + INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml + android:minSdkVersion + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:23:15-41 + INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml + INJECTED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml +uses-permission#android.permission.WRITE_EXTERNAL_STORAGE +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:25:5-81 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:25:22-78 +uses-permission#com.android.launcher.permission.INSTALL_SHORTCUT +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:26:5-88 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:26:22-85 +uses-permission#android.permission.INTERNET +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:27:5-67 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:27:22-64 +uses-permission#android.permission.READ_CONTACTS +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:28:5-72 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:28:22-69 +uses-permission#android.permission.MANAGE_ACCOUNTS +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:29:5-74 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:29:22-71 +uses-permission#android.permission.AUTHENTICATE_ACCOUNTS +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:30:5-80 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:30:22-77 +uses-permission#android.permission.GET_ACCOUNTS +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:31:5-71 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:31:22-68 +uses-permission#android.permission.USE_CREDENTIALS +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:32:5-74 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:32:22-71 +uses-permission#android.permission.RECEIVE_BOOT_COMPLETED +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:33:5-81 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:33:22-78 +application +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:35:5-149:19 + android:label + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:37:9-41 + android:icon + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:36:9-42 +activity#net.micode.notes.ui.NotesListActivity +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:38:9-51:20 + android:label + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:41:13-45 + android:launchMode + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:42:13-43 + android:windowSoftInputMode + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:45:13-52 + android:uiOptions + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:44:13-57 + android:configChanges + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:40:13-74 + android:theme + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:43:13-45 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:39:13-49 +intent-filter#action:name:android.intent.action.MAIN+category:name:android.intent.category.LAUNCHER +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:47:13-50:29 +action#android.intent.action.MAIN +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:48:17-69 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:48:25-66 +category#android.intent.category.LAUNCHER +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:49:17-77 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:49:27-74 +activity#net.micode.notes.ui.NoteEditActivity +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:53:9-81:20 + android:launchMode + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:56:13-43 + android:configChanges + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:55:13-74 + android:theme + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:57:13-45 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:54:13-48 +intent-filter#action:name:android.intent.action.VIEW+category:name:android.intent.category.DEFAULT+data:mimeType:vnd.android.cursor.item/call_note+data:mimeType:vnd.android.cursor.item/text_note +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:59:13-64:29 +action#android.intent.action.VIEW +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:60:17-69 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:60:25-66 +category#android.intent.category.DEFAULT +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:61:17-76 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:61:27-73 +data +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:62:17-78 + android:mimeType + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:62:23-75 +intent-filter#action:name:android.intent.action.INSERT_OR_EDIT+category:name:android.intent.category.DEFAULT+data:mimeType:vnd.android.cursor.item/call_note+data:mimeType:vnd.android.cursor.item/text_note +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:66:13-71:29 +action#android.intent.action.INSERT_OR_EDIT +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:67:17-79 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:67:25-76 +intent-filter#action:name:android.intent.action.SEARCH+category:name:android.intent.category.DEFAULT +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:73:13-76:29 +action#android.intent.action.SEARCH +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:74:17-71 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:74:25-68 +meta-data#android.app.searchable +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:78:13-80:54 + android:resource + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:80:17-51 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:79:17-54 +provider#net.micode.notes.data.NotesProvider +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:83:9-86:43 + android:authorities + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:85:13-47 + android:multiprocess + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:86:13-40 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:84:13-63 +receiver#net.micode.notes.widget.NoteWidgetProvider_2x +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:88:9-100:20 + android:label + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:90:13-50 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:89:13-57 +intent-filter#action:name:android.appwidget.action.APPWIDGET_DELETED+action:name:android.appwidget.action.APPWIDGET_UPDATE+action:name:android.intent.action.PRIVACY_MODE_CHANGED +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:91:13-95:29 +action#android.appwidget.action.APPWIDGET_UPDATE +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:92:17-84 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:92:25-81 +action#android.appwidget.action.APPWIDGET_DELETED +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:93:17-85 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:93:25-82 +action#android.intent.action.PRIVACY_MODE_CHANGED +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:94:17-85 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:94:25-82 +meta-data#android.appwidget.provider +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:97:13-99:58 + android:resource + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:99:17-55 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:98:17-58 +receiver#net.micode.notes.widget.NoteWidgetProvider_4x +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:101:9-114:20 + android:label + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:103:13-50 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:102:13-57 +receiver#net.micode.notes.ui.AlarmInitReceiver +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:116:9-120:20 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:116:19-55 +intent-filter#action:name:android.intent.action.BOOT_COMPLETED +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:117:13-119:29 +action#android.intent.action.BOOT_COMPLETED +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:118:17-79 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:118:25-76 +receiver#net.micode.notes.ui.AlarmReceiver +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:122:9-125:20 + android:process + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:124:13-38 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:123:13-61 +activity#net.micode.notes.ui.AlarmAlertActivity +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:127:9-132:20 + android:label + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:129:13-45 + android:launchMode + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:130:13-48 + android:theme + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:131:13-75 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:128:13-50 +activity#net.micode.notes.ui.NotesPreferenceActivity +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:134:9-139:20 + android:label + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:136:13-54 + android:launchMode + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:137:13-43 + android:theme + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:138:13-60 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:135:13-71 +service#net.micode.notes.gtask.remote.GTaskSyncService +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:141:9-144:19 + android:exported + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:143:13-37 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:142:13-74 +meta-data#android.app.default_searchable +ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:146:9-148:52 + android:value + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:148:13-49 + android:name + ADDED from E:\NOTE\src\Notes-master\app\src\main\AndroidManifest.xml:147:13-58 diff --git a/app/build/reports/lint-results-release-fatal.html b/app/build/reports/lint-results-release-fatal.html new file mode 100644 index 0000000..e82cd9a --- /dev/null +++ b/app/build/reports/lint-results-release-fatal.html @@ -0,0 +1,3448 @@ + + + + + +Lint Report + + + + + + + + +
+
+
+ Lint Report: 5 errors +
+ +
+
+
+ Issue Types + +
+
+
+ +
+
+
+

Overview

+
+
+ + + + +
Correctness:Messages +
5error +MissingTranslation: Incomplete translation
Disabled Checks (279) +
+
+
+
+
+
+ + +
+
+
+

Incomplete translation

+
+
+
+
+../../src/main/res/values/arrays.xml:20: "format_for_exported_note" is not translated in "zh-CN" (Chinese: China), "zh-TW" (Chinese: Taiwan)
+ 17 
+ 18 <resources>
+ 19     <!-- Backup format -->
+ 20     <string-array name="format_for_exported_note">                                                  
+ 21         <item>-%s</item>      <!-- format_folder_name -->
+ 22         <item>--%s</item>     <!-- format_folder_note_date -->
+ 23         <item>--%s</item>     <!-- format_note_date -->
+ +../../src/main/res/values/strings.xml:39: "file_path" is not translated in "zh-CN" (Chinese: China), "zh-TW" (Chinese: Taiwan)
+  36     <string name="note_link_web">Browse web</string>
+  37     <string name="note_link_other">Open map</string>
+  38     <!-- Text export file information -->
+  39     <string name="file_path">/MIUI/notes/</string>                                                  
+  40     <string name="file_name_txt_format">notes_%s.txt</string>
+  41     <!-- notes list string -->
+  42     <string name="format_folder_files_count">(%d)</string>
+ +../../src/main/res/values/strings.xml:40: "file_name_txt_format" is not translated in "zh-CN" (Chinese: China), "zh-TW" (Chinese: Taiwan)
+  37     <string name="note_link_other">Open map</string>
+  38     <!-- Text export file information -->
+  39     <string name="file_path">/MIUI/notes/</string>
+  40     <string name="file_name_txt_format">notes_%s.txt</string>                                       
+  41     <!-- notes list string -->
+  42     <string name="format_folder_files_count">(%d)</string>
+  43     <string name="menu_create_folder">New Folder</string>
+ +../../src/main/res/values/strings.xml:42: "format_folder_files_count" is not translated in "zh-CN" (Chinese: China), "zh-TW" (Chinese: Taiwan)
+  39     <string name="file_path">/MIUI/notes/</string>
+  40     <string name="file_name_txt_format">notes_%s.txt</string>
+  41     <!-- notes list string -->
+  42     <string name="format_folder_files_count">(%d)</string>                                          
+  43     <string name="menu_create_folder">New Folder</string>
+  44     <string name="menu_export_text">Export text</string>
+  45     <string name="menu_sync">Sync</string>
+ +../../src/main/res/values/strings.xml:104: "preferences_last_sync_time_format" is not translated in "zh-CN" (Chinese: China), "zh-TW" (Chinese: Taiwan)
+ 101     <string name="preferences_account_title">Sync account</string>
+ 102     <string name="preferences_account_summary">Sync notes with google task</string>
+ 103     <string name="preferences_last_sync_time">Last sync time %1$s</string>
+ 104     <string name="preferences_last_sync_time_format">yyyy-MM-dd hh:mm:ss</string>                   
+ 105     <string name="preferences_add_account">Add account</string>
+ 106     <string name="preferences_menu_change_account">Change sync account</string>
+ 107     <string name="preferences_menu_remove_account">Remove sync account</string>
+ +
+ +
+
+ + MissingTranslation + + + Messages + + + Correctness + + + Fatal + + + Priority 8/10 + +
+
+
+
+
+
+ +
+
+
+

Disabled Checks

+
+
+One or more issues were not run by lint, either +because the check is not enabled by default, or because +it was disabled with a command line flag or via one or +more lint.xml configuration files in the project directories. +
+
+
+
+
+ +
+
+
+

Suppressing Warnings and Errors

+
+
+Lint errors can be suppressed in a variety of ways:
+
+1. With a @SuppressLint annotation in the Java code
+2. With a tools:ignore attribute in the XML file
+3. With a //noinspection comment in the source code
+4. With ignore flags specified in the build.gradle file, as explained below
+5. With a lint.xml configuration file in the project
+6. With a lint.xml configuration file passed to lint via the --config flag
+7. With the --ignore flag passed to lint.
+
+To suppress a lint warning with an annotation, add a @SuppressLint("id") annotation on the class, method or variable declaration closest to the warning instance you want to disable. The id can be one or more issue id's, such as "UnusedResources" or {"UnusedResources","UnusedIds"}, or it can be "all" to suppress all lint warnings in the given scope.
+
+To suppress a lint warning with a comment, add a //noinspection id comment on the line before the statement with the error.
+
+To suppress a lint warning in an XML file, add a tools:ignore="id" attribute on the element containing the error, or one of its surrounding elements. You also need to define the namespace for the tools prefix on the root element in your document, next to the xmlns:android declaration:
+xmlns:tools="http://schemas.android.com/tools"
+
+To suppress a lint warning in a build.gradle file, add a section like this:
+
+android {
+    lintOptions {
+        disable 'TypographyFractions','TypographyQuotes'
+    }
+}
+
+Here we specify a comma separated list of issue id's after the disable command. You can also use warning or error instead of disable to change the severity of issues.
+
+To suppress lint warnings with a configuration XML file, create a file named lint.xml and place it at the root directory of the module in which it applies.
+
+The format of the lint.xml file is something like the following:
+
+<?xml version="1.0" encoding="UTF-8"?>
+<lint>
+    <!-- Ignore everything in the test source set -->
+    <issue id="all">
+        <ignore path="*/test/*" />
+    </issue>
+
+    <!-- Disable this given check in this project -->
+    <issue id="IconMissingDensityFolder" severity="ignore" />
+
+    <!-- Ignore the ObsoleteLayoutParam issue in the given files -->
+    <issue id="ObsoleteLayoutParam">
+        <ignore path="res/layout/activation.xml" />
+        <ignore path="res/layout-xlarge/activation.xml" />
+        <ignore regexp="(foo|bar).java" />
+    </issue>
+
+    <!-- Ignore the UselessLeaf issue in the given file -->
+    <issue id="UselessLeaf">
+        <ignore path="res/layout/main.xml" />
+    </issue>
+
+    <!-- Change the severity of hardcoded strings to "error" -->
+    <issue id="HardcodedText" severity="error" />
+</lint>
+
+To suppress lint checks from the command line, pass the --ignore flag with a comma separated list of ids to be suppressed, such as:
+$ lint --ignore UnusedResources,UselessLeaf /my/project/path
+
+For more information, see http://g.co/androidstudio/suppressing-lint-warnings
+ +
+
+
+
+
+ + \ No newline at end of file diff --git a/app/build/reports/lint-results-release-fatal.xml b/app/build/reports/lint-results-release-fatal.xml new file mode 100644 index 0000000..284b5e1 --- /dev/null +++ b/app/build/reports/lint-results-release-fatal.xml @@ -0,0 +1,84 @@ + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/app/build/tmp/bundleAppClassesDebug/MANIFEST.MF b/app/build/tmp/bundleAppClassesDebug/MANIFEST.MF new file mode 100644 index 0000000..59499bc --- /dev/null +++ b/app/build/tmp/bundleAppClassesDebug/MANIFEST.MF @@ -0,0 +1,2 @@ +Manifest-Version: 1.0 + diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml new file mode 100644 index 0000000..e5c7d47 --- /dev/null +++ b/app/src/main/AndroidManifest.xml @@ -0,0 +1,150 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/app/src/main/java/net/micode/notes/data/Contact.java b/app/src/main/java/net/micode/notes/data/Contact.java new file mode 100644 index 0000000..d97ac5d --- /dev/null +++ b/app/src/main/java/net/micode/notes/data/Contact.java @@ -0,0 +1,73 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.data; + +import android.content.Context; +import android.database.Cursor; +import android.provider.ContactsContract.CommonDataKinds.Phone; +import android.provider.ContactsContract.Data; +import android.telephony.PhoneNumberUtils; +import android.util.Log; + +import java.util.HashMap; + +public class Contact { + private static HashMap sContactCache; + private static final String TAG = "Contact"; + + private static final String CALLER_ID_SELECTION = "PHONE_NUMBERS_EQUAL(" + Phone.NUMBER + + ",?) AND " + Data.MIMETYPE + "='" + Phone.CONTENT_ITEM_TYPE + "'" + + " AND " + Data.RAW_CONTACT_ID + " IN " + + "(SELECT raw_contact_id " + + " FROM phone_lookup" + + " WHERE min_match = '+')"; + + public static String getContact(Context context, String phoneNumber) { + if(sContactCache == null) { + sContactCache = new HashMap(); + } + + if(sContactCache.containsKey(phoneNumber)) { + return sContactCache.get(phoneNumber); + } + + String selection = CALLER_ID_SELECTION.replace("+", + PhoneNumberUtils.toCallerIDMinMatch(phoneNumber)); + Cursor cursor = context.getContentResolver().query( + Data.CONTENT_URI, + new String [] { Phone.DISPLAY_NAME }, + selection, + new String[] { phoneNumber }, + null); + + if (cursor != null && cursor.moveToFirst()) { + try { + String name = cursor.getString(0); + sContactCache.put(phoneNumber, name); + return name; + } catch (IndexOutOfBoundsException e) { + Log.e(TAG, " Cursor get string error " + e.toString()); + return null; + } finally { + cursor.close(); + } + } else { + Log.d(TAG, "No contact matched with number:" + phoneNumber); + return null; + } + } +} diff --git a/app/src/main/java/net/micode/notes/data/Notes.java b/app/src/main/java/net/micode/notes/data/Notes.java new file mode 100644 index 0000000..f727743 --- /dev/null +++ b/app/src/main/java/net/micode/notes/data/Notes.java @@ -0,0 +1,285 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.data; + +import android.net.Uri; +public class Notes { + public static final String AUTHORITY = "micode_notes"; + public static final String TAG = "Notes"; + public static final int TYPE_NOTE = 0; + public static final int TYPE_FOLDER = 1; + public static final int TYPE_SYSTEM = 2; + + /** + * Following IDs are system folders' identifiers + * {@link Notes#ID_ROOT_FOLDER } is default folder + * {@link Notes#ID_TEMPARAY_FOLDER } is for notes belonging no folder + * {@link Notes#ID_CALL_RECORD_FOLDER} is to store call records + */ + public static final int ID_ROOT_FOLDER = 0; + public static final int ID_TEMPARAY_FOLDER = -1; + public static final int ID_CALL_RECORD_FOLDER = -2; + public static final int ID_TRASH_FOLER = -3; + + public static final String INTENT_EXTRA_ALERT_DATE = "net.micode.notes.alert_date"; + public static final String INTENT_EXTRA_BACKGROUND_ID = "net.micode.notes.background_color_id"; + public static final String INTENT_EXTRA_WIDGET_ID = "net.micode.notes.widget_id"; + public static final String INTENT_EXTRA_WIDGET_TYPE = "net.micode.notes.widget_type"; + public static final String INTENT_EXTRA_FOLDER_ID = "net.micode.notes.folder_id"; + public static final String INTENT_EXTRA_CALL_DATE = "net.micode.notes.call_date"; + + public static final int TYPE_WIDGET_INVALIDE = -1; + public static final int TYPE_WIDGET_2X = 0; + public static final int TYPE_WIDGET_4X = 1; + + public static class DataConstants { + public static final String NOTE = TextNote.CONTENT_ITEM_TYPE; + public static final String CALL_NOTE = CallNote.CONTENT_ITEM_TYPE; + } + + /** + * Uri to query all notes and folders + */ + public static final Uri CONTENT_NOTE_URI = Uri.parse("content://" + AUTHORITY + "/note"); + + /** + * Uri to query data + */ + public static final Uri CONTENT_DATA_URI = Uri.parse("content://" + AUTHORITY + "/data"); + + public interface NoteColumns { + /** + * The unique ID for a row + *

Type: INTEGER (long)

+ */ + public static final String ID = "_id"; + + /** + * The parent's id for note or folder + *

Type: INTEGER (long)

+ */ + public static final String PARENT_ID = "parent_id"; + + /** + * Created data for note or folder + *

Type: INTEGER (long)

+ */ + public static final String CREATED_DATE = "created_date"; + + /** + * Latest modified date + *

Type: INTEGER (long)

+ */ + public static final String MODIFIED_DATE = "modified_date"; + + + /** + * Alert date + *

Type: INTEGER (long)

+ */ + public static final String ALERTED_DATE = "alert_date"; + + /** + * Folder's name or text content of note + *

Type: TEXT

+ */ + public static final String SNIPPET = "snippet"; + + /** + * Note's widget id + *

Type: INTEGER (long)

+ */ + public static final String WIDGET_ID = "widget_id"; + + /** + * Note's widget type + *

Type: INTEGER (long)

+ */ + public static final String WIDGET_TYPE = "widget_type"; + + /** + * Note's background color's id + *

Type: INTEGER (long)

+ */ + public static final String BG_COLOR_ID = "bg_color_id"; + + /** + * For text note, it doesn't has attachment, for multi-media + * note, it has at least one attachment + *

Type: INTEGER

+ */ + public static final String HAS_ATTACHMENT = "has_attachment"; + + /** + * Folder's count of notes + *

Type: INTEGER (long)

+ */ + public static final String NOTES_COUNT = "notes_count"; + + /** + * The file type: folder or note + *

Type: INTEGER

+ */ + public static final String TYPE = "type"; + + /** + * The last sync id + *

Type: INTEGER (long)

+ */ + public static final String SYNC_ID = "sync_id"; + + /** + * Sign to indicate local modified or not + *

Type: INTEGER

+ */ + public static final String LOCAL_MODIFIED = "local_modified"; + + /** + * Original parent id before moving into temporary folder + *

Type : INTEGER

+ */ + public static final String ORIGIN_PARENT_ID = "origin_parent_id"; + + /** + * The gtask id + *

Type : TEXT

+ */ + public static final String GTASK_ID = "gtask_id"; + + /** + * The version code + *

Type : INTEGER (long)

+ */ + public static final String VERSION = "version"; + + public static final String PASSWORD = "password"; + + public static final String IMPORTANCE = "importance"; + } + /* + * 便签数据在数据库中的表头 + */ + public interface DataColumns { + /** + * The unique ID for a row + *

Type: INTEGER (long)

+ */ + public static final String ID = "_id"; + + /** + * The MIME type of the item represented by this row. + *

Type: Text

+ */ + public static final String MIME_TYPE = "mime_type"; + + /** + * The reference id to note that this data belongs to + *

Type: INTEGER (long)

+ */ + public static final String NOTE_ID = "note_id"; + + /** + * Created data for note or folder + *

Type: INTEGER (long)

+ */ + public static final String CREATED_DATE = "created_date"; + + /** + * Latest modified date + *

Type: INTEGER (long)

+ */ + public static final String MODIFIED_DATE = "modified_date"; + + /** + * Data's content + *

Type: TEXT

+ */ + public static final String CONTENT = "content"; + + + /** + * Generic data column, the meaning is {@link #MIMETYPE} specific, used for + * integer data type + *

Type: INTEGER

+ */ + public static final String DATA1 = "data1"; + + /** + * Generic data column, the meaning is {@link #MIMETYPE} specific, used for + * integer data type + *

Type: INTEGER

+ */ + public static final String DATA2 = "data2"; + + /** + * Generic data column, the meaning is {@link #MIMETYPE} specific, used for + * TEXT data type + *

Type: TEXT

+ */ + public static final String DATA3 = "data3"; + + /** + * Generic data column, the meaning is {@link #MIMETYPE} specific, used for + * TEXT data type + *

Type: TEXT

+ */ + public static final String DATA4 = "data4"; + + /** + * Generic data column, the meaning is {@link #MIMETYPE} specific, used for + * TEXT data type + *

Type: TEXT

+ */ + public static final String DATA5 = "data5"; + } + + public static final class TextNote implements DataColumns { + /** + * Mode to indicate the text in check list mode or not + *

Type: Integer 1:check list mode 0: normal mode

+ */ + public static final String MODE = DATA1; + + public static final int MODE_CHECK_LIST = 1; + + public static final String CONTENT_TYPE = "vnd.android.cursor.dir/text_note"; + + public static final String CONTENT_ITEM_TYPE = "vnd.android.cursor.item/text_note"; + + public static final Uri CONTENT_URI = Uri.parse("content://" + AUTHORITY + "/text_note"); + } + + public static final class CallNote implements DataColumns { + /** + * Call date for this record + *

Type: INTEGER (long)

+ */ + public static final String CALL_DATE = DATA1; + + /** + * Phone number for this record + *

Type: TEXT

+ */ + public static final String PHONE_NUMBER = DATA3; + + public static final String CONTENT_TYPE = "vnd.android.cursor.dir/call_note"; + + public static final String CONTENT_ITEM_TYPE = "vnd.android.cursor.item/call_note"; + + public static final Uri CONTENT_URI = Uri.parse("content://" + AUTHORITY + "/call_note"); + } +} diff --git a/app/src/main/java/net/micode/notes/data/NotesDatabaseHelper.java b/app/src/main/java/net/micode/notes/data/NotesDatabaseHelper.java new file mode 100644 index 0000000..eb0a34b --- /dev/null +++ b/app/src/main/java/net/micode/notes/data/NotesDatabaseHelper.java @@ -0,0 +1,368 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.data; + +import android.content.ContentValues; +import android.content.Context; +import android.database.sqlite.SQLiteDatabase; +import android.database.sqlite.SQLiteOpenHelper; +import android.util.Log; + +import net.micode.notes.data.Notes.DataColumns; +import net.micode.notes.data.Notes.DataConstants; +import net.micode.notes.data.Notes.NoteColumns; + + +public class NotesDatabaseHelper extends SQLiteOpenHelper { + private static final String DB_NAME = "note2.db"; + + private static final int DB_VERSION = 4; + + public interface TABLE { + public static final String NOTE = "note"; + + public static final String DATA = "data"; + } + + private static final String TAG = "NotesDatabaseHelper"; + + private static NotesDatabaseHelper mInstance; + + private static final String CREATE_NOTE_TABLE_SQL = + "CREATE TABLE " + TABLE.NOTE + "(" + + NoteColumns.ID + " INTEGER PRIMARY KEY," + + NoteColumns.PARENT_ID + " INTEGER NOT NULL DEFAULT 0," + + NoteColumns.ALERTED_DATE + " INTEGER NOT NULL DEFAULT 0," + + NoteColumns.BG_COLOR_ID + " INTEGER NOT NULL DEFAULT 0," + + NoteColumns.CREATED_DATE + " INTEGER NOT NULL DEFAULT (strftime('%s','now') * 1000)," + + NoteColumns.HAS_ATTACHMENT + " INTEGER NOT NULL DEFAULT 0," + + NoteColumns.MODIFIED_DATE + " INTEGER NOT NULL DEFAULT (strftime('%s','now') * 1000)," + + NoteColumns.NOTES_COUNT + " INTEGER NOT NULL DEFAULT 0," + + NoteColumns.SNIPPET + " TEXT NOT NULL DEFAULT ''," + + NoteColumns.TYPE + " INTEGER NOT NULL DEFAULT 0," + + NoteColumns.WIDGET_ID + " INTEGER NOT NULL DEFAULT 0," + + NoteColumns.WIDGET_TYPE + " INTEGER NOT NULL DEFAULT -1," + + NoteColumns.SYNC_ID + " INTEGER NOT NULL DEFAULT 0," + + NoteColumns.LOCAL_MODIFIED + " INTEGER NOT NULL DEFAULT 0," + + NoteColumns.ORIGIN_PARENT_ID + " INTEGER NOT NULL DEFAULT 0," + + NoteColumns.GTASK_ID + " TEXT NOT NULL DEFAULT ''," + + NoteColumns.VERSION + " INTEGER NOT NULL DEFAULT 0," + + NoteColumns.PASSWORD + " TEXT NOT NULL DEFAULT ''," + + NoteColumns.IMPORTANCE + " INTEGER NOT NULL DEFAULT 0" + + ")"; + + private static final String CREATE_DATA_TABLE_SQL = + "CREATE TABLE " + TABLE.DATA + "(" + + DataColumns.ID + " INTEGER PRIMARY KEY," + + DataColumns.MIME_TYPE + " TEXT NOT NULL," + + DataColumns.NOTE_ID + " INTEGER NOT NULL DEFAULT 0," + + NoteColumns.CREATED_DATE + " INTEGER NOT NULL DEFAULT (strftime('%s','now') * 1000)," + + NoteColumns.MODIFIED_DATE + " INTEGER NOT NULL DEFAULT (strftime('%s','now') * 1000)," + + DataColumns.CONTENT + " TEXT NOT NULL DEFAULT ''," + + DataColumns.DATA1 + " INTEGER," + + DataColumns.DATA2 + " INTEGER," + + DataColumns.DATA3 + " TEXT NOT NULL DEFAULT ''," + + DataColumns.DATA4 + " TEXT NOT NULL DEFAULT ''," + + DataColumns.DATA5 + " TEXT NOT NULL DEFAULT ''" + + ")"; + + private static final String CREATE_DATA_NOTE_ID_INDEX_SQL = + "CREATE INDEX IF NOT EXISTS note_id_index ON " + + TABLE.DATA + "(" + DataColumns.NOTE_ID + ");"; + + /** + * Increase folder's note count when move note to the folder + */ + private static final String NOTE_INCREASE_FOLDER_COUNT_ON_UPDATE_TRIGGER = + "CREATE TRIGGER increase_folder_count_on_update "+ + " AFTER UPDATE OF " + NoteColumns.PARENT_ID + " ON " + TABLE.NOTE + + " BEGIN " + + " UPDATE " + TABLE.NOTE + + " SET " + NoteColumns.NOTES_COUNT + "=" + NoteColumns.NOTES_COUNT + " + 1" + + " WHERE " + NoteColumns.ID + "=new." + NoteColumns.PARENT_ID + ";" + + " END"; + + /** + * Decrease folder's note count when move note from folder + */ + private static final String NOTE_DECREASE_FOLDER_COUNT_ON_UPDATE_TRIGGER = + "CREATE TRIGGER decrease_folder_count_on_update " + + " AFTER UPDATE OF " + NoteColumns.PARENT_ID + " ON " + TABLE.NOTE + + " BEGIN " + + " UPDATE " + TABLE.NOTE + + " SET " + NoteColumns.NOTES_COUNT + "=" + NoteColumns.NOTES_COUNT + "-1" + + " WHERE " + NoteColumns.ID + "=old." + NoteColumns.PARENT_ID + + " AND " + NoteColumns.NOTES_COUNT + ">0" + ";" + + " END"; + + /** + * Increase folder's note count when insert new note to the folder + */ + private static final String NOTE_INCREASE_FOLDER_COUNT_ON_INSERT_TRIGGER = + "CREATE TRIGGER increase_folder_count_on_insert " + + " AFTER INSERT ON " + TABLE.NOTE + + " BEGIN " + + " UPDATE " + TABLE.NOTE + + " SET " + NoteColumns.NOTES_COUNT + "=" + NoteColumns.NOTES_COUNT + " + 1" + + " WHERE " + NoteColumns.ID + "=new." + NoteColumns.PARENT_ID + ";" + + " END"; + + /** + * Decrease folder's note count when delete note from the folder + */ + private static final String NOTE_DECREASE_FOLDER_COUNT_ON_DELETE_TRIGGER = + "CREATE TRIGGER decrease_folder_count_on_delete " + + " AFTER DELETE ON " + TABLE.NOTE + + " BEGIN " + + " UPDATE " + TABLE.NOTE + + " SET " + NoteColumns.NOTES_COUNT + "=" + NoteColumns.NOTES_COUNT + "-1" + + " WHERE " + NoteColumns.ID + "=old." + NoteColumns.PARENT_ID + + " AND " + NoteColumns.NOTES_COUNT + ">0;" + + " END"; + + /** + * Update note's content when insert data with type {@link DataConstants#NOTE} + */ + private static final String DATA_UPDATE_NOTE_CONTENT_ON_INSERT_TRIGGER = + "CREATE TRIGGER update_note_content_on_insert " + + " AFTER INSERT ON " + TABLE.DATA + + " WHEN new." + DataColumns.MIME_TYPE + "='" + DataConstants.NOTE + "'" + + " BEGIN" + + " UPDATE " + TABLE.NOTE + + " SET " + NoteColumns.SNIPPET + "=new." + DataColumns.CONTENT + + " WHERE " + NoteColumns.ID + "=new." + DataColumns.NOTE_ID + ";" + + " END"; + + /** + * Update note's content when data with {@link DataConstants#NOTE} type has changed + */ + private static final String DATA_UPDATE_NOTE_CONTENT_ON_UPDATE_TRIGGER = + "CREATE TRIGGER update_note_content_on_update " + + " AFTER UPDATE ON " + TABLE.DATA + + " WHEN old." + DataColumns.MIME_TYPE + "='" + DataConstants.NOTE + "'" + + " BEGIN" + + " UPDATE " + TABLE.NOTE + + " SET " + NoteColumns.SNIPPET + "=new." + DataColumns.CONTENT + + " WHERE " + NoteColumns.ID + "=new." + DataColumns.NOTE_ID + ";" + + " END"; + + /** + * Update note's content when data with {@link DataConstants#NOTE} type has deleted + */ + private static final String DATA_UPDATE_NOTE_CONTENT_ON_DELETE_TRIGGER = + "CREATE TRIGGER update_note_content_on_delete " + + " AFTER delete ON " + TABLE.DATA + + " WHEN old." + DataColumns.MIME_TYPE + "='" + DataConstants.NOTE + "'" + + " BEGIN" + + " UPDATE " + TABLE.NOTE + + " SET " + NoteColumns.SNIPPET + "=''" + + " WHERE " + NoteColumns.ID + "=old." + DataColumns.NOTE_ID + ";" + + " END"; + + /** + * Delete datas belong to note which has been deleted + */ + private static final String NOTE_DELETE_DATA_ON_DELETE_TRIGGER = + "CREATE TRIGGER delete_data_on_delete " + + " AFTER DELETE ON " + TABLE.NOTE + + " BEGIN" + + " DELETE FROM " + TABLE.DATA + + " WHERE " + DataColumns.NOTE_ID + "=old." + NoteColumns.ID + ";" + + " END"; + + /** + * Delete notes belong to folder which has been deleted + */ + private static final String FOLDER_DELETE_NOTES_ON_DELETE_TRIGGER = + "CREATE TRIGGER folder_delete_notes_on_delete " + + " AFTER DELETE ON " + TABLE.NOTE + + " BEGIN" + + " DELETE FROM " + TABLE.NOTE + + " WHERE " + NoteColumns.PARENT_ID + "=old." + NoteColumns.ID + ";" + + " END"; + + /** + * Move notes belong to folder which has been moved to trash folder + */ + private static final String FOLDER_MOVE_NOTES_ON_TRASH_TRIGGER = + "CREATE TRIGGER folder_move_notes_on_trash " + + " AFTER UPDATE ON " + TABLE.NOTE + + " WHEN new." + NoteColumns.PARENT_ID + "=" + Notes.ID_TRASH_FOLER + + " BEGIN" + + " UPDATE " + TABLE.NOTE + + " SET " + NoteColumns.PARENT_ID + "=" + Notes.ID_TRASH_FOLER + + " WHERE " + NoteColumns.PARENT_ID + "=old." + NoteColumns.ID + ";" + + " END"; + + public NotesDatabaseHelper(Context context) { + super(context, DB_NAME, null, DB_VERSION); + } + + public void createNoteTable(SQLiteDatabase db) { + db.execSQL(CREATE_NOTE_TABLE_SQL); + reCreateNoteTableTriggers(db); + createSystemFolder(db); + Log.d(TAG, "note table has been created"); + } + + private void reCreateNoteTableTriggers(SQLiteDatabase db) { + db.execSQL("DROP TRIGGER IF EXISTS increase_folder_count_on_update"); + db.execSQL("DROP TRIGGER IF EXISTS decrease_folder_count_on_update"); + db.execSQL("DROP TRIGGER IF EXISTS decrease_folder_count_on_delete"); + db.execSQL("DROP TRIGGER IF EXISTS delete_data_on_delete"); + db.execSQL("DROP TRIGGER IF EXISTS increase_folder_count_on_insert"); + db.execSQL("DROP TRIGGER IF EXISTS folder_delete_notes_on_delete"); + db.execSQL("DROP TRIGGER IF EXISTS folder_move_notes_on_trash"); + + db.execSQL(NOTE_INCREASE_FOLDER_COUNT_ON_UPDATE_TRIGGER); + db.execSQL(NOTE_DECREASE_FOLDER_COUNT_ON_UPDATE_TRIGGER); + db.execSQL(NOTE_DECREASE_FOLDER_COUNT_ON_DELETE_TRIGGER); + db.execSQL(NOTE_DELETE_DATA_ON_DELETE_TRIGGER); + db.execSQL(NOTE_INCREASE_FOLDER_COUNT_ON_INSERT_TRIGGER); + db.execSQL(FOLDER_DELETE_NOTES_ON_DELETE_TRIGGER); + db.execSQL(FOLDER_MOVE_NOTES_ON_TRASH_TRIGGER); + } + + private void createSystemFolder(SQLiteDatabase db) { + ContentValues values = new ContentValues(); + + /** + * call record foler for call notes + */ + values.put(NoteColumns.ID, Notes.ID_CALL_RECORD_FOLDER); + values.put(NoteColumns.TYPE, Notes.TYPE_SYSTEM); + db.insert(TABLE.NOTE, null, values); + + /** + * root folder which is default folder + */ + values.clear(); + values.put(NoteColumns.ID, Notes.ID_ROOT_FOLDER); + values.put(NoteColumns.TYPE, Notes.TYPE_SYSTEM); + db.insert(TABLE.NOTE, null, values); + + /** + * temporary folder which is used for moving note + */ + values.clear(); + values.put(NoteColumns.ID, Notes.ID_TEMPARAY_FOLDER); + values.put(NoteColumns.TYPE, Notes.TYPE_SYSTEM); + db.insert(TABLE.NOTE, null, values); + + /** + * create trash folder + */ + values.clear(); + values.put(NoteColumns.ID, Notes.ID_TRASH_FOLER); + values.put(NoteColumns.TYPE, Notes.TYPE_SYSTEM); + db.insert(TABLE.NOTE, null, values); + } + + public void createDataTable(SQLiteDatabase db) { + db.execSQL(CREATE_DATA_TABLE_SQL); + reCreateDataTableTriggers(db); + db.execSQL(CREATE_DATA_NOTE_ID_INDEX_SQL); + Log.d(TAG, "data table has been created"); + } + + private void reCreateDataTableTriggers(SQLiteDatabase db) { + db.execSQL("DROP TRIGGER IF EXISTS update_note_content_on_insert"); + db.execSQL("DROP TRIGGER IF EXISTS update_note_content_on_update"); + db.execSQL("DROP TRIGGER IF EXISTS update_note_content_on_delete"); + + db.execSQL(DATA_UPDATE_NOTE_CONTENT_ON_INSERT_TRIGGER); + db.execSQL(DATA_UPDATE_NOTE_CONTENT_ON_UPDATE_TRIGGER); + db.execSQL(DATA_UPDATE_NOTE_CONTENT_ON_DELETE_TRIGGER); + } + + static synchronized NotesDatabaseHelper getInstance(Context context) { + if (mInstance == null) { + mInstance = new NotesDatabaseHelper(context); + } + return mInstance; + } + + @Override + public void onCreate(SQLiteDatabase db) { + createNoteTable(db); + createDataTable(db); + } + + @Override + public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { + boolean reCreateTriggers = false; + boolean skipV2 = false; + + if (oldVersion == 1) { + upgradeToV2(db); + skipV2 = true; // this upgrade including the upgrade from v2 to v3 + oldVersion++; + } + + if (oldVersion == 2 && !skipV2) { + upgradeToV3(db); + reCreateTriggers = true; + oldVersion++; + } + + if (oldVersion == 3) { + upgradeToV4(db); + oldVersion++; + } + + if (reCreateTriggers) { + reCreateNoteTableTriggers(db); + reCreateDataTableTriggers(db); + } + + if (oldVersion != newVersion) { + throw new IllegalStateException("Upgrade notes database to version " + newVersion + + "fails"); + } + } + + private void upgradeToV2(SQLiteDatabase db) { + db.execSQL("DROP TABLE IF EXISTS " + TABLE.NOTE); + db.execSQL("DROP TABLE IF EXISTS " + TABLE.DATA); + createNoteTable(db); + createDataTable(db); + } + + private void upgradeToV3(SQLiteDatabase db) { + // drop unused triggers + db.execSQL("DROP TRIGGER IF EXISTS update_note_modified_date_on_insert"); + db.execSQL("DROP TRIGGER IF EXISTS update_note_modified_date_on_delete"); + db.execSQL("DROP TRIGGER IF EXISTS update_note_modified_date_on_update"); + // add a column for gtask id + db.execSQL("ALTER TABLE " + TABLE.NOTE + " ADD COLUMN " + NoteColumns.GTASK_ID + + " TEXT NOT NULL DEFAULT ''"); + // add a trash system folder + ContentValues values = new ContentValues(); + values.put(NoteColumns.ID, Notes.ID_TRASH_FOLER); + values.put(NoteColumns.TYPE, Notes.TYPE_SYSTEM); + db.insert(TABLE.NOTE, null, values); + } + + private void upgradeToV4(SQLiteDatabase db) { + db.execSQL("ALTER TABLE " + TABLE.NOTE + " ADD COLUMN " + NoteColumns.VERSION + + " INTEGER NOT NULL DEFAULT 0"); + db.execSQL("ALTER TABLE " + TABLE.NOTE + " ADD COLUMN " + NoteColumns.PASSWORD + + " TEXT NOT NULL DEFAULT ''"); + db.execSQL("ALTER TABLE " + TABLE.NOTE + " ADD COLUMN " + NoteColumns.IMPORTANCE + + " INTEGER NOT NULL DEFAULT 0"); + } +} diff --git a/app/src/main/java/net/micode/notes/data/NotesProvider.java b/app/src/main/java/net/micode/notes/data/NotesProvider.java new file mode 100644 index 0000000..edb0a60 --- /dev/null +++ b/app/src/main/java/net/micode/notes/data/NotesProvider.java @@ -0,0 +1,305 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.data; + + +import android.app.SearchManager; +import android.content.ContentProvider; +import android.content.ContentUris; +import android.content.ContentValues; +import android.content.Intent; +import android.content.UriMatcher; +import android.database.Cursor; +import android.database.sqlite.SQLiteDatabase; +import android.net.Uri; +import android.text.TextUtils; +import android.util.Log; + +import net.micode.notes.R; +import net.micode.notes.data.Notes.DataColumns; +import net.micode.notes.data.Notes.NoteColumns; +import net.micode.notes.data.NotesDatabaseHelper.TABLE; + + +public class NotesProvider extends ContentProvider { + private static final UriMatcher mMatcher; + + private NotesDatabaseHelper mHelper; + + private static final String TAG = "NotesProvider"; + + private static final int URI_NOTE = 1; + private static final int URI_NOTE_ITEM = 2; + private static final int URI_DATA = 3; + private static final int URI_DATA_ITEM = 4; + + private static final int URI_SEARCH = 5; + private static final int URI_SEARCH_SUGGEST = 6; + + static { + mMatcher = new UriMatcher(UriMatcher.NO_MATCH); + mMatcher.addURI(Notes.AUTHORITY, "note", URI_NOTE); + mMatcher.addURI(Notes.AUTHORITY, "note/#", URI_NOTE_ITEM); + mMatcher.addURI(Notes.AUTHORITY, "data", URI_DATA); + mMatcher.addURI(Notes.AUTHORITY, "data/#", URI_DATA_ITEM); + mMatcher.addURI(Notes.AUTHORITY, "search", URI_SEARCH); + mMatcher.addURI(Notes.AUTHORITY, SearchManager.SUGGEST_URI_PATH_QUERY, URI_SEARCH_SUGGEST); + mMatcher.addURI(Notes.AUTHORITY, SearchManager.SUGGEST_URI_PATH_QUERY + "/*", URI_SEARCH_SUGGEST); + } + + /** + * x'0A' represents the '\n' character in sqlite. For title and content in the search result, + * we will trim '\n' and white space in order to show more information. + */ + private static final String NOTES_SEARCH_PROJECTION = NoteColumns.ID + "," + + NoteColumns.ID + " AS " + SearchManager.SUGGEST_COLUMN_INTENT_EXTRA_DATA + "," + + "TRIM(REPLACE(" + NoteColumns.SNIPPET + ", x'0A','')) AS " + SearchManager.SUGGEST_COLUMN_TEXT_1 + "," + + "TRIM(REPLACE(" + NoteColumns.SNIPPET + ", x'0A','')) AS " + SearchManager.SUGGEST_COLUMN_TEXT_2 + "," + + R.drawable.search_result + " AS " + SearchManager.SUGGEST_COLUMN_ICON_1 + "," + + "'" + Intent.ACTION_VIEW + "' AS " + SearchManager.SUGGEST_COLUMN_INTENT_ACTION + "," + + "'" + Notes.TextNote.CONTENT_TYPE + "' AS " + SearchManager.SUGGEST_COLUMN_INTENT_DATA; + + private static String NOTES_SNIPPET_SEARCH_QUERY = "SELECT " + NOTES_SEARCH_PROJECTION + + " FROM " + TABLE.NOTE + + " WHERE " + NoteColumns.SNIPPET + " LIKE ?" + + " AND " + NoteColumns.PARENT_ID + "<>" + Notes.ID_TRASH_FOLER + + " AND " + NoteColumns.TYPE + "=" + Notes.TYPE_NOTE; + + @Override + public boolean onCreate() { + mHelper = NotesDatabaseHelper.getInstance(getContext()); + return true; + } + + @Override + public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, + String sortOrder) { + Cursor c = null; + SQLiteDatabase db = mHelper.getReadableDatabase(); + String id = null; + switch (mMatcher.match(uri)) { + case URI_NOTE: + c = db.query(TABLE.NOTE, projection, selection, selectionArgs, null, null, + sortOrder); + break; + case URI_NOTE_ITEM: + id = uri.getPathSegments().get(1); + c = db.query(TABLE.NOTE, projection, NoteColumns.ID + "=" + id + + parseSelection(selection), selectionArgs, null, null, sortOrder); + break; + case URI_DATA: + c = db.query(TABLE.DATA, projection, selection, selectionArgs, null, null, + sortOrder); + break; + case URI_DATA_ITEM: + id = uri.getPathSegments().get(1); + c = db.query(TABLE.DATA, projection, DataColumns.ID + "=" + id + + parseSelection(selection), selectionArgs, null, null, sortOrder); + break; + case URI_SEARCH: + case URI_SEARCH_SUGGEST: + if (sortOrder != null || projection != null) { + throw new IllegalArgumentException( + "do not specify sortOrder, selection, selectionArgs, or projection" + "with this query"); + } + + String searchString = null; + if (mMatcher.match(uri) == URI_SEARCH_SUGGEST) { + if (uri.getPathSegments().size() > 1) { + searchString = uri.getPathSegments().get(1); + } + } else { + searchString = uri.getQueryParameter("pattern"); + } + + if (TextUtils.isEmpty(searchString)) { + return null; + } + + try { + searchString = String.format("%%%s%%", searchString); + c = db.rawQuery(NOTES_SNIPPET_SEARCH_QUERY, + new String[] { searchString }); + } catch (IllegalStateException ex) { + Log.e(TAG, "got exception: " + ex.toString()); + } + break; + default: + throw new IllegalArgumentException("Unknown URI " + uri); + } + if (c != null) { + c.setNotificationUri(getContext().getContentResolver(), uri); + } + return c; + } + + @Override + public Uri insert(Uri uri, ContentValues values) { + SQLiteDatabase db = mHelper.getWritableDatabase(); + long dataId = 0, noteId = 0, insertedId = 0; + switch (mMatcher.match(uri)) { + case URI_NOTE: + insertedId = noteId = db.insert(TABLE.NOTE, null, values); + break; + case URI_DATA: + if (values.containsKey(DataColumns.NOTE_ID)) { + noteId = values.getAsLong(DataColumns.NOTE_ID); + } else { + Log.d(TAG, "Wrong data format without note id:" + values.toString()); + } + insertedId = dataId = db.insert(TABLE.DATA, null, values); + break; + default: + throw new IllegalArgumentException("Unknown URI " + uri); + } + // Notify the note uri + if (noteId > 0) { + getContext().getContentResolver().notifyChange( + ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, noteId), null); + } + + // Notify the data uri + if (dataId > 0) { + getContext().getContentResolver().notifyChange( + ContentUris.withAppendedId(Notes.CONTENT_DATA_URI, dataId), null); + } + + return ContentUris.withAppendedId(uri, insertedId); + } + + @Override + public int delete(Uri uri, String selection, String[] selectionArgs) { + int count = 0; + String id = null; + SQLiteDatabase db = mHelper.getWritableDatabase(); + boolean deleteData = false; + switch (mMatcher.match(uri)) { + case URI_NOTE: + selection = "(" + selection + ") AND " + NoteColumns.ID + ">0 "; + count = db.delete(TABLE.NOTE, selection, selectionArgs); + break; + case URI_NOTE_ITEM: + id = uri.getPathSegments().get(1); + /** + * ID that smaller than 0 is system folder which is not allowed to + * trash + */ + long noteId = Long.valueOf(id); + if (noteId <= 0) { + break; + } + count = db.delete(TABLE.NOTE, + NoteColumns.ID + "=" + id + parseSelection(selection), selectionArgs); + break; + case URI_DATA: + count = db.delete(TABLE.DATA, selection, selectionArgs); + deleteData = true; + break; + case URI_DATA_ITEM: + id = uri.getPathSegments().get(1); + count = db.delete(TABLE.DATA, + DataColumns.ID + "=" + id + parseSelection(selection), selectionArgs); + deleteData = true; + break; + default: + throw new IllegalArgumentException("Unknown URI " + uri); + } + if (count > 0) { + if (deleteData) { + getContext().getContentResolver().notifyChange(Notes.CONTENT_NOTE_URI, null); + } + getContext().getContentResolver().notifyChange(uri, null); + } + return count; + } + + @Override + public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) { + int count = 0; + String id = null; + SQLiteDatabase db = mHelper.getWritableDatabase(); + boolean updateData = false; + switch (mMatcher.match(uri)) { + case URI_NOTE: + increaseNoteVersion(-1, selection, selectionArgs); + count = db.update(TABLE.NOTE, values, selection, selectionArgs); + break; + case URI_NOTE_ITEM: + id = uri.getPathSegments().get(1); + increaseNoteVersion(Long.valueOf(id), selection, selectionArgs); + count = db.update(TABLE.NOTE, values, NoteColumns.ID + "=" + id + + parseSelection(selection), selectionArgs); + break; + case URI_DATA: + count = db.update(TABLE.DATA, values, selection, selectionArgs); + updateData = true; + break; + case URI_DATA_ITEM: + id = uri.getPathSegments().get(1); + count = db.update(TABLE.DATA, values, DataColumns.ID + "=" + id + + parseSelection(selection), selectionArgs); + updateData = true; + break; + default: + throw new IllegalArgumentException("Unknown URI " + uri); + } + + if (count > 0) { + if (updateData) { + getContext().getContentResolver().notifyChange(Notes.CONTENT_NOTE_URI, null); + } + getContext().getContentResolver().notifyChange(uri, null); + } + return count; + } + + private String parseSelection(String selection) { + return (!TextUtils.isEmpty(selection) ? " AND (" + selection + ')' : ""); + } + + private void increaseNoteVersion(long id, String selection, String[] selectionArgs) { + StringBuilder sql = new StringBuilder(120); + sql.append("UPDATE "); + sql.append(TABLE.NOTE); + sql.append(" SET "); + sql.append(NoteColumns.VERSION); + sql.append("=" + NoteColumns.VERSION + "+1 "); + + if (id > 0 || !TextUtils.isEmpty(selection)) { + sql.append(" WHERE "); + } + if (id > 0) { + sql.append(NoteColumns.ID + "=" + String.valueOf(id)); + } + if (!TextUtils.isEmpty(selection)) { + String selectString = id > 0 ? parseSelection(selection) : selection; + for (String args : selectionArgs) { + selectString = selectString.replaceFirst("\\?", args); + } + sql.append(selectString); + } + + mHelper.getWritableDatabase().execSQL(sql.toString()); + } + + @Override + public String getType(Uri uri) { + // TODO Auto-generated method stub + return null; + } + +} diff --git a/app/src/main/java/net/micode/notes/gtask/data/MetaData.java b/app/src/main/java/net/micode/notes/gtask/data/MetaData.java new file mode 100644 index 0000000..3a2050b --- /dev/null +++ b/app/src/main/java/net/micode/notes/gtask/data/MetaData.java @@ -0,0 +1,82 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.gtask.data; + +import android.database.Cursor; +import android.util.Log; + +import net.micode.notes.tool.GTaskStringUtils; + +import org.json.JSONException; +import org.json.JSONObject; + + +public class MetaData extends Task { + private final static String TAG = MetaData.class.getSimpleName(); + + private String mRelatedGid = null; + + public void setMeta(String gid, JSONObject metaInfo) { + try { + metaInfo.put(GTaskStringUtils.META_HEAD_GTASK_ID, gid); + } catch (JSONException e) { + Log.e(TAG, "failed to put related gid"); + } + setNotes(metaInfo.toString()); + setName(GTaskStringUtils.META_NOTE_NAME); + } + + public String getRelatedGid() { + return mRelatedGid; + } + + @Override + public boolean isWorthSaving() { + return getNotes() != null; + } + + @Override + public void setContentByRemoteJSON(JSONObject js) { + super.setContentByRemoteJSON(js); + if (getNotes() != null) { + try { + JSONObject metaInfo = new JSONObject(getNotes().trim()); + mRelatedGid = metaInfo.getString(GTaskStringUtils.META_HEAD_GTASK_ID); + } catch (JSONException e) { + Log.w(TAG, "failed to get related gid"); + mRelatedGid = null; + } + } + } + + @Override + public void setContentByLocalJSON(JSONObject js) { + // this function should not be called + throw new IllegalAccessError("MetaData:setContentByLocalJSON should not be called"); + } + + @Override + public JSONObject getLocalJSONFromContent() { + throw new IllegalAccessError("MetaData:getLocalJSONFromContent should not be called"); + } + + @Override + public int getSyncAction(Cursor c) { + throw new IllegalAccessError("MetaData:getSyncAction should not be called"); + } + +} diff --git a/app/src/main/java/net/micode/notes/gtask/data/Node.java b/app/src/main/java/net/micode/notes/gtask/data/Node.java new file mode 100644 index 0000000..63950e0 --- /dev/null +++ b/app/src/main/java/net/micode/notes/gtask/data/Node.java @@ -0,0 +1,101 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.gtask.data; + +import android.database.Cursor; + +import org.json.JSONObject; + +public abstract class Node { + public static final int SYNC_ACTION_NONE = 0; + + public static final int SYNC_ACTION_ADD_REMOTE = 1; + + public static final int SYNC_ACTION_ADD_LOCAL = 2; + + public static final int SYNC_ACTION_DEL_REMOTE = 3; + + public static final int SYNC_ACTION_DEL_LOCAL = 4; + + public static final int SYNC_ACTION_UPDATE_REMOTE = 5; + + public static final int SYNC_ACTION_UPDATE_LOCAL = 6; + + public static final int SYNC_ACTION_UPDATE_CONFLICT = 7; + + public static final int SYNC_ACTION_ERROR = 8; + + private String mGid; + + private String mName; + + private long mLastModified; + + private boolean mDeleted; + + public Node() { + mGid = null; + mName = ""; + mLastModified = 0; + mDeleted = false; + } + + public abstract JSONObject getCreateAction(int actionId); + + public abstract JSONObject getUpdateAction(int actionId); + + public abstract void setContentByRemoteJSON(JSONObject js); + + public abstract void setContentByLocalJSON(JSONObject js); + + public abstract JSONObject getLocalJSONFromContent(); + + public abstract int getSyncAction(Cursor c); + + public void setGid(String gid) { + this.mGid = gid; + } + + public void setName(String name) { + this.mName = name; + } + + public void setLastModified(long lastModified) { + this.mLastModified = lastModified; + } + + public void setDeleted(boolean deleted) { + this.mDeleted = deleted; + } + + public String getGid() { + return this.mGid; + } + + public String getName() { + return this.mName; + } + + public long getLastModified() { + return this.mLastModified; + } + + public boolean getDeleted() { + return this.mDeleted; + } + +} diff --git a/app/src/main/java/net/micode/notes/gtask/data/SqlData.java b/app/src/main/java/net/micode/notes/gtask/data/SqlData.java new file mode 100644 index 0000000..d3ec3be --- /dev/null +++ b/app/src/main/java/net/micode/notes/gtask/data/SqlData.java @@ -0,0 +1,189 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.gtask.data; + +import android.content.ContentResolver; +import android.content.ContentUris; +import android.content.ContentValues; +import android.content.Context; +import android.database.Cursor; +import android.net.Uri; +import android.util.Log; + +import net.micode.notes.data.Notes; +import net.micode.notes.data.Notes.DataColumns; +import net.micode.notes.data.Notes.DataConstants; +import net.micode.notes.data.Notes.NoteColumns; +import net.micode.notes.data.NotesDatabaseHelper.TABLE; +import net.micode.notes.gtask.exception.ActionFailureException; + +import org.json.JSONException; +import org.json.JSONObject; + + +public class SqlData { + private static final String TAG = SqlData.class.getSimpleName(); + + private static final int INVALID_ID = -99999; + + public static final String[] PROJECTION_DATA = new String[] { + DataColumns.ID, DataColumns.MIME_TYPE, DataColumns.CONTENT, DataColumns.DATA1, + DataColumns.DATA3 + }; + + public static final int DATA_ID_COLUMN = 0; + + public static final int DATA_MIME_TYPE_COLUMN = 1; + + public static final int DATA_CONTENT_COLUMN = 2; + + public static final int DATA_CONTENT_DATA_1_COLUMN = 3; + + public static final int DATA_CONTENT_DATA_3_COLUMN = 4; + + private ContentResolver mContentResolver; + + private boolean mIsCreate; + + private long mDataId; + + private String mDataMimeType; + + private String mDataContent; + + private long mDataContentData1; + + private String mDataContentData3; + + private ContentValues mDiffDataValues; + + public SqlData(Context context) { + mContentResolver = context.getContentResolver(); + mIsCreate = true; + mDataId = INVALID_ID; + mDataMimeType = DataConstants.NOTE; + mDataContent = ""; + mDataContentData1 = 0; + mDataContentData3 = ""; + mDiffDataValues = new ContentValues(); + } + + public SqlData(Context context, Cursor c) { + mContentResolver = context.getContentResolver(); + mIsCreate = false; + loadFromCursor(c); + mDiffDataValues = new ContentValues(); + } + + private void loadFromCursor(Cursor c) { + mDataId = c.getLong(DATA_ID_COLUMN); + mDataMimeType = c.getString(DATA_MIME_TYPE_COLUMN); + mDataContent = c.getString(DATA_CONTENT_COLUMN); + mDataContentData1 = c.getLong(DATA_CONTENT_DATA_1_COLUMN); + mDataContentData3 = c.getString(DATA_CONTENT_DATA_3_COLUMN); + } + + public void setContent(JSONObject js) throws JSONException { + long dataId = js.has(DataColumns.ID) ? js.getLong(DataColumns.ID) : INVALID_ID; + if (mIsCreate || mDataId != dataId) { + mDiffDataValues.put(DataColumns.ID, dataId); + } + mDataId = dataId; + + String dataMimeType = js.has(DataColumns.MIME_TYPE) ? js.getString(DataColumns.MIME_TYPE) + : DataConstants.NOTE; + if (mIsCreate || !mDataMimeType.equals(dataMimeType)) { + mDiffDataValues.put(DataColumns.MIME_TYPE, dataMimeType); + } + mDataMimeType = dataMimeType; + + String dataContent = js.has(DataColumns.CONTENT) ? js.getString(DataColumns.CONTENT) : ""; + if (mIsCreate || !mDataContent.equals(dataContent)) { + mDiffDataValues.put(DataColumns.CONTENT, dataContent); + } + mDataContent = dataContent; + + long dataContentData1 = js.has(DataColumns.DATA1) ? js.getLong(DataColumns.DATA1) : 0; + if (mIsCreate || mDataContentData1 != dataContentData1) { + mDiffDataValues.put(DataColumns.DATA1, dataContentData1); + } + mDataContentData1 = dataContentData1; + + String dataContentData3 = js.has(DataColumns.DATA3) ? js.getString(DataColumns.DATA3) : ""; + if (mIsCreate || !mDataContentData3.equals(dataContentData3)) { + mDiffDataValues.put(DataColumns.DATA3, dataContentData3); + } + mDataContentData3 = dataContentData3; + } + + public JSONObject getContent() throws JSONException { + if (mIsCreate) { + Log.e(TAG, "it seems that we haven't created this in database yet"); + return null; + } + JSONObject js = new JSONObject(); + js.put(DataColumns.ID, mDataId); + js.put(DataColumns.MIME_TYPE, mDataMimeType); + js.put(DataColumns.CONTENT, mDataContent); + js.put(DataColumns.DATA1, mDataContentData1); + js.put(DataColumns.DATA3, mDataContentData3); + return js; + } + + public void commit(long noteId, boolean validateVersion, long version) { + + if (mIsCreate) { + if (mDataId == INVALID_ID && mDiffDataValues.containsKey(DataColumns.ID)) { + mDiffDataValues.remove(DataColumns.ID); + } + + mDiffDataValues.put(DataColumns.NOTE_ID, noteId); + Uri uri = mContentResolver.insert(Notes.CONTENT_DATA_URI, mDiffDataValues); + try { + mDataId = Long.valueOf(uri.getPathSegments().get(1)); + } catch (NumberFormatException e) { + Log.e(TAG, "Get note id error :" + e.toString()); + throw new ActionFailureException("create note failed"); + } + } else { + if (mDiffDataValues.size() > 0) { + int result = 0; + if (!validateVersion) { + result = mContentResolver.update(ContentUris.withAppendedId( + Notes.CONTENT_DATA_URI, mDataId), mDiffDataValues, null, null); + } else { + result = mContentResolver.update(ContentUris.withAppendedId( + Notes.CONTENT_DATA_URI, mDataId), mDiffDataValues, + " ? in (SELECT " + NoteColumns.ID + " FROM " + TABLE.NOTE + + " WHERE " + NoteColumns.VERSION + "=?)", new String[] { + String.valueOf(noteId), String.valueOf(version) + }); + } + if (result == 0) { + Log.w(TAG, "there is no update. maybe user updates note when syncing"); + } + } + } + + mDiffDataValues.clear(); + mIsCreate = false; + } + + public long getId() { + return mDataId; + } +} diff --git a/app/src/main/java/net/micode/notes/gtask/data/SqlNote.java b/app/src/main/java/net/micode/notes/gtask/data/SqlNote.java new file mode 100644 index 0000000..79a4095 --- /dev/null +++ b/app/src/main/java/net/micode/notes/gtask/data/SqlNote.java @@ -0,0 +1,505 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.gtask.data; + +import android.appwidget.AppWidgetManager; +import android.content.ContentResolver; +import android.content.ContentValues; +import android.content.Context; +import android.database.Cursor; +import android.net.Uri; +import android.util.Log; + +import net.micode.notes.data.Notes; +import net.micode.notes.data.Notes.DataColumns; +import net.micode.notes.data.Notes.NoteColumns; +import net.micode.notes.gtask.exception.ActionFailureException; +import net.micode.notes.tool.GTaskStringUtils; +import net.micode.notes.tool.ResourceParser; + +import org.json.JSONArray; +import org.json.JSONException; +import org.json.JSONObject; + +import java.util.ArrayList; + + +public class SqlNote { + private static final String TAG = SqlNote.class.getSimpleName(); + + private static final int INVALID_ID = -99999; + + public static final String[] PROJECTION_NOTE = new String[] { + NoteColumns.ID, NoteColumns.ALERTED_DATE, NoteColumns.BG_COLOR_ID, + NoteColumns.CREATED_DATE, NoteColumns.HAS_ATTACHMENT, NoteColumns.MODIFIED_DATE, + NoteColumns.NOTES_COUNT, NoteColumns.PARENT_ID, NoteColumns.SNIPPET, NoteColumns.TYPE, + NoteColumns.WIDGET_ID, NoteColumns.WIDGET_TYPE, NoteColumns.SYNC_ID, + NoteColumns.LOCAL_MODIFIED, NoteColumns.ORIGIN_PARENT_ID, NoteColumns.GTASK_ID, + NoteColumns.VERSION + }; + + public static final int ID_COLUMN = 0; + + public static final int ALERTED_DATE_COLUMN = 1; + + public static final int BG_COLOR_ID_COLUMN = 2; + + public static final int CREATED_DATE_COLUMN = 3; + + public static final int HAS_ATTACHMENT_COLUMN = 4; + + public static final int MODIFIED_DATE_COLUMN = 5; + + public static final int NOTES_COUNT_COLUMN = 6; + + public static final int PARENT_ID_COLUMN = 7; + + public static final int SNIPPET_COLUMN = 8; + + public static final int TYPE_COLUMN = 9; + + public static final int WIDGET_ID_COLUMN = 10; + + public static final int WIDGET_TYPE_COLUMN = 11; + + public static final int SYNC_ID_COLUMN = 12; + + public static final int LOCAL_MODIFIED_COLUMN = 13; + + public static final int ORIGIN_PARENT_ID_COLUMN = 14; + + public static final int GTASK_ID_COLUMN = 15; + + public static final int VERSION_COLUMN = 16; + + private Context mContext; + + private ContentResolver mContentResolver; + + private boolean mIsCreate; + + private long mId; + + private long mAlertDate; + + private int mBgColorId; + + private long mCreatedDate; + + private int mHasAttachment; + + private long mModifiedDate; + + private long mParentId; + + private String mSnippet; + + private int mType; + + private int mWidgetId; + + private int mWidgetType; + + private long mOriginParent; + + private long mVersion; + + private ContentValues mDiffNoteValues; + + private ArrayList mDataList; + + public SqlNote(Context context) { + mContext = context; + mContentResolver = context.getContentResolver(); + mIsCreate = true; + mId = INVALID_ID; + mAlertDate = 0; + mBgColorId = ResourceParser.getDefaultBgId(context); + mCreatedDate = System.currentTimeMillis(); + mHasAttachment = 0; + mModifiedDate = System.currentTimeMillis(); + mParentId = 0; + mSnippet = ""; + mType = Notes.TYPE_NOTE; + mWidgetId = AppWidgetManager.INVALID_APPWIDGET_ID; + mWidgetType = Notes.TYPE_WIDGET_INVALIDE; + mOriginParent = 0; + mVersion = 0; + mDiffNoteValues = new ContentValues(); + mDataList = new ArrayList(); + } + + public SqlNote(Context context, Cursor c) { + mContext = context; + mContentResolver = context.getContentResolver(); + mIsCreate = false; + loadFromCursor(c); + mDataList = new ArrayList(); + if (mType == Notes.TYPE_NOTE) + loadDataContent(); + mDiffNoteValues = new ContentValues(); + } + + public SqlNote(Context context, long id) { + mContext = context; + mContentResolver = context.getContentResolver(); + mIsCreate = false; + loadFromCursor(id); + mDataList = new ArrayList(); + if (mType == Notes.TYPE_NOTE) + loadDataContent(); + mDiffNoteValues = new ContentValues(); + + } + + private void loadFromCursor(long id) { + Cursor c = null; + try { + c = mContentResolver.query(Notes.CONTENT_NOTE_URI, PROJECTION_NOTE, "(_id=?)", + new String[] { + String.valueOf(id) + }, null); + if (c != null) { + c.moveToNext(); + loadFromCursor(c); + } else { + Log.w(TAG, "loadFromCursor: cursor = null"); + } + } finally { + if (c != null) + c.close(); + } + } + + private void loadFromCursor(Cursor c) { + mId = c.getLong(ID_COLUMN); + mAlertDate = c.getLong(ALERTED_DATE_COLUMN); + mBgColorId = c.getInt(BG_COLOR_ID_COLUMN); + mCreatedDate = c.getLong(CREATED_DATE_COLUMN); + mHasAttachment = c.getInt(HAS_ATTACHMENT_COLUMN); + mModifiedDate = c.getLong(MODIFIED_DATE_COLUMN); + mParentId = c.getLong(PARENT_ID_COLUMN); + mSnippet = c.getString(SNIPPET_COLUMN); + mType = c.getInt(TYPE_COLUMN); + mWidgetId = c.getInt(WIDGET_ID_COLUMN); + mWidgetType = c.getInt(WIDGET_TYPE_COLUMN); + mVersion = c.getLong(VERSION_COLUMN); + } + + private void loadDataContent() { + Cursor c = null; + mDataList.clear(); + try { + c = mContentResolver.query(Notes.CONTENT_DATA_URI, SqlData.PROJECTION_DATA, + "(note_id=?)", new String[] { + String.valueOf(mId) + }, null); + if (c != null) { + if (c.getCount() == 0) { + Log.w(TAG, "it seems that the note has not data"); + return; + } + while (c.moveToNext()) { + SqlData data = new SqlData(mContext, c); + mDataList.add(data); + } + } else { + Log.w(TAG, "loadDataContent: cursor = null"); + } + } finally { + if (c != null) + c.close(); + } + } + + public boolean setContent(JSONObject js) { + try { + JSONObject note = js.getJSONObject(GTaskStringUtils.META_HEAD_NOTE); + if (note.getInt(NoteColumns.TYPE) == Notes.TYPE_SYSTEM) { + Log.w(TAG, "cannot set system folder"); + } else if (note.getInt(NoteColumns.TYPE) == Notes.TYPE_FOLDER) { + // for folder we can only update the snnipet and type + String snippet = note.has(NoteColumns.SNIPPET) ? note + .getString(NoteColumns.SNIPPET) : ""; + if (mIsCreate || !mSnippet.equals(snippet)) { + mDiffNoteValues.put(NoteColumns.SNIPPET, snippet); + } + mSnippet = snippet; + + int type = note.has(NoteColumns.TYPE) ? note.getInt(NoteColumns.TYPE) + : Notes.TYPE_NOTE; + if (mIsCreate || mType != type) { + mDiffNoteValues.put(NoteColumns.TYPE, type); + } + mType = type; + } else if (note.getInt(NoteColumns.TYPE) == Notes.TYPE_NOTE) { + JSONArray dataArray = js.getJSONArray(GTaskStringUtils.META_HEAD_DATA); + long id = note.has(NoteColumns.ID) ? note.getLong(NoteColumns.ID) : INVALID_ID; + if (mIsCreate || mId != id) { + mDiffNoteValues.put(NoteColumns.ID, id); + } + mId = id; + + long alertDate = note.has(NoteColumns.ALERTED_DATE) ? note + .getLong(NoteColumns.ALERTED_DATE) : 0; + if (mIsCreate || mAlertDate != alertDate) { + mDiffNoteValues.put(NoteColumns.ALERTED_DATE, alertDate); + } + mAlertDate = alertDate; + + int bgColorId = note.has(NoteColumns.BG_COLOR_ID) ? note + .getInt(NoteColumns.BG_COLOR_ID) : ResourceParser.getDefaultBgId(mContext); + if (mIsCreate || mBgColorId != bgColorId) { + mDiffNoteValues.put(NoteColumns.BG_COLOR_ID, bgColorId); + } + mBgColorId = bgColorId; + + long createDate = note.has(NoteColumns.CREATED_DATE) ? note + .getLong(NoteColumns.CREATED_DATE) : System.currentTimeMillis(); + if (mIsCreate || mCreatedDate != createDate) { + mDiffNoteValues.put(NoteColumns.CREATED_DATE, createDate); + } + mCreatedDate = createDate; + + int hasAttachment = note.has(NoteColumns.HAS_ATTACHMENT) ? note + .getInt(NoteColumns.HAS_ATTACHMENT) : 0; + if (mIsCreate || mHasAttachment != hasAttachment) { + mDiffNoteValues.put(NoteColumns.HAS_ATTACHMENT, hasAttachment); + } + mHasAttachment = hasAttachment; + + long modifiedDate = note.has(NoteColumns.MODIFIED_DATE) ? note + .getLong(NoteColumns.MODIFIED_DATE) : System.currentTimeMillis(); + if (mIsCreate || mModifiedDate != modifiedDate) { + mDiffNoteValues.put(NoteColumns.MODIFIED_DATE, modifiedDate); + } + mModifiedDate = modifiedDate; + + long parentId = note.has(NoteColumns.PARENT_ID) ? note + .getLong(NoteColumns.PARENT_ID) : 0; + if (mIsCreate || mParentId != parentId) { + mDiffNoteValues.put(NoteColumns.PARENT_ID, parentId); + } + mParentId = parentId; + + String snippet = note.has(NoteColumns.SNIPPET) ? note + .getString(NoteColumns.SNIPPET) : ""; + if (mIsCreate || !mSnippet.equals(snippet)) { + mDiffNoteValues.put(NoteColumns.SNIPPET, snippet); + } + mSnippet = snippet; + + int type = note.has(NoteColumns.TYPE) ? note.getInt(NoteColumns.TYPE) + : Notes.TYPE_NOTE; + if (mIsCreate || mType != type) { + mDiffNoteValues.put(NoteColumns.TYPE, type); + } + mType = type; + + int widgetId = note.has(NoteColumns.WIDGET_ID) ? note.getInt(NoteColumns.WIDGET_ID) + : AppWidgetManager.INVALID_APPWIDGET_ID; + if (mIsCreate || mWidgetId != widgetId) { + mDiffNoteValues.put(NoteColumns.WIDGET_ID, widgetId); + } + mWidgetId = widgetId; + + int widgetType = note.has(NoteColumns.WIDGET_TYPE) ? note + .getInt(NoteColumns.WIDGET_TYPE) : Notes.TYPE_WIDGET_INVALIDE; + if (mIsCreate || mWidgetType != widgetType) { + mDiffNoteValues.put(NoteColumns.WIDGET_TYPE, widgetType); + } + mWidgetType = widgetType; + + long originParent = note.has(NoteColumns.ORIGIN_PARENT_ID) ? note + .getLong(NoteColumns.ORIGIN_PARENT_ID) : 0; + if (mIsCreate || mOriginParent != originParent) { + mDiffNoteValues.put(NoteColumns.ORIGIN_PARENT_ID, originParent); + } + mOriginParent = originParent; + + for (int i = 0; i < dataArray.length(); i++) { + JSONObject data = dataArray.getJSONObject(i); + SqlData sqlData = null; + if (data.has(DataColumns.ID)) { + long dataId = data.getLong(DataColumns.ID); + for (SqlData temp : mDataList) { + if (dataId == temp.getId()) { + sqlData = temp; + } + } + } + + if (sqlData == null) { + sqlData = new SqlData(mContext); + mDataList.add(sqlData); + } + + sqlData.setContent(data); + } + } + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + return false; + } + return true; + } + + public JSONObject getContent() { + try { + JSONObject js = new JSONObject(); + + if (mIsCreate) { + Log.e(TAG, "it seems that we haven't created this in database yet"); + return null; + } + + JSONObject note = new JSONObject(); + if (mType == Notes.TYPE_NOTE) { + note.put(NoteColumns.ID, mId); + note.put(NoteColumns.ALERTED_DATE, mAlertDate); + note.put(NoteColumns.BG_COLOR_ID, mBgColorId); + note.put(NoteColumns.CREATED_DATE, mCreatedDate); + note.put(NoteColumns.HAS_ATTACHMENT, mHasAttachment); + note.put(NoteColumns.MODIFIED_DATE, mModifiedDate); + note.put(NoteColumns.PARENT_ID, mParentId); + note.put(NoteColumns.SNIPPET, mSnippet); + note.put(NoteColumns.TYPE, mType); + note.put(NoteColumns.WIDGET_ID, mWidgetId); + note.put(NoteColumns.WIDGET_TYPE, mWidgetType); + note.put(NoteColumns.ORIGIN_PARENT_ID, mOriginParent); + js.put(GTaskStringUtils.META_HEAD_NOTE, note); + + JSONArray dataArray = new JSONArray(); + for (SqlData sqlData : mDataList) { + JSONObject data = sqlData.getContent(); + if (data != null) { + dataArray.put(data); + } + } + js.put(GTaskStringUtils.META_HEAD_DATA, dataArray); + } else if (mType == Notes.TYPE_FOLDER || mType == Notes.TYPE_SYSTEM) { + note.put(NoteColumns.ID, mId); + note.put(NoteColumns.TYPE, mType); + note.put(NoteColumns.SNIPPET, mSnippet); + js.put(GTaskStringUtils.META_HEAD_NOTE, note); + } + + return js; + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + } + return null; + } + + public void setParentId(long id) { + mParentId = id; + mDiffNoteValues.put(NoteColumns.PARENT_ID, id); + } + + public void setGtaskId(String gid) { + mDiffNoteValues.put(NoteColumns.GTASK_ID, gid); + } + + public void setSyncId(long syncId) { + mDiffNoteValues.put(NoteColumns.SYNC_ID, syncId); + } + + public void resetLocalModified() { + mDiffNoteValues.put(NoteColumns.LOCAL_MODIFIED, 0); + } + + public long getId() { + return mId; + } + + public long getParentId() { + return mParentId; + } + + public String getSnippet() { + return mSnippet; + } + + public boolean isNoteType() { + return mType == Notes.TYPE_NOTE; + } + + public void commit(boolean validateVersion) { + if (mIsCreate) { + if (mId == INVALID_ID && mDiffNoteValues.containsKey(NoteColumns.ID)) { + mDiffNoteValues.remove(NoteColumns.ID); + } + + Uri uri = mContentResolver.insert(Notes.CONTENT_NOTE_URI, mDiffNoteValues); + try { + mId = Long.valueOf(uri.getPathSegments().get(1)); + } catch (NumberFormatException e) { + Log.e(TAG, "Get note id error :" + e.toString()); + throw new ActionFailureException("create note failed"); + } + if (mId == 0) { + throw new IllegalStateException("Create thread id failed"); + } + + if (mType == Notes.TYPE_NOTE) { + for (SqlData sqlData : mDataList) { + sqlData.commit(mId, false, -1); + } + } + } else { + if (mId <= 0 && mId != Notes.ID_ROOT_FOLDER && mId != Notes.ID_CALL_RECORD_FOLDER) { + Log.e(TAG, "No such note"); + throw new IllegalStateException("Try to update note with invalid id"); + } + if (mDiffNoteValues.size() > 0) { + mVersion ++; + int result = 0; + if (!validateVersion) { + result = mContentResolver.update(Notes.CONTENT_NOTE_URI, mDiffNoteValues, "(" + + NoteColumns.ID + "=?)", new String[] { + String.valueOf(mId) + }); + } else { + result = mContentResolver.update(Notes.CONTENT_NOTE_URI, mDiffNoteValues, "(" + + NoteColumns.ID + "=?) AND (" + NoteColumns.VERSION + "<=?)", + new String[] { + String.valueOf(mId), String.valueOf(mVersion) + }); + } + if (result == 0) { + Log.w(TAG, "there is no update. maybe user updates note when syncing"); + } + } + + if (mType == Notes.TYPE_NOTE) { + for (SqlData sqlData : mDataList) { + sqlData.commit(mId, validateVersion, mVersion); + } + } + } + + // refresh local info + loadFromCursor(mId); + if (mType == Notes.TYPE_NOTE) + loadDataContent(); + + mDiffNoteValues.clear(); + mIsCreate = false; + } +} diff --git a/app/src/main/java/net/micode/notes/gtask/data/Task.java b/app/src/main/java/net/micode/notes/gtask/data/Task.java new file mode 100644 index 0000000..6a19454 --- /dev/null +++ b/app/src/main/java/net/micode/notes/gtask/data/Task.java @@ -0,0 +1,351 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.gtask.data; + +import android.database.Cursor; +import android.text.TextUtils; +import android.util.Log; + +import net.micode.notes.data.Notes; +import net.micode.notes.data.Notes.DataColumns; +import net.micode.notes.data.Notes.DataConstants; +import net.micode.notes.data.Notes.NoteColumns; +import net.micode.notes.gtask.exception.ActionFailureException; +import net.micode.notes.tool.GTaskStringUtils; + +import org.json.JSONArray; +import org.json.JSONException; +import org.json.JSONObject; + + +public class Task extends Node { + private static final String TAG = Task.class.getSimpleName(); + + private boolean mCompleted; + + private String mNotes; + + private JSONObject mMetaInfo; + + private Task mPriorSibling; + + private TaskList mParent; + + public Task() { + super(); + mCompleted = false; + mNotes = null; + mPriorSibling = null; + mParent = null; + mMetaInfo = null; + } + + public JSONObject getCreateAction(int actionId) { + JSONObject js = new JSONObject(); + + try { + // action_type + js.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE, + GTaskStringUtils.GTASK_JSON_ACTION_TYPE_CREATE); + + // action_id + js.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, actionId); + + // index + js.put(GTaskStringUtils.GTASK_JSON_INDEX, mParent.getChildTaskIndex(this)); + + // entity_delta + JSONObject entity = new JSONObject(); + entity.put(GTaskStringUtils.GTASK_JSON_NAME, getName()); + entity.put(GTaskStringUtils.GTASK_JSON_CREATOR_ID, "null"); + entity.put(GTaskStringUtils.GTASK_JSON_ENTITY_TYPE, + GTaskStringUtils.GTASK_JSON_TYPE_TASK); + if (getNotes() != null) { + entity.put(GTaskStringUtils.GTASK_JSON_NOTES, getNotes()); + } + js.put(GTaskStringUtils.GTASK_JSON_ENTITY_DELTA, entity); + + // parent_id + js.put(GTaskStringUtils.GTASK_JSON_PARENT_ID, mParent.getGid()); + + // dest_parent_type + js.put(GTaskStringUtils.GTASK_JSON_DEST_PARENT_TYPE, + GTaskStringUtils.GTASK_JSON_TYPE_GROUP); + + // list_id + js.put(GTaskStringUtils.GTASK_JSON_LIST_ID, mParent.getGid()); + + // prior_sibling_id + if (mPriorSibling != null) { + js.put(GTaskStringUtils.GTASK_JSON_PRIOR_SIBLING_ID, mPriorSibling.getGid()); + } + + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + throw new ActionFailureException("fail to generate task-create jsonobject"); + } + + return js; + } + + public JSONObject getUpdateAction(int actionId) { + JSONObject js = new JSONObject(); + + try { + // action_type + js.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE, + GTaskStringUtils.GTASK_JSON_ACTION_TYPE_UPDATE); + + // action_id + js.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, actionId); + + // id + js.put(GTaskStringUtils.GTASK_JSON_ID, getGid()); + + // entity_delta + JSONObject entity = new JSONObject(); + entity.put(GTaskStringUtils.GTASK_JSON_NAME, getName()); + if (getNotes() != null) { + entity.put(GTaskStringUtils.GTASK_JSON_NOTES, getNotes()); + } + entity.put(GTaskStringUtils.GTASK_JSON_DELETED, getDeleted()); + js.put(GTaskStringUtils.GTASK_JSON_ENTITY_DELTA, entity); + + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + throw new ActionFailureException("fail to generate task-update jsonobject"); + } + + return js; + } + + public void setContentByRemoteJSON(JSONObject js) { + if (js != null) { + try { + // id + if (js.has(GTaskStringUtils.GTASK_JSON_ID)) { + setGid(js.getString(GTaskStringUtils.GTASK_JSON_ID)); + } + + // last_modified + if (js.has(GTaskStringUtils.GTASK_JSON_LAST_MODIFIED)) { + setLastModified(js.getLong(GTaskStringUtils.GTASK_JSON_LAST_MODIFIED)); + } + + // name + if (js.has(GTaskStringUtils.GTASK_JSON_NAME)) { + setName(js.getString(GTaskStringUtils.GTASK_JSON_NAME)); + } + + // notes + if (js.has(GTaskStringUtils.GTASK_JSON_NOTES)) { + setNotes(js.getString(GTaskStringUtils.GTASK_JSON_NOTES)); + } + + // deleted + if (js.has(GTaskStringUtils.GTASK_JSON_DELETED)) { + setDeleted(js.getBoolean(GTaskStringUtils.GTASK_JSON_DELETED)); + } + + // completed + if (js.has(GTaskStringUtils.GTASK_JSON_COMPLETED)) { + setCompleted(js.getBoolean(GTaskStringUtils.GTASK_JSON_COMPLETED)); + } + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + throw new ActionFailureException("fail to get task content from jsonobject"); + } + } + } + + public void setContentByLocalJSON(JSONObject js) { + if (js == null || !js.has(GTaskStringUtils.META_HEAD_NOTE) + || !js.has(GTaskStringUtils.META_HEAD_DATA)) { + Log.w(TAG, "setContentByLocalJSON: nothing is avaiable"); + } + + try { + JSONObject note = js.getJSONObject(GTaskStringUtils.META_HEAD_NOTE); + JSONArray dataArray = js.getJSONArray(GTaskStringUtils.META_HEAD_DATA); + + if (note.getInt(NoteColumns.TYPE) != Notes.TYPE_NOTE) { + Log.e(TAG, "invalid type"); + return; + } + + for (int i = 0; i < dataArray.length(); i++) { + JSONObject data = dataArray.getJSONObject(i); + if (TextUtils.equals(data.getString(DataColumns.MIME_TYPE), DataConstants.NOTE)) { + setName(data.getString(DataColumns.CONTENT)); + break; + } + } + + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + } + } + + public JSONObject getLocalJSONFromContent() { + String name = getName(); + try { + if (mMetaInfo == null) { + // new task created from web + if (name == null) { + Log.w(TAG, "the note seems to be an empty one"); + return null; + } + + JSONObject js = new JSONObject(); + JSONObject note = new JSONObject(); + JSONArray dataArray = new JSONArray(); + JSONObject data = new JSONObject(); + data.put(DataColumns.CONTENT, name); + dataArray.put(data); + js.put(GTaskStringUtils.META_HEAD_DATA, dataArray); + note.put(NoteColumns.TYPE, Notes.TYPE_NOTE); + js.put(GTaskStringUtils.META_HEAD_NOTE, note); + return js; + } else { + // synced task + JSONObject note = mMetaInfo.getJSONObject(GTaskStringUtils.META_HEAD_NOTE); + JSONArray dataArray = mMetaInfo.getJSONArray(GTaskStringUtils.META_HEAD_DATA); + + for (int i = 0; i < dataArray.length(); i++) { + JSONObject data = dataArray.getJSONObject(i); + if (TextUtils.equals(data.getString(DataColumns.MIME_TYPE), DataConstants.NOTE)) { + data.put(DataColumns.CONTENT, getName()); + break; + } + } + + note.put(NoteColumns.TYPE, Notes.TYPE_NOTE); + return mMetaInfo; + } + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + return null; + } + } + + public void setMetaInfo(MetaData metaData) { + if (metaData != null && metaData.getNotes() != null) { + try { + mMetaInfo = new JSONObject(metaData.getNotes()); + } catch (JSONException e) { + Log.w(TAG, e.toString()); + mMetaInfo = null; + } + } + } + + public int getSyncAction(Cursor c) { + try { + JSONObject noteInfo = null; + if (mMetaInfo != null && mMetaInfo.has(GTaskStringUtils.META_HEAD_NOTE)) { + noteInfo = mMetaInfo.getJSONObject(GTaskStringUtils.META_HEAD_NOTE); + } + + if (noteInfo == null) { + Log.w(TAG, "it seems that note meta has been deleted"); + return SYNC_ACTION_UPDATE_REMOTE; + } + + if (!noteInfo.has(NoteColumns.ID)) { + Log.w(TAG, "remote note id seems to be deleted"); + return SYNC_ACTION_UPDATE_LOCAL; + } + + // validate the note id now + if (c.getLong(SqlNote.ID_COLUMN) != noteInfo.getLong(NoteColumns.ID)) { + Log.w(TAG, "note id doesn't match"); + return SYNC_ACTION_UPDATE_LOCAL; + } + + if (c.getInt(SqlNote.LOCAL_MODIFIED_COLUMN) == 0) { + // there is no local update + if (c.getLong(SqlNote.SYNC_ID_COLUMN) == getLastModified()) { + // no update both side + return SYNC_ACTION_NONE; + } else { + // apply remote to local + return SYNC_ACTION_UPDATE_LOCAL; + } + } else { + // validate gtask id + if (!c.getString(SqlNote.GTASK_ID_COLUMN).equals(getGid())) { + Log.e(TAG, "gtask id doesn't match"); + return SYNC_ACTION_ERROR; + } + if (c.getLong(SqlNote.SYNC_ID_COLUMN) == getLastModified()) { + // local modification only + return SYNC_ACTION_UPDATE_REMOTE; + } else { + return SYNC_ACTION_UPDATE_CONFLICT; + } + } + } catch (Exception e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + } + + return SYNC_ACTION_ERROR; + } + + public boolean isWorthSaving() { + return mMetaInfo != null || (getName() != null && getName().trim().length() > 0) + || (getNotes() != null && getNotes().trim().length() > 0); + } + + public void setCompleted(boolean completed) { + this.mCompleted = completed; + } + + public void setNotes(String notes) { + this.mNotes = notes; + } + + public void setPriorSibling(Task priorSibling) { + this.mPriorSibling = priorSibling; + } + + public void setParent(TaskList parent) { + this.mParent = parent; + } + + public boolean getCompleted() { + return this.mCompleted; + } + + public String getNotes() { + return this.mNotes; + } + + public Task getPriorSibling() { + return this.mPriorSibling; + } + + public TaskList getParent() { + return this.mParent; + } + +} diff --git a/app/src/main/java/net/micode/notes/gtask/data/TaskList.java b/app/src/main/java/net/micode/notes/gtask/data/TaskList.java new file mode 100644 index 0000000..4ea21c5 --- /dev/null +++ b/app/src/main/java/net/micode/notes/gtask/data/TaskList.java @@ -0,0 +1,343 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.gtask.data; + +import android.database.Cursor; +import android.util.Log; + +import net.micode.notes.data.Notes; +import net.micode.notes.data.Notes.NoteColumns; +import net.micode.notes.gtask.exception.ActionFailureException; +import net.micode.notes.tool.GTaskStringUtils; + +import org.json.JSONException; +import org.json.JSONObject; + +import java.util.ArrayList; + + +public class TaskList extends Node { + private static final String TAG = TaskList.class.getSimpleName(); + + private int mIndex; + + private ArrayList mChildren; + + public TaskList() { + super(); + mChildren = new ArrayList(); + mIndex = 1; + } + + public JSONObject getCreateAction(int actionId) { + JSONObject js = new JSONObject(); + + try { + // action_type + js.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE, + GTaskStringUtils.GTASK_JSON_ACTION_TYPE_CREATE); + + // action_id + js.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, actionId); + + // index + js.put(GTaskStringUtils.GTASK_JSON_INDEX, mIndex); + + // entity_delta + JSONObject entity = new JSONObject(); + entity.put(GTaskStringUtils.GTASK_JSON_NAME, getName()); + entity.put(GTaskStringUtils.GTASK_JSON_CREATOR_ID, "null"); + entity.put(GTaskStringUtils.GTASK_JSON_ENTITY_TYPE, + GTaskStringUtils.GTASK_JSON_TYPE_GROUP); + js.put(GTaskStringUtils.GTASK_JSON_ENTITY_DELTA, entity); + + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + throw new ActionFailureException("fail to generate tasklist-create jsonobject"); + } + + return js; + } + + public JSONObject getUpdateAction(int actionId) { + JSONObject js = new JSONObject(); + + try { + // action_type + js.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE, + GTaskStringUtils.GTASK_JSON_ACTION_TYPE_UPDATE); + + // action_id + js.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, actionId); + + // id + js.put(GTaskStringUtils.GTASK_JSON_ID, getGid()); + + // entity_delta + JSONObject entity = new JSONObject(); + entity.put(GTaskStringUtils.GTASK_JSON_NAME, getName()); + entity.put(GTaskStringUtils.GTASK_JSON_DELETED, getDeleted()); + js.put(GTaskStringUtils.GTASK_JSON_ENTITY_DELTA, entity); + + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + throw new ActionFailureException("fail to generate tasklist-update jsonobject"); + } + + return js; + } + + public void setContentByRemoteJSON(JSONObject js) { + if (js != null) { + try { + // id + if (js.has(GTaskStringUtils.GTASK_JSON_ID)) { + setGid(js.getString(GTaskStringUtils.GTASK_JSON_ID)); + } + + // last_modified + if (js.has(GTaskStringUtils.GTASK_JSON_LAST_MODIFIED)) { + setLastModified(js.getLong(GTaskStringUtils.GTASK_JSON_LAST_MODIFIED)); + } + + // name + if (js.has(GTaskStringUtils.GTASK_JSON_NAME)) { + setName(js.getString(GTaskStringUtils.GTASK_JSON_NAME)); + } + + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + throw new ActionFailureException("fail to get tasklist content from jsonobject"); + } + } + } + + public void setContentByLocalJSON(JSONObject js) { + if (js == null || !js.has(GTaskStringUtils.META_HEAD_NOTE)) { + Log.w(TAG, "setContentByLocalJSON: nothing is avaiable"); + } + + try { + JSONObject folder = js.getJSONObject(GTaskStringUtils.META_HEAD_NOTE); + + if (folder.getInt(NoteColumns.TYPE) == Notes.TYPE_FOLDER) { + String name = folder.getString(NoteColumns.SNIPPET); + setName(GTaskStringUtils.MIUI_FOLDER_PREFFIX + name); + } else if (folder.getInt(NoteColumns.TYPE) == Notes.TYPE_SYSTEM) { + if (folder.getLong(NoteColumns.ID) == Notes.ID_ROOT_FOLDER) + setName(GTaskStringUtils.MIUI_FOLDER_PREFFIX + GTaskStringUtils.FOLDER_DEFAULT); + else if (folder.getLong(NoteColumns.ID) == Notes.ID_CALL_RECORD_FOLDER) + setName(GTaskStringUtils.MIUI_FOLDER_PREFFIX + + GTaskStringUtils.FOLDER_CALL_NOTE); + else + Log.e(TAG, "invalid system folder"); + } else { + Log.e(TAG, "error type"); + } + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + } + } + + public JSONObject getLocalJSONFromContent() { + try { + JSONObject js = new JSONObject(); + JSONObject folder = new JSONObject(); + + String folderName = getName(); + if (getName().startsWith(GTaskStringUtils.MIUI_FOLDER_PREFFIX)) + folderName = folderName.substring(GTaskStringUtils.MIUI_FOLDER_PREFFIX.length(), + folderName.length()); + folder.put(NoteColumns.SNIPPET, folderName); + if (folderName.equals(GTaskStringUtils.FOLDER_DEFAULT) + || folderName.equals(GTaskStringUtils.FOLDER_CALL_NOTE)) + folder.put(NoteColumns.TYPE, Notes.TYPE_SYSTEM); + else + folder.put(NoteColumns.TYPE, Notes.TYPE_FOLDER); + + js.put(GTaskStringUtils.META_HEAD_NOTE, folder); + + return js; + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + return null; + } + } + + public int getSyncAction(Cursor c) { + try { + if (c.getInt(SqlNote.LOCAL_MODIFIED_COLUMN) == 0) { + // there is no local update + if (c.getLong(SqlNote.SYNC_ID_COLUMN) == getLastModified()) { + // no update both side + return SYNC_ACTION_NONE; + } else { + // apply remote to local + return SYNC_ACTION_UPDATE_LOCAL; + } + } else { + // validate gtask id + if (!c.getString(SqlNote.GTASK_ID_COLUMN).equals(getGid())) { + Log.e(TAG, "gtask id doesn't match"); + return SYNC_ACTION_ERROR; + } + if (c.getLong(SqlNote.SYNC_ID_COLUMN) == getLastModified()) { + // local modification only + return SYNC_ACTION_UPDATE_REMOTE; + } else { + // for folder conflicts, just apply local modification + return SYNC_ACTION_UPDATE_REMOTE; + } + } + } catch (Exception e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + } + + return SYNC_ACTION_ERROR; + } + + public int getChildTaskCount() { + return mChildren.size(); + } + + public boolean addChildTask(Task task) { + boolean ret = false; + if (task != null && !mChildren.contains(task)) { + ret = mChildren.add(task); + if (ret) { + // need to set prior sibling and parent + task.setPriorSibling(mChildren.isEmpty() ? null : mChildren + .get(mChildren.size() - 1)); + task.setParent(this); + } + } + return ret; + } + + public boolean addChildTask(Task task, int index) { + if (index < 0 || index > mChildren.size()) { + Log.e(TAG, "add child task: invalid index"); + return false; + } + + int pos = mChildren.indexOf(task); + if (task != null && pos == -1) { + mChildren.add(index, task); + + // update the task list + Task preTask = null; + Task afterTask = null; + if (index != 0) + preTask = mChildren.get(index - 1); + if (index != mChildren.size() - 1) + afterTask = mChildren.get(index + 1); + + task.setPriorSibling(preTask); + if (afterTask != null) + afterTask.setPriorSibling(task); + } + + return true; + } + + public boolean removeChildTask(Task task) { + boolean ret = false; + int index = mChildren.indexOf(task); + if (index != -1) { + ret = mChildren.remove(task); + + if (ret) { + // reset prior sibling and parent + task.setPriorSibling(null); + task.setParent(null); + + // update the task list + if (index != mChildren.size()) { + mChildren.get(index).setPriorSibling( + index == 0 ? null : mChildren.get(index - 1)); + } + } + } + return ret; + } + + public boolean moveChildTask(Task task, int index) { + + if (index < 0 || index >= mChildren.size()) { + Log.e(TAG, "move child task: invalid index"); + return false; + } + + int pos = mChildren.indexOf(task); + if (pos == -1) { + Log.e(TAG, "move child task: the task should in the list"); + return false; + } + + if (pos == index) + return true; + return (removeChildTask(task) && addChildTask(task, index)); + } + + public Task findChildTaskByGid(String gid) { + for (int i = 0; i < mChildren.size(); i++) { + Task t = mChildren.get(i); + if (t.getGid().equals(gid)) { + return t; + } + } + return null; + } + + public int getChildTaskIndex(Task task) { + return mChildren.indexOf(task); + } + + public Task getChildTaskByIndex(int index) { + if (index < 0 || index >= mChildren.size()) { + Log.e(TAG, "getTaskByIndex: invalid index"); + return null; + } + return mChildren.get(index); + } + + public Task getChilTaskByGid(String gid) { + for (Task task : mChildren) { + if (task.getGid().equals(gid)) + return task; + } + return null; + } + + public ArrayList getChildTaskList() { + return this.mChildren; + } + + public void setIndex(int index) { + this.mIndex = index; + } + + public int getIndex() { + return this.mIndex; + } +} diff --git a/app/src/main/java/net/micode/notes/gtask/exception/ActionFailureException.java b/app/src/main/java/net/micode/notes/gtask/exception/ActionFailureException.java new file mode 100644 index 0000000..15504be --- /dev/null +++ b/app/src/main/java/net/micode/notes/gtask/exception/ActionFailureException.java @@ -0,0 +1,33 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.gtask.exception; + +public class ActionFailureException extends RuntimeException { + private static final long serialVersionUID = 4425249765923293627L; + + public ActionFailureException() { + super(); + } + + public ActionFailureException(String paramString) { + super(paramString); + } + + public ActionFailureException(String paramString, Throwable paramThrowable) { + super(paramString, paramThrowable); + } +} diff --git a/app/src/main/java/net/micode/notes/gtask/exception/NetworkFailureException.java b/app/src/main/java/net/micode/notes/gtask/exception/NetworkFailureException.java new file mode 100644 index 0000000..b08cfb1 --- /dev/null +++ b/app/src/main/java/net/micode/notes/gtask/exception/NetworkFailureException.java @@ -0,0 +1,33 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.gtask.exception; + +public class NetworkFailureException extends Exception { + private static final long serialVersionUID = 2107610287180234136L; + + public NetworkFailureException() { + super(); + } + + public NetworkFailureException(String paramString) { + super(paramString); + } + + public NetworkFailureException(String paramString, Throwable paramThrowable) { + super(paramString, paramThrowable); + } +} diff --git a/app/src/main/java/net/micode/notes/gtask/remote/GTaskASyncTask.java b/app/src/main/java/net/micode/notes/gtask/remote/GTaskASyncTask.java new file mode 100644 index 0000000..b3b61e7 --- /dev/null +++ b/app/src/main/java/net/micode/notes/gtask/remote/GTaskASyncTask.java @@ -0,0 +1,123 @@ + +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.gtask.remote; + +import android.app.Notification; +import android.app.NotificationManager; +import android.app.PendingIntent; +import android.content.Context; +import android.content.Intent; +import android.os.AsyncTask; + +import net.micode.notes.R; +import net.micode.notes.ui.NotesListActivity; +import net.micode.notes.ui.NotesPreferenceActivity; + + +public class GTaskASyncTask extends AsyncTask { + + private static int GTASK_SYNC_NOTIFICATION_ID = 5234235; + + public interface OnCompleteListener { + void onComplete(); + } + + private Context mContext; + + private NotificationManager mNotifiManager; + + private GTaskManager mTaskManager; + + private OnCompleteListener mOnCompleteListener; + + public GTaskASyncTask(Context context, OnCompleteListener listener) { + mContext = context; + mOnCompleteListener = listener; + mNotifiManager = (NotificationManager) mContext + .getSystemService(Context.NOTIFICATION_SERVICE); + mTaskManager = GTaskManager.getInstance(); + } + + public void cancelSync() { + mTaskManager.cancelSync(); + } + + public void publishProgess(String message) { + publishProgress(new String[] { + message + }); + } + + private void showNotification(int tickerId, String content) { + Notification notification = new Notification(R.drawable.notification, mContext + .getString(tickerId), System.currentTimeMillis()); + notification.defaults = Notification.DEFAULT_LIGHTS; + notification.flags = Notification.FLAG_AUTO_CANCEL; + PendingIntent pendingIntent; + if (tickerId != R.string.ticker_success) { + pendingIntent = PendingIntent.getActivity(mContext, 0, new Intent(mContext, + NotesPreferenceActivity.class), 0); + + } else { + pendingIntent = PendingIntent.getActivity(mContext, 0, new Intent(mContext, + NotesListActivity.class), 0); + } + notification.setLatestEventInfo(mContext, mContext.getString(R.string.app_name), content, + pendingIntent); + mNotifiManager.notify(GTASK_SYNC_NOTIFICATION_ID, notification); + } + + @Override + protected Integer doInBackground(Void... unused) { + publishProgess(mContext.getString(R.string.sync_progress_login, NotesPreferenceActivity + .getSyncAccountName(mContext))); + return mTaskManager.sync(mContext, this); + } + + @Override + protected void onProgressUpdate(String... progress) { + showNotification(R.string.ticker_syncing, progress[0]); + if (mContext instanceof GTaskSyncService) { + ((GTaskSyncService) mContext).sendBroadcast(progress[0]); + } + } + + @Override + protected void onPostExecute(Integer result) { + if (result == GTaskManager.STATE_SUCCESS) { + showNotification(R.string.ticker_success, mContext.getString( + R.string.success_sync_account, mTaskManager.getSyncAccount())); + NotesPreferenceActivity.setLastSyncTime(mContext, System.currentTimeMillis()); + } else if (result == GTaskManager.STATE_NETWORK_ERROR) { + showNotification(R.string.ticker_fail, mContext.getString(R.string.error_sync_network)); + } else if (result == GTaskManager.STATE_INTERNAL_ERROR) { + showNotification(R.string.ticker_fail, mContext.getString(R.string.error_sync_internal)); + } else if (result == GTaskManager.STATE_SYNC_CANCELLED) { + showNotification(R.string.ticker_cancel, mContext + .getString(R.string.error_sync_cancelled)); + } + if (mOnCompleteListener != null) { + new Thread(new Runnable() { + + public void run() { + mOnCompleteListener.onComplete(); + } + }).start(); + } + } +} diff --git a/app/src/main/java/net/micode/notes/gtask/remote/GTaskClient.java b/app/src/main/java/net/micode/notes/gtask/remote/GTaskClient.java new file mode 100644 index 0000000..c67dfdf --- /dev/null +++ b/app/src/main/java/net/micode/notes/gtask/remote/GTaskClient.java @@ -0,0 +1,585 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.gtask.remote; + +import android.accounts.Account; +import android.accounts.AccountManager; +import android.accounts.AccountManagerFuture; +import android.app.Activity; +import android.os.Bundle; +import android.text.TextUtils; +import android.util.Log; + +import net.micode.notes.gtask.data.Node; +import net.micode.notes.gtask.data.Task; +import net.micode.notes.gtask.data.TaskList; +import net.micode.notes.gtask.exception.ActionFailureException; +import net.micode.notes.gtask.exception.NetworkFailureException; +import net.micode.notes.tool.GTaskStringUtils; +import net.micode.notes.ui.NotesPreferenceActivity; + +import org.apache.http.HttpEntity; +import org.apache.http.HttpResponse; +import org.apache.http.client.ClientProtocolException; +import org.apache.http.client.entity.UrlEncodedFormEntity; +import org.apache.http.client.methods.HttpGet; +import org.apache.http.client.methods.HttpPost; +import org.apache.http.cookie.Cookie; +import org.apache.http.impl.client.BasicCookieStore; +import org.apache.http.impl.client.DefaultHttpClient; +import org.apache.http.message.BasicNameValuePair; +import org.apache.http.params.BasicHttpParams; +import org.apache.http.params.HttpConnectionParams; +import org.apache.http.params.HttpParams; +import org.apache.http.params.HttpProtocolParams; +import org.json.JSONArray; +import org.json.JSONException; +import org.json.JSONObject; + +import java.io.BufferedReader; +import java.io.IOException; +import java.io.InputStream; +import java.io.InputStreamReader; +import java.util.LinkedList; +import java.util.List; +import java.util.zip.GZIPInputStream; +import java.util.zip.Inflater; +import java.util.zip.InflaterInputStream; + + +public class GTaskClient { + private static final String TAG = GTaskClient.class.getSimpleName(); + + private static final String GTASK_URL = "https://mail.google.com/tasks/"; + + private static final String GTASK_GET_URL = "https://mail.google.com/tasks/ig"; + + private static final String GTASK_POST_URL = "https://mail.google.com/tasks/r/ig"; + + private static GTaskClient mInstance = null; + + private DefaultHttpClient mHttpClient; + + private String mGetUrl; + + private String mPostUrl; + + private long mClientVersion; + + private boolean mLoggedin; + + private long mLastLoginTime; + + private int mActionId; + + private Account mAccount; + + private JSONArray mUpdateArray; + + private GTaskClient() { + mHttpClient = null; + mGetUrl = GTASK_GET_URL; + mPostUrl = GTASK_POST_URL; + mClientVersion = -1; + mLoggedin = false; + mLastLoginTime = 0; + mActionId = 1; + mAccount = null; + mUpdateArray = null; + } + + public static synchronized GTaskClient getInstance() { + if (mInstance == null) { + mInstance = new GTaskClient(); + } + return mInstance; + } + + public boolean login(Activity activity) { + // we suppose that the cookie would expire after 5 minutes + // then we need to re-login + final long interval = 1000 * 60 * 5; + if (mLastLoginTime + interval < System.currentTimeMillis()) { + mLoggedin = false; + } + + // need to re-login after account switch + if (mLoggedin + && !TextUtils.equals(getSyncAccount().name, NotesPreferenceActivity + .getSyncAccountName(activity))) { + mLoggedin = false; + } + + if (mLoggedin) { + Log.d(TAG, "already logged in"); + return true; + } + + mLastLoginTime = System.currentTimeMillis(); + String authToken = loginGoogleAccount(activity, false); + if (authToken == null) { + Log.e(TAG, "login google account failed"); + return false; + } + + // login with custom domain if necessary + if (!(mAccount.name.toLowerCase().endsWith("gmail.com") || mAccount.name.toLowerCase() + .endsWith("googlemail.com"))) { + StringBuilder url = new StringBuilder(GTASK_URL).append("a/"); + int index = mAccount.name.indexOf('@') + 1; + String suffix = mAccount.name.substring(index); + url.append(suffix + "/"); + mGetUrl = url.toString() + "ig"; + mPostUrl = url.toString() + "r/ig"; + + if (tryToLoginGtask(activity, authToken)) { + mLoggedin = true; + } + } + + // try to login with google official url + if (!mLoggedin) { + mGetUrl = GTASK_GET_URL; + mPostUrl = GTASK_POST_URL; + if (!tryToLoginGtask(activity, authToken)) { + return false; + } + } + + mLoggedin = true; + return true; + } + + private String loginGoogleAccount(Activity activity, boolean invalidateToken) { + String authToken; + AccountManager accountManager = AccountManager.get(activity); + Account[] accounts = accountManager.getAccountsByType("com.google"); + + if (accounts.length == 0) { + Log.e(TAG, "there is no available google account"); + return null; + } + + String accountName = NotesPreferenceActivity.getSyncAccountName(activity); + Account account = null; + for (Account a : accounts) { + if (a.name.equals(accountName)) { + account = a; + break; + } + } + if (account != null) { + mAccount = account; + } else { + Log.e(TAG, "unable to get an account with the same name in the settings"); + return null; + } + + // get the token now + AccountManagerFuture accountManagerFuture = accountManager.getAuthToken(account, + "goanna_mobile", null, activity, null, null); + try { + Bundle authTokenBundle = accountManagerFuture.getResult(); + authToken = authTokenBundle.getString(AccountManager.KEY_AUTHTOKEN); + if (invalidateToken) { + accountManager.invalidateAuthToken("com.google", authToken); + loginGoogleAccount(activity, false); + } + } catch (Exception e) { + Log.e(TAG, "get auth token failed"); + authToken = null; + } + + return authToken; + } + + private boolean tryToLoginGtask(Activity activity, String authToken) { + if (!loginGtask(authToken)) { + // maybe the auth token is out of date, now let's invalidate the + // token and try again + authToken = loginGoogleAccount(activity, true); + if (authToken == null) { + Log.e(TAG, "login google account failed"); + return false; + } + + if (!loginGtask(authToken)) { + Log.e(TAG, "login gtask failed"); + return false; + } + } + return true; + } + + private boolean loginGtask(String authToken) { + int timeoutConnection = 10000; + int timeoutSocket = 15000; + HttpParams httpParameters = new BasicHttpParams(); + HttpConnectionParams.setConnectionTimeout(httpParameters, timeoutConnection); + HttpConnectionParams.setSoTimeout(httpParameters, timeoutSocket); + mHttpClient = new DefaultHttpClient(httpParameters); + BasicCookieStore localBasicCookieStore = new BasicCookieStore(); + mHttpClient.setCookieStore(localBasicCookieStore); + HttpProtocolParams.setUseExpectContinue(mHttpClient.getParams(), false); + + // login gtask + try { + String loginUrl = mGetUrl + "?auth=" + authToken; + HttpGet httpGet = new HttpGet(loginUrl); + HttpResponse response = null; + response = mHttpClient.execute(httpGet); + + // get the cookie now + List cookies = mHttpClient.getCookieStore().getCookies(); + boolean hasAuthCookie = false; + for (Cookie cookie : cookies) { + if (cookie.getName().contains("GTL")) { + hasAuthCookie = true; + } + } + if (!hasAuthCookie) { + Log.w(TAG, "it seems that there is no auth cookie"); + } + + // get the client version + String resString = getResponseContent(response.getEntity()); + String jsBegin = "_setup("; + String jsEnd = ")}"; + int begin = resString.indexOf(jsBegin); + int end = resString.lastIndexOf(jsEnd); + String jsString = null; + if (begin != -1 && end != -1 && begin < end) { + jsString = resString.substring(begin + jsBegin.length(), end); + } + JSONObject js = new JSONObject(jsString); + mClientVersion = js.getLong("v"); + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + return false; + } catch (Exception e) { + // simply catch all exceptions + Log.e(TAG, "httpget gtask_url failed"); + return false; + } + + return true; + } + + private int getActionId() { + return mActionId++; + } + + private HttpPost createHttpPost() { + HttpPost httpPost = new HttpPost(mPostUrl); + httpPost.setHeader("Content-Type", "application/x-www-form-urlencoded;charset=utf-8"); + httpPost.setHeader("AT", "1"); + return httpPost; + } + + private String getResponseContent(HttpEntity entity) throws IOException { + String contentEncoding = null; + if (entity.getContentEncoding() != null) { + contentEncoding = entity.getContentEncoding().getValue(); + Log.d(TAG, "encoding: " + contentEncoding); + } + + InputStream input = entity.getContent(); + if (contentEncoding != null && contentEncoding.equalsIgnoreCase("gzip")) { + input = new GZIPInputStream(entity.getContent()); + } else if (contentEncoding != null && contentEncoding.equalsIgnoreCase("deflate")) { + Inflater inflater = new Inflater(true); + input = new InflaterInputStream(entity.getContent(), inflater); + } + + try { + InputStreamReader isr = new InputStreamReader(input); + BufferedReader br = new BufferedReader(isr); + StringBuilder sb = new StringBuilder(); + + while (true) { + String buff = br.readLine(); + if (buff == null) { + return sb.toString(); + } + sb = sb.append(buff); + } + } finally { + input.close(); + } + } + + private JSONObject postRequest(JSONObject js) throws NetworkFailureException { + if (!mLoggedin) { + Log.e(TAG, "please login first"); + throw new ActionFailureException("not logged in"); + } + + HttpPost httpPost = createHttpPost(); + try { + LinkedList list = new LinkedList(); + list.add(new BasicNameValuePair("r", js.toString())); + UrlEncodedFormEntity entity = new UrlEncodedFormEntity(list, "UTF-8"); + httpPost.setEntity(entity); + + // execute the post + HttpResponse response = mHttpClient.execute(httpPost); + String jsString = getResponseContent(response.getEntity()); + return new JSONObject(jsString); + + } catch (ClientProtocolException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + throw new NetworkFailureException("postRequest failed"); + } catch (IOException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + throw new NetworkFailureException("postRequest failed"); + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + throw new ActionFailureException("unable to convert response content to jsonobject"); + } catch (Exception e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + throw new ActionFailureException("error occurs when posting request"); + } + } + + public void createTask(Task task) throws NetworkFailureException { + commitUpdate(); + try { + JSONObject jsPost = new JSONObject(); + JSONArray actionList = new JSONArray(); + + // action_list + actionList.put(task.getCreateAction(getActionId())); + jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList); + + // client_version + jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion); + + // post + JSONObject jsResponse = postRequest(jsPost); + JSONObject jsResult = (JSONObject) jsResponse.getJSONArray( + GTaskStringUtils.GTASK_JSON_RESULTS).get(0); + task.setGid(jsResult.getString(GTaskStringUtils.GTASK_JSON_NEW_ID)); + + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + throw new ActionFailureException("create task: handing jsonobject failed"); + } + } + + public void createTaskList(TaskList tasklist) throws NetworkFailureException { + commitUpdate(); + try { + JSONObject jsPost = new JSONObject(); + JSONArray actionList = new JSONArray(); + + // action_list + actionList.put(tasklist.getCreateAction(getActionId())); + jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList); + + // client version + jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion); + + // post + JSONObject jsResponse = postRequest(jsPost); + JSONObject jsResult = (JSONObject) jsResponse.getJSONArray( + GTaskStringUtils.GTASK_JSON_RESULTS).get(0); + tasklist.setGid(jsResult.getString(GTaskStringUtils.GTASK_JSON_NEW_ID)); + + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + throw new ActionFailureException("create tasklist: handing jsonobject failed"); + } + } + + public void commitUpdate() throws NetworkFailureException { + if (mUpdateArray != null) { + try { + JSONObject jsPost = new JSONObject(); + + // action_list + jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, mUpdateArray); + + // client_version + jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion); + + postRequest(jsPost); + mUpdateArray = null; + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + throw new ActionFailureException("commit update: handing jsonobject failed"); + } + } + } + + public void addUpdateNode(Node node) throws NetworkFailureException { + if (node != null) { + // too many update items may result in an error + // set max to 10 items + if (mUpdateArray != null && mUpdateArray.length() > 10) { + commitUpdate(); + } + + if (mUpdateArray == null) + mUpdateArray = new JSONArray(); + mUpdateArray.put(node.getUpdateAction(getActionId())); + } + } + + public void moveTask(Task task, TaskList preParent, TaskList curParent) + throws NetworkFailureException { + commitUpdate(); + try { + JSONObject jsPost = new JSONObject(); + JSONArray actionList = new JSONArray(); + JSONObject action = new JSONObject(); + + // action_list + action.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE, + GTaskStringUtils.GTASK_JSON_ACTION_TYPE_MOVE); + action.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, getActionId()); + action.put(GTaskStringUtils.GTASK_JSON_ID, task.getGid()); + if (preParent == curParent && task.getPriorSibling() != null) { + // put prioring_sibing_id only if moving within the tasklist and + // it is not the first one + action.put(GTaskStringUtils.GTASK_JSON_PRIOR_SIBLING_ID, task.getPriorSibling()); + } + action.put(GTaskStringUtils.GTASK_JSON_SOURCE_LIST, preParent.getGid()); + action.put(GTaskStringUtils.GTASK_JSON_DEST_PARENT, curParent.getGid()); + if (preParent != curParent) { + // put the dest_list only if moving between tasklists + action.put(GTaskStringUtils.GTASK_JSON_DEST_LIST, curParent.getGid()); + } + actionList.put(action); + jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList); + + // client_version + jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion); + + postRequest(jsPost); + + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + throw new ActionFailureException("move task: handing jsonobject failed"); + } + } + + public void deleteNode(Node node) throws NetworkFailureException { + commitUpdate(); + try { + JSONObject jsPost = new JSONObject(); + JSONArray actionList = new JSONArray(); + + // action_list + node.setDeleted(true); + actionList.put(node.getUpdateAction(getActionId())); + jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList); + + // client_version + jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion); + + postRequest(jsPost); + mUpdateArray = null; + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + throw new ActionFailureException("delete node: handing jsonobject failed"); + } + } + + public JSONArray getTaskLists() throws NetworkFailureException { + if (!mLoggedin) { + Log.e(TAG, "please login first"); + throw new ActionFailureException("not logged in"); + } + + try { + HttpGet httpGet = new HttpGet(mGetUrl); + HttpResponse response = null; + response = mHttpClient.execute(httpGet); + + // get the task list + String resString = getResponseContent(response.getEntity()); + String jsBegin = "_setup("; + String jsEnd = ")}"; + int begin = resString.indexOf(jsBegin); + int end = resString.lastIndexOf(jsEnd); + String jsString = null; + if (begin != -1 && end != -1 && begin < end) { + jsString = resString.substring(begin + jsBegin.length(), end); + } + JSONObject js = new JSONObject(jsString); + return js.getJSONObject("t").getJSONArray(GTaskStringUtils.GTASK_JSON_LISTS); + } catch (ClientProtocolException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + throw new NetworkFailureException("gettasklists: httpget failed"); + } catch (IOException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + throw new NetworkFailureException("gettasklists: httpget failed"); + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + throw new ActionFailureException("get task lists: handing jasonobject failed"); + } + } + + public JSONArray getTaskList(String listGid) throws NetworkFailureException { + commitUpdate(); + try { + JSONObject jsPost = new JSONObject(); + JSONArray actionList = new JSONArray(); + JSONObject action = new JSONObject(); + + // action_list + action.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE, + GTaskStringUtils.GTASK_JSON_ACTION_TYPE_GETALL); + action.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, getActionId()); + action.put(GTaskStringUtils.GTASK_JSON_LIST_ID, listGid); + action.put(GTaskStringUtils.GTASK_JSON_GET_DELETED, false); + actionList.put(action); + jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList); + + // client_version + jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion); + + JSONObject jsResponse = postRequest(jsPost); + return jsResponse.getJSONArray(GTaskStringUtils.GTASK_JSON_TASKS); + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + throw new ActionFailureException("get task list: handing jsonobject failed"); + } + } + + public Account getSyncAccount() { + return mAccount; + } + + public void resetUpdateArray() { + mUpdateArray = null; + } +} diff --git a/app/src/main/java/net/micode/notes/gtask/remote/GTaskManager.java b/app/src/main/java/net/micode/notes/gtask/remote/GTaskManager.java new file mode 100644 index 0000000..d2b4082 --- /dev/null +++ b/app/src/main/java/net/micode/notes/gtask/remote/GTaskManager.java @@ -0,0 +1,800 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.gtask.remote; + +import android.app.Activity; +import android.content.ContentResolver; +import android.content.ContentUris; +import android.content.ContentValues; +import android.content.Context; +import android.database.Cursor; +import android.util.Log; + +import net.micode.notes.R; +import net.micode.notes.data.Notes; +import net.micode.notes.data.Notes.DataColumns; +import net.micode.notes.data.Notes.NoteColumns; +import net.micode.notes.gtask.data.MetaData; +import net.micode.notes.gtask.data.Node; +import net.micode.notes.gtask.data.SqlNote; +import net.micode.notes.gtask.data.Task; +import net.micode.notes.gtask.data.TaskList; +import net.micode.notes.gtask.exception.ActionFailureException; +import net.micode.notes.gtask.exception.NetworkFailureException; +import net.micode.notes.tool.DataUtils; +import net.micode.notes.tool.GTaskStringUtils; + +import org.json.JSONArray; +import org.json.JSONException; +import org.json.JSONObject; + +import java.util.HashMap; +import java.util.HashSet; +import java.util.Iterator; +import java.util.Map; + + +public class GTaskManager { + private static final String TAG = GTaskManager.class.getSimpleName(); + + public static final int STATE_SUCCESS = 0; + + public static final int STATE_NETWORK_ERROR = 1; + + public static final int STATE_INTERNAL_ERROR = 2; + + public static final int STATE_SYNC_IN_PROGRESS = 3; + + public static final int STATE_SYNC_CANCELLED = 4; + + private static GTaskManager mInstance = null; + + private Activity mActivity; + + private Context mContext; + + private ContentResolver mContentResolver; + + private boolean mSyncing; + + private boolean mCancelled; + + private HashMap mGTaskListHashMap; + + private HashMap mGTaskHashMap; + + private HashMap mMetaHashMap; + + private TaskList mMetaList; + + private HashSet mLocalDeleteIdMap; + + private HashMap mGidToNid; + + private HashMap mNidToGid; + + private GTaskManager() { + mSyncing = false; + mCancelled = false; + mGTaskListHashMap = new HashMap(); + mGTaskHashMap = new HashMap(); + mMetaHashMap = new HashMap(); + mMetaList = null; + mLocalDeleteIdMap = new HashSet(); + mGidToNid = new HashMap(); + mNidToGid = new HashMap(); + } + + public static synchronized GTaskManager getInstance() { + if (mInstance == null) { + mInstance = new GTaskManager(); + } + return mInstance; + } + + public synchronized void setActivityContext(Activity activity) { + // used for getting authtoken + mActivity = activity; + } + + public int sync(Context context, GTaskASyncTask asyncTask) { + if (mSyncing) { + Log.d(TAG, "Sync is in progress"); + return STATE_SYNC_IN_PROGRESS; + } + mContext = context; + mContentResolver = mContext.getContentResolver(); + mSyncing = true; + mCancelled = false; + mGTaskListHashMap.clear(); + mGTaskHashMap.clear(); + mMetaHashMap.clear(); + mLocalDeleteIdMap.clear(); + mGidToNid.clear(); + mNidToGid.clear(); + + try { + GTaskClient client = GTaskClient.getInstance(); + client.resetUpdateArray(); + + // login google task + if (!mCancelled) { + if (!client.login(mActivity)) { + throw new NetworkFailureException("login google task failed"); + } + } + + // get the task list from google + asyncTask.publishProgess(mContext.getString(R.string.sync_progress_init_list)); + initGTaskList(); + + // do content sync work + asyncTask.publishProgess(mContext.getString(R.string.sync_progress_syncing)); + syncContent(); + } catch (NetworkFailureException e) { + Log.e(TAG, e.toString()); + return STATE_NETWORK_ERROR; + } catch (ActionFailureException e) { + Log.e(TAG, e.toString()); + return STATE_INTERNAL_ERROR; + } catch (Exception e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + return STATE_INTERNAL_ERROR; + } finally { + mGTaskListHashMap.clear(); + mGTaskHashMap.clear(); + mMetaHashMap.clear(); + mLocalDeleteIdMap.clear(); + mGidToNid.clear(); + mNidToGid.clear(); + mSyncing = false; + } + + return mCancelled ? STATE_SYNC_CANCELLED : STATE_SUCCESS; + } + + private void initGTaskList() throws NetworkFailureException { + if (mCancelled) + return; + GTaskClient client = GTaskClient.getInstance(); + try { + JSONArray jsTaskLists = client.getTaskLists(); + + // init meta list first + mMetaList = null; + for (int i = 0; i < jsTaskLists.length(); i++) { + JSONObject object = jsTaskLists.getJSONObject(i); + String gid = object.getString(GTaskStringUtils.GTASK_JSON_ID); + String name = object.getString(GTaskStringUtils.GTASK_JSON_NAME); + + if (name + .equals(GTaskStringUtils.MIUI_FOLDER_PREFFIX + GTaskStringUtils.FOLDER_META)) { + mMetaList = new TaskList(); + mMetaList.setContentByRemoteJSON(object); + + // load meta data + JSONArray jsMetas = client.getTaskList(gid); + for (int j = 0; j < jsMetas.length(); j++) { + object = (JSONObject) jsMetas.getJSONObject(j); + MetaData metaData = new MetaData(); + metaData.setContentByRemoteJSON(object); + if (metaData.isWorthSaving()) { + mMetaList.addChildTask(metaData); + if (metaData.getGid() != null) { + mMetaHashMap.put(metaData.getRelatedGid(), metaData); + } + } + } + } + } + + // create meta list if not existed + if (mMetaList == null) { + mMetaList = new TaskList(); + mMetaList.setName(GTaskStringUtils.MIUI_FOLDER_PREFFIX + + GTaskStringUtils.FOLDER_META); + GTaskClient.getInstance().createTaskList(mMetaList); + } + + // init task list + for (int i = 0; i < jsTaskLists.length(); i++) { + JSONObject object = jsTaskLists.getJSONObject(i); + String gid = object.getString(GTaskStringUtils.GTASK_JSON_ID); + String name = object.getString(GTaskStringUtils.GTASK_JSON_NAME); + + if (name.startsWith(GTaskStringUtils.MIUI_FOLDER_PREFFIX) + && !name.equals(GTaskStringUtils.MIUI_FOLDER_PREFFIX + + GTaskStringUtils.FOLDER_META)) { + TaskList tasklist = new TaskList(); + tasklist.setContentByRemoteJSON(object); + mGTaskListHashMap.put(gid, tasklist); + mGTaskHashMap.put(gid, tasklist); + + // load tasks + JSONArray jsTasks = client.getTaskList(gid); + for (int j = 0; j < jsTasks.length(); j++) { + object = (JSONObject) jsTasks.getJSONObject(j); + gid = object.getString(GTaskStringUtils.GTASK_JSON_ID); + Task task = new Task(); + task.setContentByRemoteJSON(object); + if (task.isWorthSaving()) { + task.setMetaInfo(mMetaHashMap.get(gid)); + tasklist.addChildTask(task); + mGTaskHashMap.put(gid, task); + } + } + } + } + } catch (JSONException e) { + Log.e(TAG, e.toString()); + e.printStackTrace(); + throw new ActionFailureException("initGTaskList: handing JSONObject failed"); + } + } + + private void syncContent() throws NetworkFailureException { + int syncType; + Cursor c = null; + String gid; + Node node; + + mLocalDeleteIdMap.clear(); + + if (mCancelled) { + return; + } + + // for local deleted note + try { + c = mContentResolver.query(Notes.CONTENT_NOTE_URI, SqlNote.PROJECTION_NOTE, + "(type<>? AND parent_id=?)", new String[] { + String.valueOf(Notes.TYPE_SYSTEM), String.valueOf(Notes.ID_TRASH_FOLER) + }, null); + if (c != null) { + while (c.moveToNext()) { + gid = c.getString(SqlNote.GTASK_ID_COLUMN); + node = mGTaskHashMap.get(gid); + if (node != null) { + mGTaskHashMap.remove(gid); + doContentSync(Node.SYNC_ACTION_DEL_REMOTE, node, c); + } + + mLocalDeleteIdMap.add(c.getLong(SqlNote.ID_COLUMN)); + } + } else { + Log.w(TAG, "failed to query trash folder"); + } + } finally { + if (c != null) { + c.close(); + c = null; + } + } + + // sync folder first + syncFolder(); + + // for note existing in database + try { + c = mContentResolver.query(Notes.CONTENT_NOTE_URI, SqlNote.PROJECTION_NOTE, + "(type=? AND parent_id<>?)", new String[] { + String.valueOf(Notes.TYPE_NOTE), String.valueOf(Notes.ID_TRASH_FOLER) + }, NoteColumns.TYPE + " DESC"); + if (c != null) { + while (c.moveToNext()) { + gid = c.getString(SqlNote.GTASK_ID_COLUMN); + node = mGTaskHashMap.get(gid); + if (node != null) { + mGTaskHashMap.remove(gid); + mGidToNid.put(gid, c.getLong(SqlNote.ID_COLUMN)); + mNidToGid.put(c.getLong(SqlNote.ID_COLUMN), gid); + syncType = node.getSyncAction(c); + } else { + if (c.getString(SqlNote.GTASK_ID_COLUMN).trim().length() == 0) { + // local add + syncType = Node.SYNC_ACTION_ADD_REMOTE; + } else { + // remote delete + syncType = Node.SYNC_ACTION_DEL_LOCAL; + } + } + doContentSync(syncType, node, c); + } + } else { + Log.w(TAG, "failed to query existing note in database"); + } + + } finally { + if (c != null) { + c.close(); + c = null; + } + } + + // go through remaining items + Iterator> iter = mGTaskHashMap.entrySet().iterator(); + while (iter.hasNext()) { + Map.Entry entry = iter.next(); + node = entry.getValue(); + doContentSync(Node.SYNC_ACTION_ADD_LOCAL, node, null); + } + + // mCancelled can be set by another thread, so we neet to check one by + // one + // clear local delete table + if (!mCancelled) { + if (!DataUtils.batchDeleteNotes(mContentResolver, mLocalDeleteIdMap)) { + throw new ActionFailureException("failed to batch-delete local deleted notes"); + } + } + + // refresh local sync id + if (!mCancelled) { + GTaskClient.getInstance().commitUpdate(); + refreshLocalSyncId(); + } + + } + + private void syncFolder() throws NetworkFailureException { + Cursor c = null; + String gid; + Node node; + int syncType; + + if (mCancelled) { + return; + } + + // for root folder + try { + c = mContentResolver.query(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, + Notes.ID_ROOT_FOLDER), SqlNote.PROJECTION_NOTE, null, null, null); + if (c != null) { + c.moveToNext(); + gid = c.getString(SqlNote.GTASK_ID_COLUMN); + node = mGTaskHashMap.get(gid); + if (node != null) { + mGTaskHashMap.remove(gid); + mGidToNid.put(gid, (long) Notes.ID_ROOT_FOLDER); + mNidToGid.put((long) Notes.ID_ROOT_FOLDER, gid); + // for system folder, only update remote name if necessary + if (!node.getName().equals( + GTaskStringUtils.MIUI_FOLDER_PREFFIX + GTaskStringUtils.FOLDER_DEFAULT)) + doContentSync(Node.SYNC_ACTION_UPDATE_REMOTE, node, c); + } else { + doContentSync(Node.SYNC_ACTION_ADD_REMOTE, node, c); + } + } else { + Log.w(TAG, "failed to query root folder"); + } + } finally { + if (c != null) { + c.close(); + c = null; + } + } + + // for call-note folder + try { + c = mContentResolver.query(Notes.CONTENT_NOTE_URI, SqlNote.PROJECTION_NOTE, "(_id=?)", + new String[] { + String.valueOf(Notes.ID_CALL_RECORD_FOLDER) + }, null); + if (c != null) { + if (c.moveToNext()) { + gid = c.getString(SqlNote.GTASK_ID_COLUMN); + node = mGTaskHashMap.get(gid); + if (node != null) { + mGTaskHashMap.remove(gid); + mGidToNid.put(gid, (long) Notes.ID_CALL_RECORD_FOLDER); + mNidToGid.put((long) Notes.ID_CALL_RECORD_FOLDER, gid); + // for system folder, only update remote name if + // necessary + if (!node.getName().equals( + GTaskStringUtils.MIUI_FOLDER_PREFFIX + + GTaskStringUtils.FOLDER_CALL_NOTE)) + doContentSync(Node.SYNC_ACTION_UPDATE_REMOTE, node, c); + } else { + doContentSync(Node.SYNC_ACTION_ADD_REMOTE, node, c); + } + } + } else { + Log.w(TAG, "failed to query call note folder"); + } + } finally { + if (c != null) { + c.close(); + c = null; + } + } + + // for local existing folders + try { + c = mContentResolver.query(Notes.CONTENT_NOTE_URI, SqlNote.PROJECTION_NOTE, + "(type=? AND parent_id<>?)", new String[] { + String.valueOf(Notes.TYPE_FOLDER), String.valueOf(Notes.ID_TRASH_FOLER) + }, NoteColumns.TYPE + " DESC"); + if (c != null) { + while (c.moveToNext()) { + gid = c.getString(SqlNote.GTASK_ID_COLUMN); + node = mGTaskHashMap.get(gid); + if (node != null) { + mGTaskHashMap.remove(gid); + mGidToNid.put(gid, c.getLong(SqlNote.ID_COLUMN)); + mNidToGid.put(c.getLong(SqlNote.ID_COLUMN), gid); + syncType = node.getSyncAction(c); + } else { + if (c.getString(SqlNote.GTASK_ID_COLUMN).trim().length() == 0) { + // local add + syncType = Node.SYNC_ACTION_ADD_REMOTE; + } else { + // remote delete + syncType = Node.SYNC_ACTION_DEL_LOCAL; + } + } + doContentSync(syncType, node, c); + } + } else { + Log.w(TAG, "failed to query existing folder"); + } + } finally { + if (c != null) { + c.close(); + c = null; + } + } + + // for remote add folders + Iterator> iter = mGTaskListHashMap.entrySet().iterator(); + while (iter.hasNext()) { + Map.Entry entry = iter.next(); + gid = entry.getKey(); + node = entry.getValue(); + if (mGTaskHashMap.containsKey(gid)) { + mGTaskHashMap.remove(gid); + doContentSync(Node.SYNC_ACTION_ADD_LOCAL, node, null); + } + } + + if (!mCancelled) + GTaskClient.getInstance().commitUpdate(); + } + + private void doContentSync(int syncType, Node node, Cursor c) throws NetworkFailureException { + if (mCancelled) { + return; + } + + MetaData meta; + switch (syncType) { + case Node.SYNC_ACTION_ADD_LOCAL: + addLocalNode(node); + break; + case Node.SYNC_ACTION_ADD_REMOTE: + addRemoteNode(node, c); + break; + case Node.SYNC_ACTION_DEL_LOCAL: + meta = mMetaHashMap.get(c.getString(SqlNote.GTASK_ID_COLUMN)); + if (meta != null) { + GTaskClient.getInstance().deleteNode(meta); + } + mLocalDeleteIdMap.add(c.getLong(SqlNote.ID_COLUMN)); + break; + case Node.SYNC_ACTION_DEL_REMOTE: + meta = mMetaHashMap.get(node.getGid()); + if (meta != null) { + GTaskClient.getInstance().deleteNode(meta); + } + GTaskClient.getInstance().deleteNode(node); + break; + case Node.SYNC_ACTION_UPDATE_LOCAL: + updateLocalNode(node, c); + break; + case Node.SYNC_ACTION_UPDATE_REMOTE: + updateRemoteNode(node, c); + break; + case Node.SYNC_ACTION_UPDATE_CONFLICT: + // merging both modifications maybe a good idea + // right now just use local update simply + updateRemoteNode(node, c); + break; + case Node.SYNC_ACTION_NONE: + break; + case Node.SYNC_ACTION_ERROR: + default: + throw new ActionFailureException("unkown sync action type"); + } + } + + private void addLocalNode(Node node) throws NetworkFailureException { + if (mCancelled) { + return; + } + + SqlNote sqlNote; + if (node instanceof TaskList) { + if (node.getName().equals( + GTaskStringUtils.MIUI_FOLDER_PREFFIX + GTaskStringUtils.FOLDER_DEFAULT)) { + sqlNote = new SqlNote(mContext, Notes.ID_ROOT_FOLDER); + } else if (node.getName().equals( + GTaskStringUtils.MIUI_FOLDER_PREFFIX + GTaskStringUtils.FOLDER_CALL_NOTE)) { + sqlNote = new SqlNote(mContext, Notes.ID_CALL_RECORD_FOLDER); + } else { + sqlNote = new SqlNote(mContext); + sqlNote.setContent(node.getLocalJSONFromContent()); + sqlNote.setParentId(Notes.ID_ROOT_FOLDER); + } + } else { + sqlNote = new SqlNote(mContext); + JSONObject js = node.getLocalJSONFromContent(); + try { + if (js.has(GTaskStringUtils.META_HEAD_NOTE)) { + JSONObject note = js.getJSONObject(GTaskStringUtils.META_HEAD_NOTE); + if (note.has(NoteColumns.ID)) { + long id = note.getLong(NoteColumns.ID); + if (DataUtils.existInNoteDatabase(mContentResolver, id)) { + // the id is not available, have to create a new one + note.remove(NoteColumns.ID); + } + } + } + + if (js.has(GTaskStringUtils.META_HEAD_DATA)) { + JSONArray dataArray = js.getJSONArray(GTaskStringUtils.META_HEAD_DATA); + for (int i = 0; i < dataArray.length(); i++) { + JSONObject data = dataArray.getJSONObject(i); + if (data.has(DataColumns.ID)) { + long dataId = data.getLong(DataColumns.ID); + if (DataUtils.existInDataDatabase(mContentResolver, dataId)) { + // the data id is not available, have to create + // a new one + data.remove(DataColumns.ID); + } + } + } + + } + } catch (JSONException e) { + Log.w(TAG, e.toString()); + e.printStackTrace(); + } + sqlNote.setContent(js); + + Long parentId = mGidToNid.get(((Task) node).getParent().getGid()); + if (parentId == null) { + Log.e(TAG, "cannot find task's parent id locally"); + throw new ActionFailureException("cannot add local node"); + } + sqlNote.setParentId(parentId.longValue()); + } + + // create the local node + sqlNote.setGtaskId(node.getGid()); + sqlNote.commit(false); + + // update gid-nid mapping + mGidToNid.put(node.getGid(), sqlNote.getId()); + mNidToGid.put(sqlNote.getId(), node.getGid()); + + // update meta + updateRemoteMeta(node.getGid(), sqlNote); + } + + private void updateLocalNode(Node node, Cursor c) throws NetworkFailureException { + if (mCancelled) { + return; + } + + SqlNote sqlNote; + // update the note locally + sqlNote = new SqlNote(mContext, c); + sqlNote.setContent(node.getLocalJSONFromContent()); + + Long parentId = (node instanceof Task) ? mGidToNid.get(((Task) node).getParent().getGid()) + : new Long(Notes.ID_ROOT_FOLDER); + if (parentId == null) { + Log.e(TAG, "cannot find task's parent id locally"); + throw new ActionFailureException("cannot update local node"); + } + sqlNote.setParentId(parentId.longValue()); + sqlNote.commit(true); + + // update meta info + updateRemoteMeta(node.getGid(), sqlNote); + } + + private void addRemoteNode(Node node, Cursor c) throws NetworkFailureException { + if (mCancelled) { + return; + } + + SqlNote sqlNote = new SqlNote(mContext, c); + Node n; + + // update remotely + if (sqlNote.isNoteType()) { + Task task = new Task(); + task.setContentByLocalJSON(sqlNote.getContent()); + + String parentGid = mNidToGid.get(sqlNote.getParentId()); + if (parentGid == null) { + Log.e(TAG, "cannot find task's parent tasklist"); + throw new ActionFailureException("cannot add remote task"); + } + mGTaskListHashMap.get(parentGid).addChildTask(task); + + GTaskClient.getInstance().createTask(task); + n = (Node) task; + + // add meta + updateRemoteMeta(task.getGid(), sqlNote); + } else { + TaskList tasklist = null; + + // we need to skip folder if it has already existed + String folderName = GTaskStringUtils.MIUI_FOLDER_PREFFIX; + if (sqlNote.getId() == Notes.ID_ROOT_FOLDER) + folderName += GTaskStringUtils.FOLDER_DEFAULT; + else if (sqlNote.getId() == Notes.ID_CALL_RECORD_FOLDER) + folderName += GTaskStringUtils.FOLDER_CALL_NOTE; + else + folderName += sqlNote.getSnippet(); + + Iterator> iter = mGTaskListHashMap.entrySet().iterator(); + while (iter.hasNext()) { + Map.Entry entry = iter.next(); + String gid = entry.getKey(); + TaskList list = entry.getValue(); + + if (list.getName().equals(folderName)) { + tasklist = list; + if (mGTaskHashMap.containsKey(gid)) { + mGTaskHashMap.remove(gid); + } + break; + } + } + + // no match we can add now + if (tasklist == null) { + tasklist = new TaskList(); + tasklist.setContentByLocalJSON(sqlNote.getContent()); + GTaskClient.getInstance().createTaskList(tasklist); + mGTaskListHashMap.put(tasklist.getGid(), tasklist); + } + n = (Node) tasklist; + } + + // update local note + sqlNote.setGtaskId(n.getGid()); + sqlNote.commit(false); + sqlNote.resetLocalModified(); + sqlNote.commit(true); + + // gid-id mapping + mGidToNid.put(n.getGid(), sqlNote.getId()); + mNidToGid.put(sqlNote.getId(), n.getGid()); + } + + private void updateRemoteNode(Node node, Cursor c) throws NetworkFailureException { + if (mCancelled) { + return; + } + + SqlNote sqlNote = new SqlNote(mContext, c); + + // update remotely + node.setContentByLocalJSON(sqlNote.getContent()); + GTaskClient.getInstance().addUpdateNode(node); + + // update meta + updateRemoteMeta(node.getGid(), sqlNote); + + // move task if necessary + if (sqlNote.isNoteType()) { + Task task = (Task) node; + TaskList preParentList = task.getParent(); + + String curParentGid = mNidToGid.get(sqlNote.getParentId()); + if (curParentGid == null) { + Log.e(TAG, "cannot find task's parent tasklist"); + throw new ActionFailureException("cannot update remote task"); + } + TaskList curParentList = mGTaskListHashMap.get(curParentGid); + + if (preParentList != curParentList) { + preParentList.removeChildTask(task); + curParentList.addChildTask(task); + GTaskClient.getInstance().moveTask(task, preParentList, curParentList); + } + } + + // clear local modified flag + sqlNote.resetLocalModified(); + sqlNote.commit(true); + } + + private void updateRemoteMeta(String gid, SqlNote sqlNote) throws NetworkFailureException { + if (sqlNote != null && sqlNote.isNoteType()) { + MetaData metaData = mMetaHashMap.get(gid); + if (metaData != null) { + metaData.setMeta(gid, sqlNote.getContent()); + GTaskClient.getInstance().addUpdateNode(metaData); + } else { + metaData = new MetaData(); + metaData.setMeta(gid, sqlNote.getContent()); + mMetaList.addChildTask(metaData); + mMetaHashMap.put(gid, metaData); + GTaskClient.getInstance().createTask(metaData); + } + } + } + + private void refreshLocalSyncId() throws NetworkFailureException { + if (mCancelled) { + return; + } + + // get the latest gtask list + mGTaskHashMap.clear(); + mGTaskListHashMap.clear(); + mMetaHashMap.clear(); + initGTaskList(); + + Cursor c = null; + try { + c = mContentResolver.query(Notes.CONTENT_NOTE_URI, SqlNote.PROJECTION_NOTE, + "(type<>? AND parent_id<>?)", new String[] { + String.valueOf(Notes.TYPE_SYSTEM), String.valueOf(Notes.ID_TRASH_FOLER) + }, NoteColumns.TYPE + " DESC"); + if (c != null) { + while (c.moveToNext()) { + String gid = c.getString(SqlNote.GTASK_ID_COLUMN); + Node node = mGTaskHashMap.get(gid); + if (node != null) { + mGTaskHashMap.remove(gid); + ContentValues values = new ContentValues(); + values.put(NoteColumns.SYNC_ID, node.getLastModified()); + mContentResolver.update(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, + c.getLong(SqlNote.ID_COLUMN)), values, null, null); + } else { + Log.e(TAG, "something is missed"); + throw new ActionFailureException( + "some local items don't have gid after sync"); + } + } + } else { + Log.w(TAG, "failed to query local note to refresh sync id"); + } + } finally { + if (c != null) { + c.close(); + c = null; + } + } + } + + public String getSyncAccount() { + return GTaskClient.getInstance().getSyncAccount().name; + } + + public void cancelSync() { + mCancelled = true; + } +} diff --git a/app/src/main/java/net/micode/notes/gtask/remote/GTaskSyncService.java b/app/src/main/java/net/micode/notes/gtask/remote/GTaskSyncService.java new file mode 100644 index 0000000..cca36f7 --- /dev/null +++ b/app/src/main/java/net/micode/notes/gtask/remote/GTaskSyncService.java @@ -0,0 +1,128 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.gtask.remote; + +import android.app.Activity; +import android.app.Service; +import android.content.Context; +import android.content.Intent; +import android.os.Bundle; +import android.os.IBinder; + +public class GTaskSyncService extends Service { + public final static String ACTION_STRING_NAME = "sync_action_type"; + + public final static int ACTION_START_SYNC = 0; + + public final static int ACTION_CANCEL_SYNC = 1; + + public final static int ACTION_INVALID = 2; + + public final static String GTASK_SERVICE_BROADCAST_NAME = "net.micode.notes.gtask.remote.gtask_sync_service"; + + public final static String GTASK_SERVICE_BROADCAST_IS_SYNCING = "isSyncing"; + + public final static String GTASK_SERVICE_BROADCAST_PROGRESS_MSG = "progressMsg"; + + private static GTaskASyncTask mSyncTask = null; + + private static String mSyncProgress = ""; + + private void startSync() { + if (mSyncTask == null) { + mSyncTask = new GTaskASyncTask(this, new GTaskASyncTask.OnCompleteListener() { + public void onComplete() { + mSyncTask = null; + sendBroadcast(""); + stopSelf(); + } + }); + sendBroadcast(""); + mSyncTask.execute(); + } + } + + private void cancelSync() { + if (mSyncTask != null) { + mSyncTask.cancelSync(); + } + } + + @Override + public void onCreate() { + mSyncTask = null; + } + + @Override + public int onStartCommand(Intent intent, int flags, int startId) { + Bundle bundle = intent.getExtras(); + if (bundle != null && bundle.containsKey(ACTION_STRING_NAME)) { + switch (bundle.getInt(ACTION_STRING_NAME, ACTION_INVALID)) { + case ACTION_START_SYNC: + startSync(); + break; + case ACTION_CANCEL_SYNC: + cancelSync(); + break; + default: + break; + } + return START_STICKY; + } + return super.onStartCommand(intent, flags, startId); + } + + @Override + public void onLowMemory() { + if (mSyncTask != null) { + mSyncTask.cancelSync(); + } + } + + public IBinder onBind(Intent intent) { + return null; + } + + public void sendBroadcast(String msg) { + mSyncProgress = msg; + Intent intent = new Intent(GTASK_SERVICE_BROADCAST_NAME); + intent.putExtra(GTASK_SERVICE_BROADCAST_IS_SYNCING, mSyncTask != null); + intent.putExtra(GTASK_SERVICE_BROADCAST_PROGRESS_MSG, msg); + sendBroadcast(intent); + } + + public static void startSync(Activity activity) { + GTaskManager.getInstance().setActivityContext(activity); + Intent intent = new Intent(activity, GTaskSyncService.class); + intent.putExtra(GTaskSyncService.ACTION_STRING_NAME, GTaskSyncService.ACTION_START_SYNC); + activity.startService(intent); + } + + public static void cancelSync(Context context) { + Intent intent = new Intent(context, GTaskSyncService.class); + intent.putExtra(GTaskSyncService.ACTION_STRING_NAME, GTaskSyncService.ACTION_CANCEL_SYNC); + context.startService(intent); + } + + public static boolean isSyncing() { + return mSyncTask != null; + } + + public static String getProgressString() { + return mSyncProgress; + } +} diff --git a/app/src/main/java/net/micode/notes/model/Note.java b/app/src/main/java/net/micode/notes/model/Note.java new file mode 100644 index 0000000..ee86fdd --- /dev/null +++ b/app/src/main/java/net/micode/notes/model/Note.java @@ -0,0 +1,258 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.model; +import android.content.ContentProviderOperation; +import android.content.ContentProviderResult; +import android.content.ContentUris; +import android.content.ContentValues; +import android.content.Context; +import android.content.OperationApplicationException; +import android.net.Uri; +import android.os.RemoteException; +import android.util.Log; + +import net.micode.notes.data.Notes; +import net.micode.notes.data.Notes.CallNote; +import net.micode.notes.data.Notes.DataColumns; +import net.micode.notes.data.Notes.NoteColumns; +import net.micode.notes.data.Notes.TextNote; + +import java.util.ArrayList; + + +public class Note { + private ContentValues mNoteDiffValues; + private NoteData mNoteData; + + public static final int FIRST_MODIFIED = 1; + public static final int UNASSIGNED_NOTE_ID = 0; + public static final int ILLEGAL_NOTE_ID = -1; + + private static final String TAG = "Note"; + /** + * Create a new note id for adding a new note to databases + */ + public static synchronized long getNewNoteId(Context context, long folderId) { + // Create a new note in the database + ContentValues values = new ContentValues(); + long createdTime = System.currentTimeMillis(); + values.put(NoteColumns.CREATED_DATE, createdTime); + values.put(NoteColumns.MODIFIED_DATE, createdTime); + values.put(NoteColumns.TYPE, Notes.TYPE_NOTE); + values.put(NoteColumns.LOCAL_MODIFIED, FIRST_MODIFIED); + values.put(NoteColumns.PARENT_ID, folderId); + Uri uri = context.getContentResolver().insert(Notes.CONTENT_NOTE_URI, values); + + long noteId = UNASSIGNED_NOTE_ID; + try { + noteId = Long.valueOf(uri.getPathSegments().get(1)); + } catch (NumberFormatException e) { + Log.e(TAG, "Get note id error :" + e.toString()); + noteId = UNASSIGNED_NOTE_ID; + } + if (noteId == ILLEGAL_NOTE_ID) { + throw new IllegalStateException("Wrong note id:" + noteId); + } + return noteId; + } + + public Note() { + mNoteDiffValues = new ContentValues(); + mNoteData = new NoteData(); + } + + public void setNoteValue(String key, String value) { + mNoteDiffValues.put(key, value); + mNoteDiffValues.put(NoteColumns.LOCAL_MODIFIED, 1); + mNoteDiffValues.put(NoteColumns.MODIFIED_DATE, System.currentTimeMillis()); + } + + public void setTextData(String key, String value) { + mNoteData.setTextData(key, value); + } + + public void setTextDataId(long id) { + mNoteData.setTextDataId(id); + } + + public long getTextDataId() { + return mNoteData.mTextDataId; + } + + public void setCallDataId(long id) { + mNoteData.setCallDataId(id); + } + + public void setCallData(String key, String value) { + mNoteData.setCallData(key, value); + } + + public boolean isLocalModified() { + return mNoteDiffValues.size() > 0 || mNoteData.isLocalModified(); + } + + public boolean syncNote(Context context, long noteId) { + if (noteId <= 0) { + throw new IllegalArgumentException("Wrong note id:" + noteId); + } + + if (!isLocalModified()) { + return true; + } + + /** + * In theory, once data changed, the note should be updated on {@link NoteColumns#LOCAL_MODIFIED} and + * {@link NoteColumns#MODIFIED_DATE}. For data safety, though update note fails, we also update the + * note data info + */ + if (context.getContentResolver().update( + ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, noteId), mNoteDiffValues, null, + null) == 0) { + Log.e(TAG, "Update note error, should not happen"); + // Do not return, fall through + } + mNoteDiffValues.clear(); + + if (mNoteData.isLocalModified() + && (mNoteData.pushIntoContentResolver(context, noteId) == null)) { + return false; + } + + return true; + } + + private class NoteData { + private long mTextDataId; + + private ContentValues mTextDataValues; + + private long mCallDataId; + + private ContentValues mCallDataValues; + + private static final String TAG = "NoteData"; + + public NoteData() { + mTextDataValues = new ContentValues(); + mCallDataValues = new ContentValues(); + mTextDataId = 0; + mCallDataId = 0; + } + + boolean isLocalModified() { + return mTextDataValues.size() > 0 || mCallDataValues.size() > 0; + } + + void setTextDataId(long id) { + if(id <= 0) { + throw new IllegalArgumentException("Text data id should larger than 0"); + } + mTextDataId = id; + } + + void setCallDataId(long id) { + if (id <= 0) { + throw new IllegalArgumentException("Call data id should larger than 0"); + } + mCallDataId = id; + } + + void setCallData(String key, String value) { + mCallDataValues.put(key, value); + mNoteDiffValues.put(NoteColumns.LOCAL_MODIFIED, 1); + mNoteDiffValues.put(NoteColumns.MODIFIED_DATE, System.currentTimeMillis()); + } + + void setTextData(String key, String value) { + mTextDataValues.put(key, value); + mNoteDiffValues.put(NoteColumns.LOCAL_MODIFIED, 1); + mNoteDiffValues.put(NoteColumns.MODIFIED_DATE, System.currentTimeMillis()); + } + + Uri pushIntoContentResolver(Context context, long noteId) { + /** + * Check for safety + */ + if (noteId <= 0) { + throw new IllegalArgumentException("Wrong note id:" + noteId); + } + + ArrayList operationList = new ArrayList(); + ContentProviderOperation.Builder builder = null; + + if(mTextDataValues.size() > 0) { + mTextDataValues.put(DataColumns.NOTE_ID, noteId); + if (mTextDataId == 0) { + mTextDataValues.put(DataColumns.MIME_TYPE, TextNote.CONTENT_ITEM_TYPE); + Uri uri = context.getContentResolver().insert(Notes.CONTENT_DATA_URI, + mTextDataValues); + try { + setTextDataId(Long.valueOf(uri.getPathSegments().get(1))); + } catch (NumberFormatException e) { + Log.e(TAG, "Insert new text data fail with noteId" + noteId); + mTextDataValues.clear(); + return null; + } + } else { + builder = ContentProviderOperation.newUpdate(ContentUris.withAppendedId( + Notes.CONTENT_DATA_URI, mTextDataId)); + builder.withValues(mTextDataValues); + operationList.add(builder.build()); + } + mTextDataValues.clear(); + } + + if(mCallDataValues.size() > 0) { + mCallDataValues.put(DataColumns.NOTE_ID, noteId); + if (mCallDataId == 0) { + mCallDataValues.put(DataColumns.MIME_TYPE, CallNote.CONTENT_ITEM_TYPE); + Uri uri = context.getContentResolver().insert(Notes.CONTENT_DATA_URI, + mCallDataValues); + try { + setCallDataId(Long.valueOf(uri.getPathSegments().get(1))); + } catch (NumberFormatException e) { + Log.e(TAG, "Insert new call data fail with noteId" + noteId); + mCallDataValues.clear(); + return null; + } + } else { + builder = ContentProviderOperation.newUpdate(ContentUris.withAppendedId( + Notes.CONTENT_DATA_URI, mCallDataId)); + builder.withValues(mCallDataValues); + operationList.add(builder.build()); + } + mCallDataValues.clear(); + } + + if (operationList.size() > 0) { + try { + ContentProviderResult[] results = context.getContentResolver().applyBatch( + Notes.AUTHORITY, operationList); + return (results == null || results.length == 0 || results[0] == null) ? null + : ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, noteId); + } catch (RemoteException e) { + Log.e(TAG, String.format("%s: %s", e.toString(), e.getMessage())); + return null; + } catch (OperationApplicationException e) { + Log.e(TAG, String.format("%s: %s", e.toString(), e.getMessage())); + return null; + } + } + return null; + } + } +} diff --git a/app/src/main/java/net/micode/notes/model/WorkingNote.java b/app/src/main/java/net/micode/notes/model/WorkingNote.java new file mode 100644 index 0000000..59d39f1 --- /dev/null +++ b/app/src/main/java/net/micode/notes/model/WorkingNote.java @@ -0,0 +1,416 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.model; + +import android.appwidget.AppWidgetManager; +import android.content.ContentUris; +import android.content.Context; +import android.database.Cursor; +import android.text.TextUtils; +import android.util.Log; + +import net.micode.notes.data.Notes; +import net.micode.notes.data.Notes.CallNote; +import net.micode.notes.data.Notes.DataColumns; +import net.micode.notes.data.Notes.DataConstants; +import net.micode.notes.data.Notes.NoteColumns; +import net.micode.notes.data.Notes.TextNote; +import net.micode.notes.tool.ResourceParser.NoteBgResources; + + +public class WorkingNote { + // Note for the working note + private Note mNote; + // Note Id + private long mNoteId; + // Note content + private String mContent; + // Note mode + private int mMode; + + private String mPassword; + + private int mImportance; + + private long mAlertDate; + + private long mModifiedDate; + + private int mBgColorId; + + private int mWidgetId; + + private int mWidgetType; + + private long mFolderId; + + private Context mContext; + + private static final String TAG = "WorkingNote"; + + private boolean mIsDeleted; + + private NoteSettingChangedListener mNoteSettingStatusListener; + + public static final String[] DATA_PROJECTION = new String[] { + DataColumns.ID, + DataColumns.CONTENT, + DataColumns.MIME_TYPE, + DataColumns.DATA1, + DataColumns.DATA2, + DataColumns.DATA3, + DataColumns.DATA4, + }; + + public static final String[] NOTE_PROJECTION = new String[] { + NoteColumns.PARENT_ID, + NoteColumns.ALERTED_DATE, + NoteColumns.BG_COLOR_ID, + NoteColumns.WIDGET_ID, + NoteColumns.WIDGET_TYPE, + NoteColumns.MODIFIED_DATE, + NoteColumns.PASSWORD, + NoteColumns.IMPORTANCE + }; + + private static final int DATA_ID_COLUMN = 0; + + private static final int DATA_CONTENT_COLUMN = 1; + + private static final int DATA_MIME_TYPE_COLUMN = 2; + + private static final int DATA_MODE_COLUMN = 3; + + private static final int NOTE_PARENT_ID_COLUMN = 0; + + private static final int NOTE_ALERTED_DATE_COLUMN = 1; + + private static final int NOTE_BG_COLOR_ID_COLUMN = 2; + + private static final int NOTE_WIDGET_ID_COLUMN = 3; + + private static final int NOTE_WIDGET_TYPE_COLUMN = 4; + + private static final int NOTE_MODIFIED_DATE_COLUMN = 5; + + private static final int NOTE_PASSWORD = 6; + + private static final int NOTE_IMPORTANCE = 7; + + // New note construct + private WorkingNote(Context context, long folderId) { + mContext = context; + mAlertDate = 0; + mModifiedDate = System.currentTimeMillis(); + mFolderId = folderId; + mNote = new Note(); + mNoteId = 0; + mIsDeleted = false; + mMode = 0; + mWidgetType = Notes.TYPE_WIDGET_INVALIDE; + + mPassword = ""; + mImportance = 0; + } + + // Existing note construct + private WorkingNote(Context context, long noteId, long folderId) { + mContext = context; + mNoteId = noteId; + mFolderId = folderId; + mIsDeleted = false; + mNote = new Note(); + loadNote(); + } + + /** + * 通过游标cursor从数据库中加载便签及其属性 + */ + private void loadNote() { + Cursor cursor = mContext.getContentResolver().query( + ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, mNoteId), NOTE_PROJECTION, null, + null, null); + + if (cursor != null) { + if (cursor.moveToFirst()) { + mFolderId = cursor.getLong(NOTE_PARENT_ID_COLUMN); + mBgColorId = cursor.getInt(NOTE_BG_COLOR_ID_COLUMN); + mWidgetId = cursor.getInt(NOTE_WIDGET_ID_COLUMN); + mWidgetType = cursor.getInt(NOTE_WIDGET_TYPE_COLUMN); + mAlertDate = cursor.getLong(NOTE_ALERTED_DATE_COLUMN); + mModifiedDate = cursor.getLong(NOTE_MODIFIED_DATE_COLUMN); + mPassword = cursor.getString(NOTE_PASSWORD); + mImportance =cursor.getInt(NOTE_IMPORTANCE); + } + cursor.close(); + } else { + Log.e(TAG, "No note with id:" + mNoteId); + throw new IllegalArgumentException("Unable to find note with id " + mNoteId); + } + loadNoteData(); + } + /** + *通过游标cursor从数据库中加载便签数据 + */ + private void loadNoteData() { + Cursor cursor = mContext.getContentResolver().query(Notes.CONTENT_DATA_URI, DATA_PROJECTION, + DataColumns.NOTE_ID + "=?", new String[] { + String.valueOf(mNoteId) + }, null); + + if (cursor != null) { + if (cursor.moveToFirst()) { + do { + String type = cursor.getString(DATA_MIME_TYPE_COLUMN); + if (DataConstants.NOTE.equals(type)) { + mContent = cursor.getString(DATA_CONTENT_COLUMN); + mMode = cursor.getInt(DATA_MODE_COLUMN); + mNote.setTextDataId(cursor.getLong(DATA_ID_COLUMN)); + } else if (DataConstants.CALL_NOTE.equals(type)) { + mNote.setCallDataId(cursor.getLong(DATA_ID_COLUMN)); + } else { + Log.d(TAG, "Wrong note type with type:" + type); + } + } while (cursor.moveToNext()); + } + cursor.close(); + } else { + Log.e(TAG, "No data with id:" + mNoteId); + throw new IllegalArgumentException("Unable to find note's data with id " + mNoteId); + } + } + /** + * 创建空便签 + */ + public static WorkingNote createEmptyNote(Context context, long folderId, int widgetId, + int widgetType, int defaultBgColorId) { + WorkingNote note = new WorkingNote(context, folderId); + note.setBgColorId(defaultBgColorId); + note.setWidgetId(widgetId); + note.setWidgetType(widgetType); + return note; + } + + public static WorkingNote load(Context context, long id) { + return new WorkingNote(context, id, 0); + } + + public synchronized boolean saveNote() { + if (isWorthSaving()) { + if (!existInDatabase()) { + if ((mNoteId = Note.getNewNoteId(mContext, mFolderId)) == 0) { + Log.e(TAG, "Create new note fail with id:" + mNoteId); + return false; + } + } + + mNote.syncNote(mContext, mNoteId); + + /** + * Update widget content if there exist any widget of this note + */ + if (mWidgetId != AppWidgetManager.INVALID_APPWIDGET_ID + && mWidgetType != Notes.TYPE_WIDGET_INVALIDE + && mNoteSettingStatusListener != null) { + mNoteSettingStatusListener.onWidgetChanged(); + } + return true; + } else { + return false; + } + } + + + + public boolean existInDatabase() { + return mNoteId > 0; + } + + private boolean isWorthSaving() { + if (mIsDeleted || (!existInDatabase() && TextUtils.isEmpty(mContent)) + || (existInDatabase() && !mNote.isLocalModified())) { + return false; + } else { + return true; + } + } + + public void setOnSettingStatusChangedListener(NoteSettingChangedListener l) { + mNoteSettingStatusListener = l; + } + + /** + * 该方法用于设置当前工作便签的访问密码 + * @param password 新的访问密码 + */ + public void setPassword(String password) { + //将该类的mPassword属性设置为新的访问密码 + mPassword = password; + //将修改后的便签密码写入到便签数据库中 + mNote.setNoteValue(NoteColumns.PASSWORD, mPassword); + } + + public void setImportance(int importance) { + mImportance = importance; + mNote.setNoteValue(NoteColumns.IMPORTANCE, String.valueOf(mImportance)); + } + + public void setAlertDate(long date, boolean set) { + if (date != mAlertDate) { + mAlertDate = date; + mNote.setNoteValue(NoteColumns.ALERTED_DATE, String.valueOf(mAlertDate)); + } + if (mNoteSettingStatusListener != null) { + mNoteSettingStatusListener.onClockAlertChanged(date, set); + } + } + + public void markDeleted(boolean mark) { + mIsDeleted = mark; + if (mWidgetId != AppWidgetManager.INVALID_APPWIDGET_ID + && mWidgetType != Notes.TYPE_WIDGET_INVALIDE && mNoteSettingStatusListener != null) { + mNoteSettingStatusListener.onWidgetChanged(); + } + } + + public void setBgColorId(int id) { + if (id != mBgColorId) { + mBgColorId = id; + if (mNoteSettingStatusListener != null) { + mNoteSettingStatusListener.onBackgroundColorChanged(); + } + mNote.setNoteValue(NoteColumns.BG_COLOR_ID, String.valueOf(id)); + } + } + + public void setCheckListMode(int mode) { + if (mMode != mode) { + if (mNoteSettingStatusListener != null) { + mNoteSettingStatusListener.onCheckListModeChanged(mMode, mode); + } + mMode = mode; + mNote.setTextData(TextNote.MODE, String.valueOf(mMode)); + } + } + + public void setWidgetType(int type) { + if (type != mWidgetType) { + mWidgetType = type; + mNote.setNoteValue(NoteColumns.WIDGET_TYPE, String.valueOf(mWidgetType)); + } + } + + public void setWidgetId(int id) { + if (id != mWidgetId) { + mWidgetId = id; + mNote.setNoteValue(NoteColumns.WIDGET_ID, String.valueOf(mWidgetId)); + } + } + + public void setWorkingText(String text) { + if (!TextUtils.equals(mContent, text)) { + mContent = text; + mNote.setTextData(DataColumns.CONTENT, mContent); + } + } + + public void convertToCallNote(String phoneNumber, long callDate) { + mNote.setCallData(CallNote.CALL_DATE, String.valueOf(callDate)); + mNote.setCallData(CallNote.PHONE_NUMBER, phoneNumber); + mNote.setNoteValue(NoteColumns.PARENT_ID, String.valueOf(Notes.ID_CALL_RECORD_FOLDER)); + } + + public boolean hasPassword() { return !mPassword.equals(""); } + + public String getPassword() { return mPassword; } + + public boolean hasImportance() { return (mImportance > 0); } + + public int getImportance() { return mImportance; } + + public boolean hasClockAlert() { + return (mAlertDate > 0 ? true : false); + } + + public String getContent() { + return mContent; + } + + public long getAlertDate() { + return mAlertDate; + } + + public long getModifiedDate() { + return mModifiedDate; + } + + public int getBgColorResId() { + return NoteBgResources.getNoteBgResource(mBgColorId); + } + + public int getBgColorId() { + return mBgColorId; + } + + public int getTitleBgResId() { + return NoteBgResources.getNoteTitleBgResource(mBgColorId); + } + + public int getCheckListMode() { + return mMode; + } + + public long getNoteId() { + return mNoteId; + } + + public long getFolderId() { + return mFolderId; + } + + public int getWidgetId() { + return mWidgetId; + } + + public int getWidgetType() { + return mWidgetType; + } + + public interface NoteSettingChangedListener { + /** + * Called when the background color of current note has just changed + */ + void onBackgroundColorChanged(); + + /** + * Called when user set clock + */ + void onClockAlertChanged(long date, boolean set); + + /** + * Call when user create note from widget + */ + void onWidgetChanged(); + + /** + * Call when switch between check list mode and normal mode + * @param oldMode is previous mode before change + * @param newMode is new mode + */ + void onCheckListModeChanged(int oldMode, int newMode); + } +} diff --git a/app/src/main/java/net/micode/notes/tool/BackupUtils.java b/app/src/main/java/net/micode/notes/tool/BackupUtils.java new file mode 100644 index 0000000..39f6ec4 --- /dev/null +++ b/app/src/main/java/net/micode/notes/tool/BackupUtils.java @@ -0,0 +1,344 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.tool; + +import android.content.Context; +import android.database.Cursor; +import android.os.Environment; +import android.text.TextUtils; +import android.text.format.DateFormat; +import android.util.Log; + +import net.micode.notes.R; +import net.micode.notes.data.Notes; +import net.micode.notes.data.Notes.DataColumns; +import net.micode.notes.data.Notes.DataConstants; +import net.micode.notes.data.Notes.NoteColumns; + +import java.io.File; +import java.io.FileNotFoundException; +import java.io.FileOutputStream; +import java.io.IOException; +import java.io.PrintStream; + + +public class BackupUtils { + private static final String TAG = "BackupUtils"; + // Singleton stuff + private static BackupUtils sInstance; + + public static synchronized BackupUtils getInstance(Context context) { + if (sInstance == null) { + sInstance = new BackupUtils(context); + } + return sInstance; + } + + /** + * Following states are signs to represents backup or restore + * status + */ + // Currently, the sdcard is not mounted + public static final int STATE_SD_CARD_UNMOUONTED = 0; + // The backup file not exist + public static final int STATE_BACKUP_FILE_NOT_EXIST = 1; + // The data is not well formated, may be changed by other programs + public static final int STATE_DATA_DESTROIED = 2; + // Some run-time exception which causes restore or backup fails + public static final int STATE_SYSTEM_ERROR = 3; + // Backup or restore success + public static final int STATE_SUCCESS = 4; + + private TextExport mTextExport; + + private BackupUtils(Context context) { + mTextExport = new TextExport(context); + } + + private static boolean externalStorageAvailable() { + return Environment.MEDIA_MOUNTED.equals(Environment.getExternalStorageState()); + } + + public int exportToText() { + return mTextExport.exportToText(); + } + + public String getExportedTextFileName() { + return mTextExport.mFileName; + } + + public String getExportedTextFileDir() { + return mTextExport.mFileDirectory; + } + + private static class TextExport { + private static final String[] NOTE_PROJECTION = { + NoteColumns.ID, + NoteColumns.MODIFIED_DATE, + NoteColumns.SNIPPET, + NoteColumns.TYPE + }; + + private static final int NOTE_COLUMN_ID = 0; + + private static final int NOTE_COLUMN_MODIFIED_DATE = 1; + + private static final int NOTE_COLUMN_SNIPPET = 2; + + private static final String[] DATA_PROJECTION = { + DataColumns.CONTENT, + DataColumns.MIME_TYPE, + DataColumns.DATA1, + DataColumns.DATA2, + DataColumns.DATA3, + DataColumns.DATA4, + }; + + private static final int DATA_COLUMN_CONTENT = 0; + + private static final int DATA_COLUMN_MIME_TYPE = 1; + + private static final int DATA_COLUMN_CALL_DATE = 2; + + private static final int DATA_COLUMN_PHONE_NUMBER = 4; + + private final String [] TEXT_FORMAT; + private static final int FORMAT_FOLDER_NAME = 0; + private static final int FORMAT_NOTE_DATE = 1; + private static final int FORMAT_NOTE_CONTENT = 2; + + private Context mContext; + private String mFileName; + private String mFileDirectory; + + public TextExport(Context context) { + TEXT_FORMAT = context.getResources().getStringArray(R.array.format_for_exported_note); + mContext = context; + mFileName = ""; + mFileDirectory = ""; + } + + private String getFormat(int id) { + return TEXT_FORMAT[id]; + } + + /** + * Export the folder identified by folder id to text + */ + private void exportFolderToText(String folderId, PrintStream ps) { + // Query notes belong to this folder + Cursor notesCursor = mContext.getContentResolver().query(Notes.CONTENT_NOTE_URI, + NOTE_PROJECTION, NoteColumns.PARENT_ID + "=?", new String[] { + folderId + }, null); + + if (notesCursor != null) { + if (notesCursor.moveToFirst()) { + do { + // Print note's last modified date + ps.println(String.format(getFormat(FORMAT_NOTE_DATE), DateFormat.format( + mContext.getString(R.string.format_datetime_mdhm), + notesCursor.getLong(NOTE_COLUMN_MODIFIED_DATE)))); + // Query data belong to this note + String noteId = notesCursor.getString(NOTE_COLUMN_ID); + exportNoteToText(noteId, ps); + } while (notesCursor.moveToNext()); + } + notesCursor.close(); + } + } + + /** + * Export note identified by id to a print stream + */ + private void exportNoteToText(String noteId, PrintStream ps) { + Cursor dataCursor = mContext.getContentResolver().query(Notes.CONTENT_DATA_URI, + DATA_PROJECTION, DataColumns.NOTE_ID + "=?", new String[] { + noteId + }, null); + + if (dataCursor != null) { + if (dataCursor.moveToFirst()) { + do { + String mimeType = dataCursor.getString(DATA_COLUMN_MIME_TYPE); + if (DataConstants.CALL_NOTE.equals(mimeType)) { + // Print phone number + String phoneNumber = dataCursor.getString(DATA_COLUMN_PHONE_NUMBER); + long callDate = dataCursor.getLong(DATA_COLUMN_CALL_DATE); + String location = dataCursor.getString(DATA_COLUMN_CONTENT); + + if (!TextUtils.isEmpty(phoneNumber)) { + ps.println(String.format(getFormat(FORMAT_NOTE_CONTENT), + phoneNumber)); + } + // Print call date + ps.println(String.format(getFormat(FORMAT_NOTE_CONTENT), DateFormat + .format(mContext.getString(R.string.format_datetime_mdhm), + callDate))); + // Print call attachment location + if (!TextUtils.isEmpty(location)) { + ps.println(String.format(getFormat(FORMAT_NOTE_CONTENT), + location)); + } + } else if (DataConstants.NOTE.equals(mimeType)) { + String content = dataCursor.getString(DATA_COLUMN_CONTENT); + if (!TextUtils.isEmpty(content)) { + ps.println(String.format(getFormat(FORMAT_NOTE_CONTENT), + content)); + } + } + } while (dataCursor.moveToNext()); + } + dataCursor.close(); + } + // print a line separator between note + try { + ps.write(new byte[] { + Character.LINE_SEPARATOR, Character.LETTER_NUMBER + }); + } catch (IOException e) { + Log.e(TAG, e.toString()); + } + } + + /** + * Note will be exported as text which is user readable + */ + public int exportToText() { + if (!externalStorageAvailable()) { + Log.d(TAG, "Media was not mounted"); + return STATE_SD_CARD_UNMOUONTED; + } + + PrintStream ps = getExportToTextPrintStream(); + if (ps == null) { + Log.e(TAG, "get print stream error"); + return STATE_SYSTEM_ERROR; + } + // First export folder and its notes + Cursor folderCursor = mContext.getContentResolver().query( + Notes.CONTENT_NOTE_URI, + NOTE_PROJECTION, + "(" + NoteColumns.TYPE + "=" + Notes.TYPE_FOLDER + " AND " + + NoteColumns.PARENT_ID + "<>" + Notes.ID_TRASH_FOLER + ") OR " + + NoteColumns.ID + "=" + Notes.ID_CALL_RECORD_FOLDER, null, null); + + if (folderCursor != null) { + if (folderCursor.moveToFirst()) { + do { + // Print folder's name + String folderName = ""; + if(folderCursor.getLong(NOTE_COLUMN_ID) == Notes.ID_CALL_RECORD_FOLDER) { + folderName = mContext.getString(R.string.call_record_folder_name); + } else { + folderName = folderCursor.getString(NOTE_COLUMN_SNIPPET); + } + if (!TextUtils.isEmpty(folderName)) { + ps.println(String.format(getFormat(FORMAT_FOLDER_NAME), folderName)); + } + String folderId = folderCursor.getString(NOTE_COLUMN_ID); + exportFolderToText(folderId, ps); + } while (folderCursor.moveToNext()); + } + folderCursor.close(); + } + + // Export notes in root's folder + Cursor noteCursor = mContext.getContentResolver().query( + Notes.CONTENT_NOTE_URI, + NOTE_PROJECTION, + NoteColumns.TYPE + "=" + +Notes.TYPE_NOTE + " AND " + NoteColumns.PARENT_ID + + "=0", null, null); + + if (noteCursor != null) { + if (noteCursor.moveToFirst()) { + do { + ps.println(String.format(getFormat(FORMAT_NOTE_DATE), DateFormat.format( + mContext.getString(R.string.format_datetime_mdhm), + noteCursor.getLong(NOTE_COLUMN_MODIFIED_DATE)))); + // Query data belong to this note + String noteId = noteCursor.getString(NOTE_COLUMN_ID); + exportNoteToText(noteId, ps); + } while (noteCursor.moveToNext()); + } + noteCursor.close(); + } + ps.close(); + + return STATE_SUCCESS; + } + + /** + * Get a print stream pointed to the file {@generateExportedTextFile} + */ + private PrintStream getExportToTextPrintStream() { + File file = generateFileMountedOnSDcard(mContext, R.string.file_path, + R.string.file_name_txt_format); + if (file == null) { + Log.e(TAG, "create file to exported failed"); + return null; + } + mFileName = file.getName(); + mFileDirectory = mContext.getString(R.string.file_path); + PrintStream ps = null; + try { + FileOutputStream fos = new FileOutputStream(file); + ps = new PrintStream(fos); + } catch (FileNotFoundException e) { + e.printStackTrace(); + return null; + } catch (NullPointerException e) { + e.printStackTrace(); + return null; + } + return ps; + } + } + + /** + * Generate the text file to store imported data + */ + private static File generateFileMountedOnSDcard(Context context, int filePathResId, int fileNameFormatResId) { + StringBuilder sb = new StringBuilder(); + sb.append(Environment.getExternalStorageDirectory()); + sb.append(context.getString(filePathResId)); + File filedir = new File(sb.toString()); + sb.append(context.getString( + fileNameFormatResId, + DateFormat.format(context.getString(R.string.format_date_ymd), + System.currentTimeMillis()))); + File file = new File(sb.toString()); + + try { + if (!filedir.exists()) { + filedir.mkdir(); + } + if (!file.exists()) { + file.createNewFile(); + } + return file; + } catch (SecurityException e) { + e.printStackTrace(); + } catch (IOException e) { + e.printStackTrace(); + } + + return null; + } +} + + diff --git a/app/src/main/java/net/micode/notes/tool/DataUtils.java b/app/src/main/java/net/micode/notes/tool/DataUtils.java new file mode 100644 index 0000000..2a14982 --- /dev/null +++ b/app/src/main/java/net/micode/notes/tool/DataUtils.java @@ -0,0 +1,295 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.tool; + +import android.content.ContentProviderOperation; +import android.content.ContentProviderResult; +import android.content.ContentResolver; +import android.content.ContentUris; +import android.content.ContentValues; +import android.content.OperationApplicationException; +import android.database.Cursor; +import android.os.RemoteException; +import android.util.Log; + +import net.micode.notes.data.Notes; +import net.micode.notes.data.Notes.CallNote; +import net.micode.notes.data.Notes.NoteColumns; +import net.micode.notes.ui.NotesListAdapter.AppWidgetAttribute; + +import java.util.ArrayList; +import java.util.HashSet; + + +public class DataUtils { + public static final String TAG = "DataUtils"; + public static boolean batchDeleteNotes(ContentResolver resolver, HashSet ids) { + if (ids == null) { + Log.d(TAG, "the ids is null"); + return true; + } + if (ids.size() == 0) { + Log.d(TAG, "no id is in the hashset"); + return true; + } + + ArrayList operationList = new ArrayList(); + for (long id : ids) { + if(id == Notes.ID_ROOT_FOLDER) { + Log.e(TAG, "Don't delete system folder root"); + continue; + } + ContentProviderOperation.Builder builder = ContentProviderOperation + .newDelete(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, id)); + operationList.add(builder.build()); + } + try { + ContentProviderResult[] results = resolver.applyBatch(Notes.AUTHORITY, operationList); + if (results == null || results.length == 0 || results[0] == null) { + Log.d(TAG, "delete notes failed, ids:" + ids.toString()); + return false; + } + return true; + } catch (RemoteException e) { + Log.e(TAG, String.format("%s: %s", e.toString(), e.getMessage())); + } catch (OperationApplicationException e) { + Log.e(TAG, String.format("%s: %s", e.toString(), e.getMessage())); + } + return false; + } + + public static void moveNoteToFoler(ContentResolver resolver, long id, long srcFolderId, long desFolderId) { + ContentValues values = new ContentValues(); + values.put(NoteColumns.PARENT_ID, desFolderId); + values.put(NoteColumns.ORIGIN_PARENT_ID, srcFolderId); + values.put(NoteColumns.LOCAL_MODIFIED, 1); + resolver.update(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, id), values, null, null); + } + + public static boolean batchMoveToFolder(ContentResolver resolver, HashSet ids, + long folderId) { + if (ids == null) { + Log.d(TAG, "the ids is null"); + return true; + } + + ArrayList operationList = new ArrayList(); + for (long id : ids) { + ContentProviderOperation.Builder builder = ContentProviderOperation + .newUpdate(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, id)); + builder.withValue(NoteColumns.PARENT_ID, folderId); + builder.withValue(NoteColumns.LOCAL_MODIFIED, 1); + operationList.add(builder.build()); + } + + try { + ContentProviderResult[] results = resolver.applyBatch(Notes.AUTHORITY, operationList); + if (results == null || results.length == 0 || results[0] == null) { + Log.d(TAG, "delete notes failed, ids:" + ids.toString()); + return false; + } + return true; + } catch (RemoteException e) { + Log.e(TAG, String.format("%s: %s", e.toString(), e.getMessage())); + } catch (OperationApplicationException e) { + Log.e(TAG, String.format("%s: %s", e.toString(), e.getMessage())); + } + return false; + } + + /** + * Get the all folder count except system folders {@link Notes#TYPE_SYSTEM}} + */ + public static int getUserFolderCount(ContentResolver resolver) { + Cursor cursor =resolver.query(Notes.CONTENT_NOTE_URI, + new String[] { "COUNT(*)" }, + NoteColumns.TYPE + "=? AND " + NoteColumns.PARENT_ID + "<>?", + new String[] { String.valueOf(Notes.TYPE_FOLDER), String.valueOf(Notes.ID_TRASH_FOLER)}, + null); + + int count = 0; + if(cursor != null) { + if(cursor.moveToFirst()) { + try { + count = cursor.getInt(0); + } catch (IndexOutOfBoundsException e) { + Log.e(TAG, "get folder count failed:" + e.toString()); + } finally { + cursor.close(); + } + } + } + return count; + } + + public static boolean visibleInNoteDatabase(ContentResolver resolver, long noteId, int type) { + Cursor cursor = resolver.query(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, noteId), + null, + NoteColumns.TYPE + "=? AND " + NoteColumns.PARENT_ID + "<>" + Notes.ID_TRASH_FOLER, + new String [] {String.valueOf(type)}, + null); + + boolean exist = false; + if (cursor != null) { + if (cursor.getCount() > 0) { + exist = true; + } + cursor.close(); + } + return exist; + } + + public static boolean existInNoteDatabase(ContentResolver resolver, long noteId) { + Cursor cursor = resolver.query(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, noteId), + null, null, null, null); + + boolean exist = false; + if (cursor != null) { + if (cursor.getCount() > 0) { + exist = true; + } + cursor.close(); + } + return exist; + } + + public static boolean existInDataDatabase(ContentResolver resolver, long dataId) { + Cursor cursor = resolver.query(ContentUris.withAppendedId(Notes.CONTENT_DATA_URI, dataId), + null, null, null, null); + + boolean exist = false; + if (cursor != null) { + if (cursor.getCount() > 0) { + exist = true; + } + cursor.close(); + } + return exist; + } + + public static boolean checkVisibleFolderName(ContentResolver resolver, String name) { + Cursor cursor = resolver.query(Notes.CONTENT_NOTE_URI, null, + NoteColumns.TYPE + "=" + Notes.TYPE_FOLDER + + " AND " + NoteColumns.PARENT_ID + "<>" + Notes.ID_TRASH_FOLER + + " AND " + NoteColumns.SNIPPET + "=?", + new String[] { name }, null); + boolean exist = false; + if(cursor != null) { + if(cursor.getCount() > 0) { + exist = true; + } + cursor.close(); + } + return exist; + } + + public static HashSet getFolderNoteWidget(ContentResolver resolver, long folderId) { + Cursor c = resolver.query(Notes.CONTENT_NOTE_URI, + new String[] { NoteColumns.WIDGET_ID, NoteColumns.WIDGET_TYPE }, + NoteColumns.PARENT_ID + "=?", + new String[] { String.valueOf(folderId) }, + null); + + HashSet set = null; + if (c != null) { + if (c.moveToFirst()) { + set = new HashSet(); + do { + try { + AppWidgetAttribute widget = new AppWidgetAttribute(); + widget.widgetId = c.getInt(0); + widget.widgetType = c.getInt(1); + set.add(widget); + } catch (IndexOutOfBoundsException e) { + Log.e(TAG, e.toString()); + } + } while (c.moveToNext()); + } + c.close(); + } + return set; + } + + public static String getCallNumberByNoteId(ContentResolver resolver, long noteId) { + Cursor cursor = resolver.query(Notes.CONTENT_DATA_URI, + new String [] { CallNote.PHONE_NUMBER }, + CallNote.NOTE_ID + "=? AND " + CallNote.MIME_TYPE + "=?", + new String [] { String.valueOf(noteId), CallNote.CONTENT_ITEM_TYPE }, + null); + + if (cursor != null && cursor.moveToFirst()) { + try { + return cursor.getString(0); + } catch (IndexOutOfBoundsException e) { + Log.e(TAG, "Get call number fails " + e.toString()); + } finally { + cursor.close(); + } + } + return ""; + } + + public static long getNoteIdByPhoneNumberAndCallDate(ContentResolver resolver, String phoneNumber, long callDate) { + Cursor cursor = resolver.query(Notes.CONTENT_DATA_URI, + new String [] { CallNote.NOTE_ID }, + CallNote.CALL_DATE + "=? AND " + CallNote.MIME_TYPE + "=? AND PHONE_NUMBERS_EQUAL(" + + CallNote.PHONE_NUMBER + ",?)", + new String [] { String.valueOf(callDate), CallNote.CONTENT_ITEM_TYPE, phoneNumber }, + null); + + if (cursor != null) { + if (cursor.moveToFirst()) { + try { + return cursor.getLong(0); + } catch (IndexOutOfBoundsException e) { + Log.e(TAG, "Get call note id fails " + e.toString()); + } + } + cursor.close(); + } + return 0; + } + + public static String getSnippetById(ContentResolver resolver, long noteId) { + Cursor cursor = resolver.query(Notes.CONTENT_NOTE_URI, + new String [] { NoteColumns.SNIPPET }, + NoteColumns.ID + "=?", + new String [] { String.valueOf(noteId)}, + null); + + if (cursor != null) { + String snippet = ""; + if (cursor.moveToFirst()) { + snippet = cursor.getString(0); + } + cursor.close(); + return snippet; + } + throw new IllegalArgumentException("Note is not found with id: " + noteId); + } + + public static String getFormattedSnippet(String snippet) { + if (snippet != null) { + snippet = snippet.trim(); + int index = snippet.indexOf('\n'); + if (index != -1) { + snippet = snippet.substring(0, index); + } + } + return snippet; + } +} diff --git a/app/src/main/java/net/micode/notes/tool/GTaskStringUtils.java b/app/src/main/java/net/micode/notes/tool/GTaskStringUtils.java new file mode 100644 index 0000000..666b729 --- /dev/null +++ b/app/src/main/java/net/micode/notes/tool/GTaskStringUtils.java @@ -0,0 +1,113 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.tool; + +public class GTaskStringUtils { + + public final static String GTASK_JSON_ACTION_ID = "action_id"; + + public final static String GTASK_JSON_ACTION_LIST = "action_list"; + + public final static String GTASK_JSON_ACTION_TYPE = "action_type"; + + public final static String GTASK_JSON_ACTION_TYPE_CREATE = "create"; + + public final static String GTASK_JSON_ACTION_TYPE_GETALL = "get_all"; + + public final static String GTASK_JSON_ACTION_TYPE_MOVE = "move"; + + public final static String GTASK_JSON_ACTION_TYPE_UPDATE = "update"; + + public final static String GTASK_JSON_CREATOR_ID = "creator_id"; + + public final static String GTASK_JSON_CHILD_ENTITY = "child_entity"; + + public final static String GTASK_JSON_CLIENT_VERSION = "client_version"; + + public final static String GTASK_JSON_COMPLETED = "completed"; + + public final static String GTASK_JSON_CURRENT_LIST_ID = "current_list_id"; + + public final static String GTASK_JSON_DEFAULT_LIST_ID = "default_list_id"; + + public final static String GTASK_JSON_DELETED = "deleted"; + + public final static String GTASK_JSON_DEST_LIST = "dest_list"; + + public final static String GTASK_JSON_DEST_PARENT = "dest_parent"; + + public final static String GTASK_JSON_DEST_PARENT_TYPE = "dest_parent_type"; + + public final static String GTASK_JSON_ENTITY_DELTA = "entity_delta"; + + public final static String GTASK_JSON_ENTITY_TYPE = "entity_type"; + + public final static String GTASK_JSON_GET_DELETED = "get_deleted"; + + public final static String GTASK_JSON_ID = "id"; + + public final static String GTASK_JSON_INDEX = "index"; + + public final static String GTASK_JSON_LAST_MODIFIED = "last_modified"; + + public final static String GTASK_JSON_LATEST_SYNC_POINT = "latest_sync_point"; + + public final static String GTASK_JSON_LIST_ID = "list_id"; + + public final static String GTASK_JSON_LISTS = "lists"; + + public final static String GTASK_JSON_NAME = "name"; + + public final static String GTASK_JSON_NEW_ID = "new_id"; + + public final static String GTASK_JSON_NOTES = "notes"; + + public final static String GTASK_JSON_PARENT_ID = "parent_id"; + + public final static String GTASK_JSON_PRIOR_SIBLING_ID = "prior_sibling_id"; + + public final static String GTASK_JSON_RESULTS = "results"; + + public final static String GTASK_JSON_SOURCE_LIST = "source_list"; + + public final static String GTASK_JSON_TASKS = "tasks"; + + public final static String GTASK_JSON_TYPE = "type"; + + public final static String GTASK_JSON_TYPE_GROUP = "GROUP"; + + public final static String GTASK_JSON_TYPE_TASK = "TASK"; + + public final static String GTASK_JSON_USER = "user"; + + public final static String MIUI_FOLDER_PREFFIX = "[MIUI_Notes]"; + + public final static String FOLDER_DEFAULT = "Default"; + + public final static String FOLDER_CALL_NOTE = "Call_Note"; + + public final static String FOLDER_META = "METADATA"; + + public final static String META_HEAD_GTASK_ID = "meta_gid"; + + public final static String META_HEAD_NOTE = "meta_note"; + + public final static String META_HEAD_DATA = "meta_data"; + + public final static String META_NOTE_NAME = "[META INFO] DON'T UPDATE AND DELETE"; + +} diff --git a/app/src/main/java/net/micode/notes/tool/ResourceParser.java b/app/src/main/java/net/micode/notes/tool/ResourceParser.java new file mode 100644 index 0000000..1ad3ad6 --- /dev/null +++ b/app/src/main/java/net/micode/notes/tool/ResourceParser.java @@ -0,0 +1,181 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.tool; + +import android.content.Context; +import android.preference.PreferenceManager; + +import net.micode.notes.R; +import net.micode.notes.ui.NotesPreferenceActivity; + +public class ResourceParser { + + public static final int YELLOW = 0; + public static final int BLUE = 1; + public static final int WHITE = 2; + public static final int GREEN = 3; + public static final int RED = 4; + + public static final int BG_DEFAULT_COLOR = YELLOW; + + public static final int TEXT_SMALL = 0; + public static final int TEXT_MEDIUM = 1; + public static final int TEXT_LARGE = 2; + public static final int TEXT_SUPER = 3; + + public static final int BG_DEFAULT_FONT_SIZE = TEXT_MEDIUM; + + public static class NoteBgResources { + private final static int [] BG_EDIT_RESOURCES = new int [] { + R.drawable.edit_yellow, + R.drawable.edit_blue, + R.drawable.edit_white, + R.drawable.edit_green, + R.drawable.edit_red + }; + + private final static int [] BG_EDIT_TITLE_RESOURCES = new int [] { + R.drawable.edit_title_yellow, + R.drawable.edit_title_blue, + R.drawable.edit_title_white, + R.drawable.edit_title_green, + R.drawable.edit_title_red + }; + + public static int getNoteBgResource(int id) { + return BG_EDIT_RESOURCES[id]; + } + + public static int getNoteTitleBgResource(int id) { + return BG_EDIT_TITLE_RESOURCES[id]; + } + } + + public static int getDefaultBgId(Context context) { + if (PreferenceManager.getDefaultSharedPreferences(context).getBoolean( + NotesPreferenceActivity.PREFERENCE_SET_BG_COLOR_KEY, false)) { + return (int) (Math.random() * NoteBgResources.BG_EDIT_RESOURCES.length); + } else { + return BG_DEFAULT_COLOR; + } + } + + public static class NoteItemBgResources { + private final static int [] BG_FIRST_RESOURCES = new int [] { + R.drawable.list_yellow_up, + R.drawable.list_blue_up, + R.drawable.list_white_up, + R.drawable.list_green_up, + R.drawable.list_red_up + }; + + private final static int [] BG_NORMAL_RESOURCES = new int [] { + R.drawable.list_yellow_middle, + R.drawable.list_blue_middle, + R.drawable.list_white_middle, + R.drawable.list_green_middle, + R.drawable.list_red_middle + }; + + private final static int [] BG_LAST_RESOURCES = new int [] { + R.drawable.list_yellow_down, + R.drawable.list_blue_down, + R.drawable.list_white_down, + R.drawable.list_green_down, + R.drawable.list_red_down, + }; + + private final static int [] BG_SINGLE_RESOURCES = new int [] { + R.drawable.list_yellow_single, + R.drawable.list_blue_single, + R.drawable.list_white_single, + R.drawable.list_green_single, + R.drawable.list_red_single + }; + + public static int getNoteBgFirstRes(int id) { + return BG_FIRST_RESOURCES[id]; + } + + public static int getNoteBgLastRes(int id) { + return BG_LAST_RESOURCES[id]; + } + + public static int getNoteBgSingleRes(int id) { + return BG_SINGLE_RESOURCES[id]; + } + + public static int getNoteBgNormalRes(int id) { + return BG_NORMAL_RESOURCES[id]; + } + + public static int getFolderBgRes() { + return R.drawable.list_folder; + } + } + + public static class WidgetBgResources { + private final static int [] BG_2X_RESOURCES = new int [] { + R.drawable.widget_2x_yellow, + R.drawable.widget_2x_blue, + R.drawable.widget_2x_white, + R.drawable.widget_2x_green, + R.drawable.widget_2x_red, + }; + + public static int getWidget2xBgResource(int id) { + return BG_2X_RESOURCES[id]; + } + + private final static int [] BG_4X_RESOURCES = new int [] { + R.drawable.widget_4x_yellow, + R.drawable.widget_4x_blue, + R.drawable.widget_4x_white, + R.drawable.widget_4x_green, + R.drawable.widget_4x_red + }; + + public static int getWidget4xBgResource(int id) { + return BG_4X_RESOURCES[id]; + } + } + + public static class TextAppearanceResources { + private final static int [] TEXTAPPEARANCE_RESOURCES = new int [] { + R.style.TextAppearanceNormal, + R.style.TextAppearanceMedium, + R.style.TextAppearanceLarge, + R.style.TextAppearanceSuper + }; + + public static int getTexAppearanceResource(int id) { + /** + * HACKME: Fix bug of store the resource id in shared preference. + * The id may larger than the length of resources, in this case, + * return the {@link ResourceParser#BG_DEFAULT_FONT_SIZE} + */ + if (id >= TEXTAPPEARANCE_RESOURCES.length) { + return BG_DEFAULT_FONT_SIZE; + } + return TEXTAPPEARANCE_RESOURCES[id]; + } + + public static int getResourcesSize() { + return TEXTAPPEARANCE_RESOURCES.length; + } + } +} diff --git a/app/src/main/java/net/micode/notes/ui/AlarmAlertActivity.java b/app/src/main/java/net/micode/notes/ui/AlarmAlertActivity.java new file mode 100644 index 0000000..85723be --- /dev/null +++ b/app/src/main/java/net/micode/notes/ui/AlarmAlertActivity.java @@ -0,0 +1,158 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.ui; + +import android.app.Activity; +import android.app.AlertDialog; +import android.content.Context; +import android.content.DialogInterface; +import android.content.DialogInterface.OnClickListener; +import android.content.DialogInterface.OnDismissListener; +import android.content.Intent; +import android.media.AudioManager; +import android.media.MediaPlayer; +import android.media.RingtoneManager; +import android.net.Uri; +import android.os.Bundle; +import android.os.PowerManager; +import android.provider.Settings; +import android.view.Window; +import android.view.WindowManager; + +import net.micode.notes.R; +import net.micode.notes.data.Notes; +import net.micode.notes.tool.DataUtils; + +import java.io.IOException; + + +public class AlarmAlertActivity extends Activity implements OnClickListener, OnDismissListener { + private long mNoteId; + private String mSnippet; + private static final int SNIPPET_PREW_MAX_LEN = 60; + MediaPlayer mPlayer; + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + requestWindowFeature(Window.FEATURE_NO_TITLE); + + final Window win = getWindow(); + win.addFlags(WindowManager.LayoutParams.FLAG_SHOW_WHEN_LOCKED); + + if (!isScreenOn()) { + win.addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON + | WindowManager.LayoutParams.FLAG_TURN_SCREEN_ON + | WindowManager.LayoutParams.FLAG_ALLOW_LOCK_WHILE_SCREEN_ON + | WindowManager.LayoutParams.FLAG_LAYOUT_INSET_DECOR); + } + + Intent intent = getIntent(); + + try { + mNoteId = Long.valueOf(intent.getData().getPathSegments().get(1)); + mSnippet = DataUtils.getSnippetById(this.getContentResolver(), mNoteId); + mSnippet = mSnippet.length() > SNIPPET_PREW_MAX_LEN ? mSnippet.substring(0, + SNIPPET_PREW_MAX_LEN) + getResources().getString(R.string.notelist_string_info) + : mSnippet; + } catch (IllegalArgumentException e) { + e.printStackTrace(); + return; + } + + mPlayer = new MediaPlayer(); + if (DataUtils.visibleInNoteDatabase(getContentResolver(), mNoteId, Notes.TYPE_NOTE)) { + showActionDialog(); + playAlarmSound(); + } else { + finish(); + } + } + + private boolean isScreenOn() { + PowerManager pm = (PowerManager) getSystemService(Context.POWER_SERVICE); + return pm.isScreenOn(); + } + + private void playAlarmSound() { + Uri url = RingtoneManager.getActualDefaultRingtoneUri(this, RingtoneManager.TYPE_ALARM); + + int silentModeStreams = Settings.System.getInt(getContentResolver(), + Settings.System.MODE_RINGER_STREAMS_AFFECTED, 0); + + if ((silentModeStreams & (1 << AudioManager.STREAM_ALARM)) != 0) { + mPlayer.setAudioStreamType(silentModeStreams); + } else { + mPlayer.setAudioStreamType(AudioManager.STREAM_ALARM); + } + try { + mPlayer.setDataSource(this, url); + mPlayer.prepare(); + mPlayer.setLooping(true); + mPlayer.start(); + } catch (IllegalArgumentException e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } catch (SecurityException e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } catch (IllegalStateException e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } catch (IOException e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } + } + + private void showActionDialog() { + AlertDialog.Builder dialog = new AlertDialog.Builder(this); + dialog.setTitle(R.string.app_name); + dialog.setMessage(mSnippet); + dialog.setPositiveButton(R.string.notealert_ok, this); + if (isScreenOn()) { + dialog.setNegativeButton(R.string.notealert_enter, this); + } + dialog.show().setOnDismissListener(this); + } + + public void onClick(DialogInterface dialog, int which) { + switch (which) { + case DialogInterface.BUTTON_NEGATIVE: + Intent intent = new Intent(this, NoteEditActivity.class); + intent.setAction(Intent.ACTION_VIEW); + intent.putExtra(Intent.EXTRA_UID, mNoteId); + startActivity(intent); + break; + default: + break; + } + } + + public void onDismiss(DialogInterface dialog) { + stopAlarmSound(); + finish(); + } + + private void stopAlarmSound() { + if (mPlayer != null) { + mPlayer.stop(); + mPlayer.release(); + mPlayer = null; + } + } +} diff --git a/app/src/main/java/net/micode/notes/ui/AlarmInitReceiver.java b/app/src/main/java/net/micode/notes/ui/AlarmInitReceiver.java new file mode 100644 index 0000000..f221202 --- /dev/null +++ b/app/src/main/java/net/micode/notes/ui/AlarmInitReceiver.java @@ -0,0 +1,65 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.ui; + +import android.app.AlarmManager; +import android.app.PendingIntent; +import android.content.BroadcastReceiver; +import android.content.ContentUris; +import android.content.Context; +import android.content.Intent; +import android.database.Cursor; + +import net.micode.notes.data.Notes; +import net.micode.notes.data.Notes.NoteColumns; + + +public class AlarmInitReceiver extends BroadcastReceiver { + + private static final String [] PROJECTION = new String [] { + NoteColumns.ID, + NoteColumns.ALERTED_DATE + }; + + private static final int COLUMN_ID = 0; + private static final int COLUMN_ALERTED_DATE = 1; + + @Override + public void onReceive(Context context, Intent intent) { + long currentDate = System.currentTimeMillis(); + Cursor c = context.getContentResolver().query(Notes.CONTENT_NOTE_URI, + PROJECTION, + NoteColumns.ALERTED_DATE + ">? AND " + NoteColumns.TYPE + "=" + Notes.TYPE_NOTE, + new String[] { String.valueOf(currentDate) }, + null); + + if (c != null) { + if (c.moveToFirst()) { + do { + long alertDate = c.getLong(COLUMN_ALERTED_DATE); + Intent sender = new Intent(context, AlarmReceiver.class); + sender.setData(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, c.getLong(COLUMN_ID))); + PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, sender, 0); + AlarmManager alermManager = (AlarmManager) context + .getSystemService(Context.ALARM_SERVICE); + alermManager.set(AlarmManager.RTC_WAKEUP, alertDate, pendingIntent); + } while (c.moveToNext()); + } + c.close(); + } + } +} diff --git a/app/src/main/java/net/micode/notes/ui/AlarmReceiver.java b/app/src/main/java/net/micode/notes/ui/AlarmReceiver.java new file mode 100644 index 0000000..54e503b --- /dev/null +++ b/app/src/main/java/net/micode/notes/ui/AlarmReceiver.java @@ -0,0 +1,30 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.ui; + +import android.content.BroadcastReceiver; +import android.content.Context; +import android.content.Intent; + +public class AlarmReceiver extends BroadcastReceiver { + @Override + public void onReceive(Context context, Intent intent) { + intent.setClass(context, AlarmAlertActivity.class); + intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); + context.startActivity(intent); + } +} diff --git a/app/src/main/java/net/micode/notes/ui/DateTimePicker.java b/app/src/main/java/net/micode/notes/ui/DateTimePicker.java new file mode 100644 index 0000000..496b0cd --- /dev/null +++ b/app/src/main/java/net/micode/notes/ui/DateTimePicker.java @@ -0,0 +1,485 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.ui; + +import java.text.DateFormatSymbols; +import java.util.Calendar; + +import net.micode.notes.R; + + +import android.content.Context; +import android.text.format.DateFormat; +import android.view.View; +import android.widget.FrameLayout; +import android.widget.NumberPicker; + +public class DateTimePicker extends FrameLayout { + + private static final boolean DEFAULT_ENABLE_STATE = true; + + private static final int HOURS_IN_HALF_DAY = 12; + private static final int HOURS_IN_ALL_DAY = 24; + private static final int DAYS_IN_ALL_WEEK = 7; + private static final int DATE_SPINNER_MIN_VAL = 0; + private static final int DATE_SPINNER_MAX_VAL = DAYS_IN_ALL_WEEK - 1; + private static final int HOUR_SPINNER_MIN_VAL_24_HOUR_VIEW = 0; + private static final int HOUR_SPINNER_MAX_VAL_24_HOUR_VIEW = 23; + private static final int HOUR_SPINNER_MIN_VAL_12_HOUR_VIEW = 1; + private static final int HOUR_SPINNER_MAX_VAL_12_HOUR_VIEW = 12; + private static final int MINUT_SPINNER_MIN_VAL = 0; + private static final int MINUT_SPINNER_MAX_VAL = 59; + private static final int AMPM_SPINNER_MIN_VAL = 0; + private static final int AMPM_SPINNER_MAX_VAL = 1; + + private final NumberPicker mDateSpinner; + private final NumberPicker mHourSpinner; + private final NumberPicker mMinuteSpinner; + private final NumberPicker mAmPmSpinner; + private Calendar mDate; + + private String[] mDateDisplayValues = new String[DAYS_IN_ALL_WEEK]; + + private boolean mIsAm; + + private boolean mIs24HourView; + + private boolean mIsEnabled = DEFAULT_ENABLE_STATE; + + private boolean mInitialising; + + private OnDateTimeChangedListener mOnDateTimeChangedListener; + + private NumberPicker.OnValueChangeListener mOnDateChangedListener = new NumberPicker.OnValueChangeListener() { + @Override + public void onValueChange(NumberPicker picker, int oldVal, int newVal) { + mDate.add(Calendar.DAY_OF_YEAR, newVal - oldVal); + updateDateControl(); + onDateTimeChanged(); + } + }; + + private NumberPicker.OnValueChangeListener mOnHourChangedListener = new NumberPicker.OnValueChangeListener() { + @Override + public void onValueChange(NumberPicker picker, int oldVal, int newVal) { + boolean isDateChanged = false; + Calendar cal = Calendar.getInstance(); + if (!mIs24HourView) { + if (!mIsAm && oldVal == HOURS_IN_HALF_DAY - 1 && newVal == HOURS_IN_HALF_DAY) { + cal.setTimeInMillis(mDate.getTimeInMillis()); + cal.add(Calendar.DAY_OF_YEAR, 1); + isDateChanged = true; + } else if (mIsAm && oldVal == HOURS_IN_HALF_DAY && newVal == HOURS_IN_HALF_DAY - 1) { + cal.setTimeInMillis(mDate.getTimeInMillis()); + cal.add(Calendar.DAY_OF_YEAR, -1); + isDateChanged = true; + } + if (oldVal == HOURS_IN_HALF_DAY - 1 && newVal == HOURS_IN_HALF_DAY || + oldVal == HOURS_IN_HALF_DAY && newVal == HOURS_IN_HALF_DAY - 1) { + mIsAm = !mIsAm; + updateAmPmControl(); + } + } else { + if (oldVal == HOURS_IN_ALL_DAY - 1 && newVal == 0) { + cal.setTimeInMillis(mDate.getTimeInMillis()); + cal.add(Calendar.DAY_OF_YEAR, 1); + isDateChanged = true; + } else if (oldVal == 0 && newVal == HOURS_IN_ALL_DAY - 1) { + cal.setTimeInMillis(mDate.getTimeInMillis()); + cal.add(Calendar.DAY_OF_YEAR, -1); + isDateChanged = true; + } + } + int newHour = mHourSpinner.getValue() % HOURS_IN_HALF_DAY + (mIsAm ? 0 : HOURS_IN_HALF_DAY); + mDate.set(Calendar.HOUR_OF_DAY, newHour); + onDateTimeChanged(); + if (isDateChanged) { + setCurrentYear(cal.get(Calendar.YEAR)); + setCurrentMonth(cal.get(Calendar.MONTH)); + setCurrentDay(cal.get(Calendar.DAY_OF_MONTH)); + } + } + }; + + private NumberPicker.OnValueChangeListener mOnMinuteChangedListener = new NumberPicker.OnValueChangeListener() { + @Override + public void onValueChange(NumberPicker picker, int oldVal, int newVal) { + int minValue = mMinuteSpinner.getMinValue(); + int maxValue = mMinuteSpinner.getMaxValue(); + int offset = 0; + if (oldVal == maxValue && newVal == minValue) { + offset += 1; + } else if (oldVal == minValue && newVal == maxValue) { + offset -= 1; + } + if (offset != 0) { + mDate.add(Calendar.HOUR_OF_DAY, offset); + mHourSpinner.setValue(getCurrentHour()); + updateDateControl(); + int newHour = getCurrentHourOfDay(); + if (newHour >= HOURS_IN_HALF_DAY) { + mIsAm = false; + updateAmPmControl(); + } else { + mIsAm = true; + updateAmPmControl(); + } + } + mDate.set(Calendar.MINUTE, newVal); + onDateTimeChanged(); + } + }; + + private NumberPicker.OnValueChangeListener mOnAmPmChangedListener = new NumberPicker.OnValueChangeListener() { + @Override + public void onValueChange(NumberPicker picker, int oldVal, int newVal) { + mIsAm = !mIsAm; + if (mIsAm) { + mDate.add(Calendar.HOUR_OF_DAY, -HOURS_IN_HALF_DAY); + } else { + mDate.add(Calendar.HOUR_OF_DAY, HOURS_IN_HALF_DAY); + } + updateAmPmControl(); + onDateTimeChanged(); + } + }; + + public interface OnDateTimeChangedListener { + void onDateTimeChanged(DateTimePicker view, int year, int month, + int dayOfMonth, int hourOfDay, int minute); + } + + public DateTimePicker(Context context) { + this(context, System.currentTimeMillis()); + } + + public DateTimePicker(Context context, long date) { + this(context, date, DateFormat.is24HourFormat(context)); + } + + public DateTimePicker(Context context, long date, boolean is24HourView) { + super(context); + mDate = Calendar.getInstance(); + mInitialising = true; + mIsAm = getCurrentHourOfDay() >= HOURS_IN_HALF_DAY; + inflate(context, R.layout.datetime_picker, this); + + mDateSpinner = (NumberPicker) findViewById(R.id.date); + mDateSpinner.setMinValue(DATE_SPINNER_MIN_VAL); + mDateSpinner.setMaxValue(DATE_SPINNER_MAX_VAL); + mDateSpinner.setOnValueChangedListener(mOnDateChangedListener); + + mHourSpinner = (NumberPicker) findViewById(R.id.hour); + mHourSpinner.setOnValueChangedListener(mOnHourChangedListener); + mMinuteSpinner = (NumberPicker) findViewById(R.id.minute); + mMinuteSpinner.setMinValue(MINUT_SPINNER_MIN_VAL); + mMinuteSpinner.setMaxValue(MINUT_SPINNER_MAX_VAL); + mMinuteSpinner.setOnLongPressUpdateInterval(100); + mMinuteSpinner.setOnValueChangedListener(mOnMinuteChangedListener); + + String[] stringsForAmPm = new DateFormatSymbols().getAmPmStrings(); + mAmPmSpinner = (NumberPicker) findViewById(R.id.amPm); + mAmPmSpinner.setMinValue(AMPM_SPINNER_MIN_VAL); + mAmPmSpinner.setMaxValue(AMPM_SPINNER_MAX_VAL); + mAmPmSpinner.setDisplayedValues(stringsForAmPm); + mAmPmSpinner.setOnValueChangedListener(mOnAmPmChangedListener); + + // update controls to initial state + updateDateControl(); + updateHourControl(); + updateAmPmControl(); + + set24HourView(is24HourView); + + // set to current time + setCurrentDate(date); + + setEnabled(isEnabled()); + + // set the content descriptions + mInitialising = false; + } + + @Override + public void setEnabled(boolean enabled) { + if (mIsEnabled == enabled) { + return; + } + super.setEnabled(enabled); + mDateSpinner.setEnabled(enabled); + mMinuteSpinner.setEnabled(enabled); + mHourSpinner.setEnabled(enabled); + mAmPmSpinner.setEnabled(enabled); + mIsEnabled = enabled; + } + + @Override + public boolean isEnabled() { + return mIsEnabled; + } + + /** + * Get the current date in millis + * + * @return the current date in millis + */ + public long getCurrentDateInTimeMillis() { + return mDate.getTimeInMillis(); + } + + /** + * Set the current date + * + * @param date The current date in millis + */ + public void setCurrentDate(long date) { + Calendar cal = Calendar.getInstance(); + cal.setTimeInMillis(date); + setCurrentDate(cal.get(Calendar.YEAR), cal.get(Calendar.MONTH), cal.get(Calendar.DAY_OF_MONTH), + cal.get(Calendar.HOUR_OF_DAY), cal.get(Calendar.MINUTE)); + } + + /** + * Set the current date + * + * @param year The current year + * @param month The current month + * @param dayOfMonth The current dayOfMonth + * @param hourOfDay The current hourOfDay + * @param minute The current minute + */ + public void setCurrentDate(int year, int month, + int dayOfMonth, int hourOfDay, int minute) { + setCurrentYear(year); + setCurrentMonth(month); + setCurrentDay(dayOfMonth); + setCurrentHour(hourOfDay); + setCurrentMinute(minute); + } + + /** + * Get current year + * + * @return The current year + */ + public int getCurrentYear() { + return mDate.get(Calendar.YEAR); + } + + /** + * Set current year + * + * @param year The current year + */ + public void setCurrentYear(int year) { + if (!mInitialising && year == getCurrentYear()) { + return; + } + mDate.set(Calendar.YEAR, year); + updateDateControl(); + onDateTimeChanged(); + } + + /** + * Get current month in the year + * + * @return The current month in the year + */ + public int getCurrentMonth() { + return mDate.get(Calendar.MONTH); + } + + /** + * Set current month in the year + * + * @param month The month in the year + */ + public void setCurrentMonth(int month) { + if (!mInitialising && month == getCurrentMonth()) { + return; + } + mDate.set(Calendar.MONTH, month); + updateDateControl(); + onDateTimeChanged(); + } + + /** + * Get current day of the month + * + * @return The day of the month + */ + public int getCurrentDay() { + return mDate.get(Calendar.DAY_OF_MONTH); + } + + /** + * Set current day of the month + * + * @param dayOfMonth The day of the month + */ + public void setCurrentDay(int dayOfMonth) { + if (!mInitialising && dayOfMonth == getCurrentDay()) { + return; + } + mDate.set(Calendar.DAY_OF_MONTH, dayOfMonth); + updateDateControl(); + onDateTimeChanged(); + } + + /** + * Get current hour in 24 hour mode, in the range (0~23) + * @return The current hour in 24 hour mode + */ + public int getCurrentHourOfDay() { + return mDate.get(Calendar.HOUR_OF_DAY); + } + + private int getCurrentHour() { + if (mIs24HourView){ + return getCurrentHourOfDay(); + } else { + int hour = getCurrentHourOfDay(); + if (hour > HOURS_IN_HALF_DAY) { + return hour - HOURS_IN_HALF_DAY; + } else { + return hour == 0 ? HOURS_IN_HALF_DAY : hour; + } + } + } + + /** + * Set current hour in 24 hour mode, in the range (0~23) + * + * @param hourOfDay + */ + public void setCurrentHour(int hourOfDay) { + if (!mInitialising && hourOfDay == getCurrentHourOfDay()) { + return; + } + mDate.set(Calendar.HOUR_OF_DAY, hourOfDay); + if (!mIs24HourView) { + if (hourOfDay >= HOURS_IN_HALF_DAY) { + mIsAm = false; + if (hourOfDay > HOURS_IN_HALF_DAY) { + hourOfDay -= HOURS_IN_HALF_DAY; + } + } else { + mIsAm = true; + if (hourOfDay == 0) { + hourOfDay = HOURS_IN_HALF_DAY; + } + } + updateAmPmControl(); + } + mHourSpinner.setValue(hourOfDay); + onDateTimeChanged(); + } + + /** + * Get currentMinute + * + * @return The Current Minute + */ + public int getCurrentMinute() { + return mDate.get(Calendar.MINUTE); + } + + /** + * Set current minute + */ + public void setCurrentMinute(int minute) { + if (!mInitialising && minute == getCurrentMinute()) { + return; + } + mMinuteSpinner.setValue(minute); + mDate.set(Calendar.MINUTE, minute); + onDateTimeChanged(); + } + + /** + * @return true if this is in 24 hour view else false. + */ + public boolean is24HourView () { + return mIs24HourView; + } + + /** + * Set whether in 24 hour or AM/PM mode. + * + * @param is24HourView True for 24 hour mode. False for AM/PM mode. + */ + public void set24HourView(boolean is24HourView) { + if (mIs24HourView == is24HourView) { + return; + } + mIs24HourView = is24HourView; + mAmPmSpinner.setVisibility(is24HourView ? View.GONE : View.VISIBLE); + int hour = getCurrentHourOfDay(); + updateHourControl(); + setCurrentHour(hour); + updateAmPmControl(); + } + + private void updateDateControl() { + Calendar cal = Calendar.getInstance(); + cal.setTimeInMillis(mDate.getTimeInMillis()); + cal.add(Calendar.DAY_OF_YEAR, -DAYS_IN_ALL_WEEK / 2 - 1); + mDateSpinner.setDisplayedValues(null); + for (int i = 0; i < DAYS_IN_ALL_WEEK; ++i) { + cal.add(Calendar.DAY_OF_YEAR, 1); + mDateDisplayValues[i] = (String) DateFormat.format("MM.dd EEEE", cal); + } + mDateSpinner.setDisplayedValues(mDateDisplayValues); + mDateSpinner.setValue(DAYS_IN_ALL_WEEK / 2); + mDateSpinner.invalidate(); + } + + private void updateAmPmControl() { + if (mIs24HourView) { + mAmPmSpinner.setVisibility(View.GONE); + } else { + int index = mIsAm ? Calendar.AM : Calendar.PM; + mAmPmSpinner.setValue(index); + mAmPmSpinner.setVisibility(View.VISIBLE); + } + } + + private void updateHourControl() { + if (mIs24HourView) { + mHourSpinner.setMinValue(HOUR_SPINNER_MIN_VAL_24_HOUR_VIEW); + mHourSpinner.setMaxValue(HOUR_SPINNER_MAX_VAL_24_HOUR_VIEW); + } else { + mHourSpinner.setMinValue(HOUR_SPINNER_MIN_VAL_12_HOUR_VIEW); + mHourSpinner.setMaxValue(HOUR_SPINNER_MAX_VAL_12_HOUR_VIEW); + } + } + + /** + * Set the callback that indicates the 'Set' button has been pressed. + * @param callback the callback, if null will do nothing + */ + public void setOnDateTimeChangedListener(OnDateTimeChangedListener callback) { + mOnDateTimeChangedListener = callback; + } + + private void onDateTimeChanged() { + if (mOnDateTimeChangedListener != null) { + mOnDateTimeChangedListener.onDateTimeChanged(this, getCurrentYear(), + getCurrentMonth(), getCurrentDay(), getCurrentHourOfDay(), getCurrentMinute()); + } + } +} diff --git a/app/src/main/java/net/micode/notes/ui/DateTimePickerDialog.java b/app/src/main/java/net/micode/notes/ui/DateTimePickerDialog.java new file mode 100644 index 0000000..a15dcc0 --- /dev/null +++ b/app/src/main/java/net/micode/notes/ui/DateTimePickerDialog.java @@ -0,0 +1,129 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.ui; + +import java.util.Calendar; + +import net.micode.notes.R; +import net.micode.notes.ui.DateTimePicker; +import net.micode.notes.ui.DateTimePicker.OnDateTimeChangedListener; + +import android.app.AlertDialog; +import android.content.Context; +import android.content.DialogInterface; +import android.content.DialogInterface.OnClickListener; +import android.text.format.DateFormat; +import android.text.format.DateUtils; + +/** + * 类:时间日期选择器对话框 + */ +public class DateTimePickerDialog extends AlertDialog implements OnClickListener { + //语句:定义日期 + private Calendar mDate = Calendar.getInstance(); + //语句:是否为24小时视图 + private boolean mIs24HourView; + //语句:定义时间日期变化监听器 + private OnDateTimeSetListener mOnDateTimeSetListener; + //语句:定义时间日期选择器 + private DateTimePicker mDateTimePicker; + + /** + * 接口:日期时间设置监听器 + */ + public interface OnDateTimeSetListener { + void OnDateTimeSet(AlertDialog dialog, long date); + } + + /** + * 方法:构造方法,构建日期时间选择对话框 + * @param context + * @param date + */ + public DateTimePickerDialog(Context context, long date) { + super(context); + mDateTimePicker = new DateTimePicker(context); + //语句:设置视图为日期时间选择器 + setView(mDateTimePicker); + //方法:实例化时间日期变化监听器 + mDateTimePicker.setOnDateTimeChangedListener(new OnDateTimeChangedListener() { + public void onDateTimeChanged(DateTimePicker view, int year, int month, + int dayOfMonth, int hourOfDay, int minute) { + mDate.set(Calendar.YEAR, year); + mDate.set(Calendar.MONTH, month); + mDate.set(Calendar.DAY_OF_MONTH, dayOfMonth); + mDate.set(Calendar.HOUR_OF_DAY, hourOfDay); + mDate.set(Calendar.MINUTE, minute); + updateTitle(mDate.getTimeInMillis()); + } + }); + //设置日期的毫秒级时间 + mDate.setTimeInMillis(date); + //语句:将秒数设置为0 + mDate.set(Calendar.SECOND, 0); + mDateTimePicker.setCurrentDate(mDate.getTimeInMillis()); + //语句:设置对话框的按钮 + setButton(context.getString(R.string.datetime_dialog_ok), this); + setButton2(context.getString(R.string.datetime_dialog_cancel), (OnClickListener)null); + //语句:设置为24小时视图 + set24HourView(DateFormat.is24HourFormat(this.getContext())); + //语句:更新标题上的时间 + updateTitle(mDate.getTimeInMillis()); + } + + /** + * 方法:设置24小时视图 + * @param is24HourView + */ + public void set24HourView(boolean is24HourView) { + mIs24HourView = is24HourView; + } + + /** + * 方法:设置日期时间监听器 + * @param callBack + */ + public void setOnDateTimeSetListener(OnDateTimeSetListener callBack) { + mOnDateTimeSetListener = callBack; + } + + /** + * 方法:更新对话框的标题 + * @param date + */ + private void updateTitle(long date) { + int flag = + DateUtils.FORMAT_SHOW_YEAR | + DateUtils.FORMAT_SHOW_DATE | + DateUtils.FORMAT_SHOW_TIME; + flag |= mIs24HourView ? DateUtils.FORMAT_24HOUR : DateUtils.FORMAT_24HOUR; + //设置标题 + setTitle(DateUtils.formatDateTime(this.getContext(), date, flag)); + } + + /** + * 方法:重载监听点击事件的方法 + * @param arg0 + * @param arg1 + */ + public void onClick(DialogInterface arg0, int arg1) { + if (mOnDateTimeSetListener != null) { + mOnDateTimeSetListener.OnDateTimeSet(this, mDate.getTimeInMillis()); + } + } + +} \ No newline at end of file diff --git a/app/src/main/java/net/micode/notes/ui/DropdownMenu.java b/app/src/main/java/net/micode/notes/ui/DropdownMenu.java new file mode 100644 index 0000000..45f4beb --- /dev/null +++ b/app/src/main/java/net/micode/notes/ui/DropdownMenu.java @@ -0,0 +1,75 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.ui; + +import android.content.Context; +import android.view.Menu; +import android.view.MenuItem; +import android.view.View; +import android.view.View.OnClickListener; +import android.widget.Button; +import android.widget.PopupMenu; +import android.widget.PopupMenu.OnMenuItemClickListener; + +import net.micode.notes.R; + +public class DropdownMenu { + //语句:定义按钮控件 + private Button mButton; + //语句:定义弹出式菜单 + private PopupMenu mPopupMenu; + //语句:定义菜单 + private Menu mMenu; + + /** + * 方法:下拉菜单的构造方法 + * @param context + * @param button + * @param menuId + */ + public DropdownMenu(Context context, Button button, int menuId) { + mButton = button; + //语句:设置其背景资源为下拉菜单的图标 + mButton.setBackgroundResource(R.drawable.dropdown_icon); + //语句:实例化一个弹出式菜单 + mPopupMenu = new PopupMenu(context, mButton); + //语句:获得弹出式菜单的菜单项 + mMenu = mPopupMenu.getMenu(); + //语句:使用菜单项填充弹出式菜单的视图 + mPopupMenu.getMenuInflater().inflate(menuId, mMenu); + mButton.setOnClickListener(new OnClickListener() { + public void onClick(View v) { + mPopupMenu.show(); + } + }); //方法:调用mButton的setonClickListener方法,实例化一个点击事件监听器,如果监听到点击动作则显示菜单 + } + + //方法:设置下拉菜单的点击监听方法 + public void setOnDropdownMenuItemClickListener(OnMenuItemClickListener listener) { + if (mPopupMenu != null) { + mPopupMenu.setOnMenuItemClickListener(listener); + } + } + //方法:查询菜单项 + public MenuItem findItem(int id) { + return mMenu.findItem(id); + } + //方法:设置标题 + public void setTitle(CharSequence title) { + mButton.setText(title); + } +} diff --git a/app/src/main/java/net/micode/notes/ui/FoldersListAdapter.java b/app/src/main/java/net/micode/notes/ui/FoldersListAdapter.java new file mode 100644 index 0000000..c084119 --- /dev/null +++ b/app/src/main/java/net/micode/notes/ui/FoldersListAdapter.java @@ -0,0 +1,94 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.ui; + +import android.content.Context; +import android.database.Cursor; +import android.view.View; +import android.view.ViewGroup; +import android.widget.CursorAdapter; +import android.widget.LinearLayout; +import android.widget.TextView; + +import net.micode.notes.R; +import net.micode.notes.data.Notes; +import net.micode.notes.data.Notes.NoteColumns; + +/** + * 文件夹列表适配器,用于显示文件夹列表的视图 + * @version v1.0 + * @author www.micode.net + */ +public class FoldersListAdapter extends CursorAdapter { + // + public static final String [] PROJECTION = { + NoteColumns.ID, + NoteColumns.SNIPPET + }; + //语句:定义常量,文件夹ID栏编号 + public static final int ID_COLUMN = 0; + //语句:定义常量,文件夹名称栏编号 + public static final int NAME_COLUMN = 1; + + public FoldersListAdapter(Context context, Cursor c) { + super(context, c); + // TODO Auto-generated constructor stub + } + + //方法:建立新视图,返回创建的文件夹列表 + @Override + public View newView(Context context, Cursor cursor, ViewGroup parent) { + return new FolderListItem(context); + } + + @Override + public void bindView(View view, Context context, Cursor cursor) { + //语句块:如果参数视图为文件夹视图的实例,根据当前游标的ID绑定相应文件夹的视图 + if (view instanceof FolderListItem) { + String folderName = (cursor.getLong(ID_COLUMN) == Notes.ID_ROOT_FOLDER) ? context + .getString(R.string.menu_move_parent_folder) : cursor.getString(NAME_COLUMN); + //语句:绑定文件夹视图 + ((FolderListItem) view).bind(folderName); + } + } + + //方法:获取文件夹名称 + public String getFolderName(Context context, int position) { + //语句:获取当前游标 + Cursor cursor = (Cursor) getItem(position); + //语句:选定当前文件夹 + return (cursor.getLong(ID_COLUMN) == Notes.ID_ROOT_FOLDER) ? context + .getString(R.string.menu_move_parent_folder) : cursor.getString(NAME_COLUMN); + } + + //类:文件夹 + private class FolderListItem extends LinearLayout { + private TextView mName; + + //方法:FolderListItem的构造方法,使用folder_list_item布局填充当前界面 + public FolderListItem(Context context) { + super(context); + inflate(context, R.layout.folder_list_item, this); + mName = (TextView) findViewById(R.id.tv_folder_name); + } + //方法:绑定文件夹名称 + public void bind(String name) { + mName.setText(name); + } + } + +} diff --git a/app/src/main/java/net/micode/notes/ui/NoteEditActivity.java b/app/src/main/java/net/micode/notes/ui/NoteEditActivity.java new file mode 100644 index 0000000..6fdc342 --- /dev/null +++ b/app/src/main/java/net/micode/notes/ui/NoteEditActivity.java @@ -0,0 +1,1475 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.ui; + +import android.app.Activity; +import android.app.AlarmManager; +import android.app.AlertDialog; +import android.app.PendingIntent; +import android.app.SearchManager; +import android.appwidget.AppWidgetManager; +import android.content.ContentUris; +import android.content.Context; +import android.content.DialogInterface; +import android.content.Intent; +import android.content.SharedPreferences; +import android.graphics.Paint; +import android.os.Bundle; +import android.preference.PreferenceManager; +import android.text.Editable; +import android.text.Spannable; +import android.text.SpannableString; +import android.text.TextUtils; +import android.text.TextWatcher; +import android.text.format.DateUtils; +import android.text.style.BackgroundColorSpan; +import android.util.Log; +import android.view.LayoutInflater; +import android.view.Menu; +import android.view.MenuItem; +import android.view.MotionEvent; +import android.view.View; +import android.view.View.OnClickListener; +import android.view.ViewGroup; +import android.view.WindowManager; +import android.widget.CheckBox; +import android.widget.CompoundButton; +import android.widget.CompoundButton.OnCheckedChangeListener; +import android.widget.EditText; +import android.widget.ImageView; +import android.widget.LinearLayout; +import android.widget.RatingBar; +import android.widget.RelativeLayout; +import android.widget.TextView; +import android.widget.Toast; + +import net.micode.notes.R; +import net.micode.notes.data.Notes; +import net.micode.notes.data.Notes.TextNote; +import net.micode.notes.model.WorkingNote; +import net.micode.notes.model.WorkingNote.NoteSettingChangedListener; +import net.micode.notes.tool.DataUtils; +import net.micode.notes.tool.ResourceParser; +import net.micode.notes.tool.ResourceParser.TextAppearanceResources; +import net.micode.notes.ui.DateTimePickerDialog.OnDateTimeSetListener; +import net.micode.notes.ui.NoteEditText.OnTextViewChangeListener; +import net.micode.notes.ui.PasswordView; +import net.micode.notes.widget.NoteWidgetProvider_2x; +import net.micode.notes.widget.NoteWidgetProvider_4x; + +import java.util.HashMap; +import java.util.HashSet; +import java.util.Map; +import java.util.regex.Matcher; +import java.util.regex.Pattern; + +/** + * 该类实现了对当前便签界面进行编辑功能,继承了父类Activity并实现了接口,封装有方法39个 + * @author www.micode.net + */ +public class NoteEditActivity extends Activity implements OnClickListener, + NoteSettingChangedListener, OnTextViewChangeListener { + /** + * 该私有类为便签编辑界面的标题栏部分 + */ + private class HeadViewHolder { + //修改时间(文本视图) + public TextView tvModified; + //提醒标志(图像视图) + public ImageView ivAlertIcon; + //提醒时间(文本视图) + public TextView tvAlertDate; + //设置背景颜色(图像视图) + public ImageView ibSetBgColor; + } + + /** + * 常量,实现选择背景颜色按钮(未选择)和资源解析器中的颜色ID对应 + */ + private static final Map sBgSelectorBtnsMap = new HashMap(); + static { + sBgSelectorBtnsMap.put(R.id.iv_bg_yellow, ResourceParser.YELLOW); + sBgSelectorBtnsMap.put(R.id.iv_bg_red, ResourceParser.RED); + sBgSelectorBtnsMap.put(R.id.iv_bg_blue, ResourceParser.BLUE); + sBgSelectorBtnsMap.put(R.id.iv_bg_green, ResourceParser.GREEN); + sBgSelectorBtnsMap.put(R.id.iv_bg_white, ResourceParser.WHITE); + } + + /** + * 常量,实现资源解析器中的颜色ID与背景颜色选择选择按钮(已选择)对应 + */ + private static final Map sBgSelectorSelectionMap = new HashMap(); + static { + sBgSelectorSelectionMap.put(ResourceParser.YELLOW, R.id.iv_bg_yellow_select); + sBgSelectorSelectionMap.put(ResourceParser.RED, R.id.iv_bg_red_select); + sBgSelectorSelectionMap.put(ResourceParser.BLUE, R.id.iv_bg_blue_select); + sBgSelectorSelectionMap.put(ResourceParser.GREEN, R.id.iv_bg_green_select); + sBgSelectorSelectionMap.put(ResourceParser.WHITE, R.id.iv_bg_white_select); + } + + /** + * 常量,实现字体大小按钮(未选择)和资源解析器中的字号ID对应 + */ + private static final Map sFontSizeBtnsMap = new HashMap(); + static { + sFontSizeBtnsMap.put(R.id.ll_font_large, ResourceParser.TEXT_LARGE); + sFontSizeBtnsMap.put(R.id.ll_font_small, ResourceParser.TEXT_SMALL); + sFontSizeBtnsMap.put(R.id.ll_font_normal, ResourceParser.TEXT_MEDIUM); + sFontSizeBtnsMap.put(R.id.ll_font_super, ResourceParser.TEXT_SUPER); + } + + /** + * 常量,实现资源解析器中字号ID与字体大小按钮(已选择)对应 + */ + private static final Map sFontSelectorSelectionMap = new HashMap(); + static { + sFontSelectorSelectionMap.put(ResourceParser.TEXT_LARGE, R.id.iv_large_select); + sFontSelectorSelectionMap.put(ResourceParser.TEXT_SMALL, R.id.iv_small_select); + sFontSelectorSelectionMap.put(ResourceParser.TEXT_MEDIUM, R.id.iv_medium_select); + sFontSelectorSelectionMap.put(ResourceParser.TEXT_SUPER, R.id.iv_super_select); + } + //常量标识 + private static final String TAG = "NoteEditActivity"; + + //便签编辑标题栏 + private HeadViewHolder mNoteHeaderHolder; + + //便签的顶部视图块 + private View mHeadViewPanel; + + //便签的背景色选择器 + private View mNoteBgColorSelector; + + //便签的字体大小选择器 + private View mFontSizeSelector; + + //便签编辑器 + private EditText mNoteEditor; + + //便签编辑块 + private View mNoteEditorPanel; + + //定义私有变量 活动便签 + private WorkingNote mWorkingNote; + + //定义私有变量 共享设置 用来保存配置参数 + private SharedPreferences mSharedPrefs; + //定义私有变量 字体大小Id + private int mFontSizeId; + + //定义常量 字体大小设置 + private static final String PREFERENCE_FONT_SIZE = "pref_font_size"; + + private static final int SHORTCUT_ICON_TITLE_MAX_LEN = 10; + + //定义字符串常量 已标记 + public static final String TAG_CHECKED = String.valueOf('\u221A'); + //定义字符串常量 未标记 + public static final String TAG_UNCHECKED = String.valueOf('\u25A1'); + + //线性布局,用于编辑文本 + private LinearLayout mEditTextList; + //用户请求 + private String mUserQuery; + //正则表达式模式 + private Pattern mPattern; + + /** + * 重写Activity类的onCreate方法 + * @param savedInstanceState + */ + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + + this.setContentView(R.layout.note_edit); + + + //如果未保存实例状态且当前Activity未初始化完成,则结束当前Activity + if (savedInstanceState == null && !initActivityState(getIntent())) { + finish(); + return; + } + initResources(); + } + + /** + * Current activity may be killed when the memory is low. Once it is killed, for another time + * user load this activity, we should restore the former state + * 当当前活动界面在释放内存时被关闭,则再次调用该Activity时依据保存的实例恢复到被关闭之前的状态 + */ + @Override + protected void onRestoreInstanceState(Bundle savedInstanceState) { + super.onRestoreInstanceState(savedInstanceState); + /** + * 如果保存了关闭前的实例状态且其中包含着便签标识符,则将该标识符添加到初始化Activity的Intent中 + */ + if (savedInstanceState != null && savedInstanceState.containsKey(Intent.EXTRA_UID)) { + Intent intent = new Intent(Intent.ACTION_VIEW); + intent.putExtra(Intent.EXTRA_UID, savedInstanceState.getLong(Intent.EXTRA_UID)); + if (!initActivityState(intent)) { + finish(); + return; + } + Log.d(TAG, "Restoring from killed activity"); + } + } + + /** + * 初始化Activity的状态 + * @param intent 创建时传递给该Activity的intent参数,用于描述让该Activity完成的动作、附加属性信息 + * @return boolean 返回是否成功初始化了活动状态 + */ + private boolean initActivityState(Intent intent) { + /** + * If the user specified the {@link Intent#ACTION_VIEW} but not provided with id, + * then jump to the NotesListActivity + */ + mWorkingNote = null; + /** + * 判断初始化该Activity的Intent所包含的action是ACTION_VIEW还是ACTION_INSERT_OR_EDIT,然后进行不同的操作 + */ + if (TextUtils.equals(Intent.ACTION_VIEW, intent.getAction())) { + //当前Activity获取intent中的附加信息(字符串)EXTRA_UID标识noteId,默认值为0 + long noteId = intent.getLongExtra(Intent.EXTRA_UID, 0); + //初始化用户请求为空字符串 + mUserQuery = ""; + + /** + * Starting from the searched result + */ + if (intent.hasExtra(SearchManager.EXTRA_DATA_KEY)) { + //将查找到的便签标识符转化为long类型,保存在变量noteId中 + noteId = Long.parseLong(intent.getStringExtra(SearchManager.EXTRA_DATA_KEY)); + //将用户请求的字符串保存在变量mUserQuery中 + mUserQuery = intent.getStringExtra(SearchManager.USER_QUERY); + } + /** + * 如果在数据库中没有查找到相应的便签标识符,则切换到文件夹列表界面 + */ + if (!DataUtils.visibleInNoteDatabase(getContentResolver(), noteId, Notes.TYPE_NOTE)) { + //设置Intent目的组件为NotesListActivity + Intent jump = new Intent(this, NotesListActivity.class); + //启动目的组件 + startActivity(jump); + //显示消息提示框,消息为便签不存在 + showToast(R.string.error_note_not_exist); + //结束NoteEditActivity的生命周期 + finish(); + return false; + } else { + //如果在数据库中查找到相应的便签标识符noteId,则将该便签加载到mWorkingNote变量中 + mWorkingNote = WorkingNote.load(this, noteId); + //如果活动便签为空,显示错误信息 + if (mWorkingNote == null) { + Log.e(TAG, "load note failed with note id" + noteId); + finish(); + return false; + } + } + //设置软键盘输入模式 + getWindow().setSoftInputMode( + WindowManager.LayoutParams.SOFT_INPUT_STATE_HIDDEN + | WindowManager.LayoutParams.SOFT_INPUT_ADJUST_RESIZE); + } else if(TextUtils.equals(Intent.ACTION_INSERT_OR_EDIT, intent.getAction())) { + // New note + //初始化便签的各属性 + long folderId = intent.getLongExtra(Notes.INTENT_EXTRA_FOLDER_ID, 0); + int widgetId = intent.getIntExtra(Notes.INTENT_EXTRA_WIDGET_ID, + AppWidgetManager.INVALID_APPWIDGET_ID); + int widgetType = intent.getIntExtra(Notes.INTENT_EXTRA_WIDGET_TYPE, + Notes.TYPE_WIDGET_INVALIDE); + int bgResId = intent.getIntExtra(Notes.INTENT_EXTRA_BACKGROUND_ID, + ResourceParser.getDefaultBgId(this)); + + // Parse call-record note + //解析通话记录便签 + String phoneNumber = intent.getStringExtra(Intent.EXTRA_PHONE_NUMBER); + long callDate = intent.getLongExtra(Notes.INTENT_EXTRA_CALL_DATE, 0); + /** + * 如果便签的通话日期和通话号码均存在,则把其当做通话便签进行处理,否则当做普通便签进行初始化 + */ + if (callDate != 0 && phoneNumber != null) { + //如果记录的通话号码为空,则显示警告 + if (TextUtils.isEmpty(phoneNumber)) { + Log.w(TAG, "The call record number is null"); + } + long noteId = 0; + //通过通话号码和通话日期在数据库中查找noteId + if ((noteId = DataUtils.getNoteIdByPhoneNumberAndCallDate(getContentResolver(), + phoneNumber, callDate)) > 0) { + mWorkingNote = WorkingNote.load(this, noteId); + if (mWorkingNote == null) { + Log.e(TAG, "load call note failed with note id" + noteId); + finish(); + return false; + } + } else { + //没有查找到noteId信息则重新建立空便签,使用之前默认参量对便签进行初始化 + mWorkingNote = WorkingNote.createEmptyNote(this, folderId, widgetId, + widgetType, bgResId); + //将便签转化为通话记录便签 + mWorkingNote.convertToCallNote(phoneNumber, callDate); + } + } else { + //否则按照普通的创建 + mWorkingNote = WorkingNote.createEmptyNote(this, folderId, widgetId, widgetType, + bgResId); + } + + getWindow().setSoftInputMode( + WindowManager.LayoutParams.SOFT_INPUT_ADJUST_RESIZE + | WindowManager.LayoutParams.SOFT_INPUT_STATE_VISIBLE); + } else { + //显示错误信息,Intent没有指定动作,不应支持 + Log.e(TAG, "Intent not specified action, should not support"); + finish(); + return false; + } + //调用mWorkingNote的setOnSettingStatusChangedListener()方法设置状态变化监听器 + mWorkingNote.setOnSettingStatusChangedListener(this); + + + + //返回true表示初始化该Activity成功 + return true; + } + + /** + * 重写Activity的onResume方法,将标签编辑界面作为界面的最上层呈现 + */ + @Override + protected void onResume() { + super.onResume(); + //调用初始化便签界面方法 + initNoteScreen(); + } + + /** + * 初始化便签界面的窗口 + */ + private void initNoteScreen() { + //设置便签界面的文字外观 + mNoteEditor.setTextAppearance(this, TextAppearanceResources + .getTexAppearanceResource(mFontSizeId)); + /** + * 判断是否为清单列表界面,是则切换到清单列表的处理过程,否则继续执行 + */ + if (mWorkingNote.getCheckListMode() == TextNote.MODE_CHECK_LIST) { + switchToListMode(mWorkingNote.getContent()); + } else { + mNoteEditor.setText(getHighlightQueryResult(mWorkingNote.getContent(), mUserQuery)); + //设置光标在便签文档的末尾 + mNoteEditor.setSelection(mNoteEditor.getText().length()); + } + for (Integer id : sBgSelectorSelectionMap.keySet()) { + findViewById(sBgSelectorSelectionMap.get(id)).setVisibility(View.GONE); + } + //设置便签头部背景和编辑部分的背景颜色 + mHeadViewPanel.setBackgroundResource(mWorkingNote.getTitleBgResId()); + mNoteEditorPanel.setBackgroundResource(mWorkingNote.getBgColorResId()); + + //设置便签头的修改时间 + mNoteHeaderHolder.tvModified.setText(DateUtils.formatDateTime(this, + mWorkingNote.getModifiedDate(), DateUtils.FORMAT_SHOW_DATE + | DateUtils.FORMAT_NUMERIC_DATE | DateUtils.FORMAT_SHOW_TIME + | DateUtils.FORMAT_SHOW_YEAR)); + + /** + * TODO: Add the menu for setting alert. Currently disable it because the DateTimePicker + * is not ready + */ + showAlertHeader(); + +/*字数统计*/ + + final TextView WordNUm = (TextView) findViewById(R.id.textCount); + mNoteEditor.addTextChangedListener(new TextWatcher() { + @Override + public void beforeTextChanged(CharSequence s, int i, int i1, int i2) { + + } + + @Override + public void onTextChanged(CharSequence s, int i, int i1, int i2) { + + } + + @Override + public void afterTextChanged(Editable s) { + WordNUm.setText("当前字数为:"+(s.length())); } + }); + if(mWorkingNote.hasPassword()) { + final PasswordView pwdView = new PasswordView(this, PasswordView.CUR_PWD_VIEW); + RelativeLayout.LayoutParams LP = new RelativeLayout.LayoutParams(RelativeLayout.LayoutParams.MATCH_PARENT, + RelativeLayout.LayoutParams.MATCH_PARENT); + + addContentView(pwdView,LP); + /** + * 口令输入完毕后执行的操作 + */ + pwdView.setOnFinishInput(new OnPasswordInputFinish() { + @Override + public void inputFinish() { + //在当前界面下实例化一个对话框 + final AlertDialog.Builder builder_c0 = new AlertDialog.Builder(NoteEditActivity.this); + //设置对话框标题 + builder_c0.setTitle(getString(R.string.alert_title_encrypt)); + //设置对话框图标 + builder_c0.setIcon(android.R.drawable.ic_dialog_info); + /** + * 如果口令输入正确 + */ + if (pwdView.getStrPassword().equals(mWorkingNote.getPassword())) { + ViewGroup vg = (ViewGroup) pwdView.getParent(); + vg.removeView(pwdView); + /* + //设置对话框消息 + builder_c0.setMessage(getString(R.string.alert_message_decrypt)); + */ + /** + * 设置对话框确认按钮的功能 + + builder_c0.setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener() { + @Override + public void onClick(DialogInterface dialogInterface, int i) { + //点击时关闭对话框和输入口令界面 + AlertDialog alertdialog = builder_c0.show(); + alertdialog.dismiss(); + ViewGroup vg = (ViewGroup) pwdView.getParent(); + vg.removeView(pwdView); + } + }); + */ + } else { + builder_c0.setMessage(getString(R.string.alert_message_decrypt_error)); + builder_c0.setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener() { + @Override + public void onClick(DialogInterface dialogInterface, int i) { + finish(); + } + }); + builder_c0.show(); + } + + } + }); + pwdView.getCancelImageView().setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + Toast.makeText(NoteEditActivity.this, "Return", Toast.LENGTH_SHORT).show(); + finish(); + } + }); + }else{ + //Toast.makeText(NoteEditActivity.this, "XXXX", Toast.LENGTH_SHORT).show(); + } + } + + //显示便签提醒的标头 + private void showAlertHeader() { + + if (mWorkingNote.hasClockAlert()) { + long time = System.currentTimeMillis(); + /** + * 如果当前时间已超过活动便签的提醒时间,则置便签标头为过期,否则将显示当前时间到提醒时间的时长 + */ + if (time > mWorkingNote.getAlertDate()) { + mNoteHeaderHolder.tvAlertDate.setText(R.string.note_alert_expired); + } else { + mNoteHeaderHolder.tvAlertDate.setText(DateUtils.getRelativeTimeSpanString( + mWorkingNote.getAlertDate(), time, DateUtils.MINUTE_IN_MILLIS)); + } + mNoteHeaderHolder.tvAlertDate.setVisibility(View.VISIBLE); + mNoteHeaderHolder.ivAlertIcon.setVisibility(View.VISIBLE); + } else { + mNoteHeaderHolder.tvAlertDate.setVisibility(View.GONE); + mNoteHeaderHolder.ivAlertIcon.setVisibility(View.GONE); + } + } + + /** + * 重写onNewIntent方法,监听发送给NoteEditActivity的意图 + * @param intent + */ + @Override + protected void onNewIntent(Intent intent) { + super.onNewIntent(intent); + initActivityState(intent); + } + + /** + * 监听保存实例状态方法 + * @param outState + */ + @Override + protected void onSaveInstanceState(Bundle outState) { + super.onSaveInstanceState(outState); + /** + * For new note without note id, we should firstly save it to + * generate a id. If the editing note is not worth saving, there + * is no id which is equivalent to create new note + * 如果当前工作便签没有分配noteId则先调用saveNote()保存便签 + */ + if (!mWorkingNote.existInDatabase()) { + saveNote(); + } + //将生成的noteId保存到outState中 + outState.putLong(Intent.EXTRA_UID, mWorkingNote.getNoteId()); + Log.d(TAG, "Save working note id: " + mWorkingNote.getNoteId() + " onSaveInstanceState"); + } + + /** + * 分发触摸事件 + * @param ev 触摸点 + * @return boolean + */ + @Override + public boolean dispatchTouchEvent(MotionEvent ev) { + //由便签背景选择器消耗触摸事件 + if (mNoteBgColorSelector.getVisibility() == View.VISIBLE + && !inRangeOfView(mNoteBgColorSelector, ev)) { + mNoteBgColorSelector.setVisibility(View.GONE); + return true; + } + //由便签字号选择器消耗触摸事件 + if (mFontSizeSelector.getVisibility() == View.VISIBLE + && !inRangeOfView(mFontSizeSelector, ev)) { + mFontSizeSelector.setVisibility(View.GONE); + return true; + } + //未被消耗时调用父类的方法 + return super.dispatchTouchEvent(ev); + } + + /** + * 判断触摸点是否在视图内部 + * @param view + * @param ev 触摸点 + * @return boolean + */ + private boolean inRangeOfView(View view, MotionEvent ev) { + int []location = new int[2]; + view.getLocationOnScreen(location); + int x = location[0]; + int y = location[1]; + if (ev.getX() < x + || ev.getX() > (x + view.getWidth()) + || ev.getY() < y + || ev.getY() > (y + view.getHeight())) { + return false; + } + + return true; + } + + /** + * + */ + private void initResources() { + //初始化便签标题栏 + mHeadViewPanel = findViewById(R.id.note_title); + mNoteHeaderHolder = new HeadViewHolder(); + mNoteHeaderHolder.tvModified = (TextView) findViewById(R.id.tv_modified_date); + mNoteHeaderHolder.ivAlertIcon = (ImageView) findViewById(R.id.iv_alert_icon); + mNoteHeaderHolder.tvAlertDate = (TextView) findViewById(R.id.tv_alert_date); + mNoteHeaderHolder.ibSetBgColor = (ImageView) findViewById(R.id.btn_set_bg_color); + mNoteHeaderHolder.ibSetBgColor.setOnClickListener(this); + //初始化便签编辑部分界面 + mNoteEditor = (EditText) findViewById(R.id.note_edit_view); + mNoteEditorPanel = findViewById(R.id.sv_note_edit); + //初始化便签背景选择界面 + mNoteBgColorSelector = findViewById(R.id.note_bg_color_selector); + /** + * 对所有颜色选择按钮设置监听器 + */ + for (int id : sBgSelectorBtnsMap.keySet()) { + ImageView iv = (ImageView) findViewById(id); + //设置点击事件监听器 + iv.setOnClickListener(this); + } + //初始化便签文字字号选择器 + mFontSizeSelector = findViewById(R.id.font_size_selector); + for (int id : sFontSizeBtnsMap.keySet()) { + View view = findViewById(id); + view.setOnClickListener(this); + }; + //初始化共享设置 + mSharedPrefs = PreferenceManager.getDefaultSharedPreferences(this); + //将字体大小标识设置为默认大小 + mFontSizeId = mSharedPrefs.getInt(PREFERENCE_FONT_SIZE, ResourceParser.BG_DEFAULT_FONT_SIZE); + /** + * HACKME: Fix bug of store the resource id in shared preference. + * The id may larger than the length of resources, in this case, + * return the {@link ResourceParser#BG_DEFAULT_FONT_SIZE} + */ + if(mFontSizeId >= TextAppearanceResources.getResourcesSize()) { + mFontSizeId = ResourceParser.BG_DEFAULT_FONT_SIZE; + } + mEditTextList = (LinearLayout) findViewById(R.id.note_edit_list); + + + } + + /** + * 重写onPause方法,将便签编辑界面暂停(部分可见) + */ + @Override + protected void onPause() { + super.onPause(); + //保存便签 + if(saveNote()) { + Log.d(TAG, "Note data was saved with length:" + mWorkingNote.getContent().length()); + } + clearSettingState(); + } + + /** + * 更新桌面挂件 + */ + private void updateWidget() { + //实例化Intent,用于和AppWidgetManager进行消息交换 + Intent intent = new Intent(AppWidgetManager.ACTION_APPWIDGET_UPDATE); + //判断当前工作中的便签的桌面挂件的类型,并根据不同类型的桌面挂件指定Intent不同的目的组件 + if (mWorkingNote.getWidgetType() == Notes.TYPE_WIDGET_2X) { + intent.setClass(this, NoteWidgetProvider_2x.class); + } else if (mWorkingNote.getWidgetType() == Notes.TYPE_WIDGET_4X) { + intent.setClass(this, NoteWidgetProvider_4x.class); + } else { + Log.e(TAG, "Unspported widget type"); + return; + } + //将桌面挂件的标识作为附加信息添加到Intent中 + intent.putExtra(AppWidgetManager.EXTRA_APPWIDGET_IDS, new int[] { + mWorkingNote.getWidgetId() + }); + //将指定好参数的Intent对象通过广播发送出去以启动相应的Activity + sendBroadcast(intent); + //设置当前Activity结束后将结束信息发送给其父活动 + setResult(RESULT_OK, intent); + } + + /** + * 点击事件 + * @param v + */ + public void onClick(View v) { + + //获取点击目标 + int id = v.getId(); + //点击设置背景色图标 or 点击颜色图标 or 点击字体图标 + if (id == R.id.btn_set_bg_color) { + //将便签背景选择器界面设为可见 + mNoteBgColorSelector.setVisibility(View.VISIBLE); + //将备选颜色界面设为可见 + findViewById(sBgSelectorSelectionMap.get(mWorkingNote.getBgColorId())).setVisibility( + View.VISIBLE); + } else if (sBgSelectorBtnsMap.containsKey(id)) { + //将备选颜色界面设为不可见 + findViewById(sBgSelectorSelectionMap.get(mWorkingNote.getBgColorId())).setVisibility( + View.GONE); + //设置背景色 + mWorkingNote.setBgColorId(sBgSelectorBtnsMap.get(id)); + //将便签背景选择器界面设为不可见 + mNoteBgColorSelector.setVisibility(View.GONE); + } else if (sFontSizeBtnsMap.containsKey(id)) { + //将备选字体界面设为可见 + findViewById(sFontSelectorSelectionMap.get(mFontSizeId)).setVisibility(View.GONE); + //使用mFontSizeId变量存储选定大小 + mFontSizeId = sFontSizeBtnsMap.get(id); + //将共享设置中的字体进行修改 + mSharedPrefs.edit().putInt(PREFERENCE_FONT_SIZE, mFontSizeId).commit(); + + findViewById(sFontSelectorSelectionMap.get(mFontSizeId)).setVisibility(View.VISIBLE); + //如果便签为清单模式 + if (mWorkingNote.getCheckListMode() == TextNote.MODE_CHECK_LIST) { + //获取工作文字 + getWorkingText(); + //转成列表模式 + switchToListMode(mWorkingNote.getContent()); + } else { + //将字体资源设置为当前大小 + mNoteEditor.setTextAppearance(this, + TextAppearanceResources.getTexAppearanceResource(mFontSizeId)); + } + //将字体大小选择器界面设为不可见 + mFontSizeSelector.setVisibility(View.GONE); + } + + } + + @Override + public void onBackPressed() { + /** + * 如果字体选择器和背景选择器均不可见,即为便签编辑界面,点击返回键退出,保存便签 + * 如果字体选择器和背景选择器可见,则点击返回键时关闭选择界面 + */ + if(clearSettingState()) { + return; + } + //保存便签 + saveNote(); + super.onBackPressed(); + } + + /** + * 清除设置状态 + * @return boolean 如果选择器为可见,则返回true,在便签编辑界面返回false + */ + private boolean clearSettingState() { + //将字体选择器和背景颜色选择器设为不可见 + if (mNoteBgColorSelector.getVisibility() == View.VISIBLE) { + mNoteBgColorSelector.setVisibility(View.GONE); + return true; + } else if (mFontSizeSelector.getVisibility() == View.VISIBLE) { + mFontSizeSelector.setVisibility(View.GONE); + return true; + } + return false; + } + + /** + * 监听背景颜色变化 + */ + public void onBackgroundColorChanged() { + //将便签背景色设置为可见,并显示该视图 + findViewById(sBgSelectorSelectionMap.get(mWorkingNote.getBgColorId())).setVisibility( + View.VISIBLE); + //将文件编辑区域的背景资源设置为便签背景色 + mNoteEditorPanel.setBackgroundResource(mWorkingNote.getBgColorResId()); + //将便签头的背景资源设置为标题的背景色 + mHeadViewPanel.setBackgroundResource(mWorkingNote.getTitleBgResId()); + } + + @Override + public boolean onPrepareOptionsMenu(Menu menu) { + if (isFinishing()) { + return true; + } + //清除设置状态 + clearSettingState(); + //清除菜单项 + menu.clear(); + /** + * 根据文件夹类型,则调用相应的目录填充方法 + */ + if (mWorkingNote.getFolderId() == Notes.ID_CALL_RECORD_FOLDER) { + getMenuInflater().inflate(R.menu.call_note_edit, menu); + } else { + getMenuInflater().inflate(R.menu.note_edit, menu); + } + /** + * 根据工作便签属性,则调用相应的目录填充方法 + */ + if (mWorkingNote.getCheckListMode() == TextNote.MODE_CHECK_LIST) { + menu.findItem(R.id.menu_list_mode).setTitle(R.string.menu_normal_mode); + } else { + menu.findItem(R.id.menu_list_mode).setTitle(R.string.menu_list_mode); + } + /** + * 将工作便签中的时钟提醒设置为不可见 + */ + if (mWorkingNote.hasClockAlert()) { + menu.findItem(R.id.menu_alert).setVisible(false); + } else { + menu.findItem(R.id.menu_delete_remind).setVisible(false); + } + + if (mWorkingNote.hasPassword()) { + menu.findItem(R.id.menu_encrypt).setVisible(false); + } else { + menu.findItem(R.id.menu_delete_encrypt).setVisible(false); + } + + //menu.findItem(R.id.menu_set_importance).setVisible(false); + return true; + } + + /** + * 监听菜单中的项是否被选择 + * @param item + * @return + */ + @Override + public boolean onOptionsItemSelected(MenuItem item) { + switch (item.getItemId()) { + //选择新建便签 + case R.id.menu_new_note: + createNewNote(); + break; + //选择删除便签 + case R.id.menu_delete: + + AlertDialog.Builder builder = new AlertDialog.Builder(this); + builder.setTitle(getString(R.string.alert_title_delete)); + //设置提醒图标 + builder.setIcon(android.R.drawable.ic_dialog_alert); + //设置删除提醒消息 + builder.setMessage(getString(R.string.alert_message_delete_note)); + //设置选择按钮 + builder.setPositiveButton(android.R.string.ok, + new DialogInterface.OnClickListener() { + public void onClick(DialogInterface dialog, int which) { + deleteCurrentNote(); + finish(); + } + }); + //设置取消选择按钮 + builder.setNegativeButton(android.R.string.cancel, null); + builder.show(); + break; + //选择设置字号 + case R.id.menu_font_size: + mFontSizeSelector.setVisibility(View.VISIBLE); + findViewById(sFontSelectorSelectionMap.get(mFontSizeId)).setVisibility(View.VISIBLE); + break; + //选择设置清单模式 + case R.id.menu_list_mode: + mWorkingNote.setCheckListMode(mWorkingNote.getCheckListMode() == 0 ? + TextNote.MODE_CHECK_LIST : 0); + break; + //选择分享 + case R.id.menu_share: + getWorkingText(); + sendTo(this, mWorkingNote.getContent()); + break; + //选择分享到桌面 + case R.id.menu_send_to_desktop: + sendToDesktop(); + break; + //选择提醒 + case R.id.menu_alert: + setReminder(); + break; + //选择删除提醒 + case R.id.menu_delete_remind: + mWorkingNote.setAlertDate(0, false); + break; + case R.id.menu_encrypt: + setEncryption(); + break; + case R.id.menu_delete_encrypt: + deleteEncryption(); + break; + case R.id.menu_set_importance: + setImportance(); + break; + default: + break; + } + return true; + } + private class RatingBarLayout extends LinearLayout{ + Context context; + private RatingBar ratingBar; + public RatingBarLayout(Context context) { + super(context); + this.context = context; + View view; + view = View.inflate(context, R.layout.note_importance, null); + ratingBar = (RatingBar) view.findViewById(R.id.ratingBar); + ratingBar.setOnRatingBarChangeListener(new RatingBar.OnRatingBarChangeListener(){ + + @Override + public void onRatingChanged(RatingBar ratingBar, float r, boolean fromUser) { + ratingBar.setRating(r); + } + }); + addView(view); + } + + public int getStars(){ + return (int) ratingBar.getRating(); + } + } + private void setImportance(){ + final RatingBarLayout rbLayout = new RatingBarLayout(this); + AlertDialog.Builder builder = new AlertDialog.Builder(this); + builder.setTitle(getString(R.string.alert_title_importance)); + builder.setIcon(android.R.drawable.ic_dialog_info); + builder.setView(rbLayout); + builder.setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener(){ + @Override + public void onClick(DialogInterface dialogInterface, int i) { + Toast.makeText(NoteEditActivity.this, "Rating:"+String.valueOf(rbLayout.getStars()), Toast.LENGTH_SHORT).show(); + mWorkingNote.setImportance(rbLayout.getStars()); + finish(); + } + }); + builder.show(); + } + + private void setEncryption(){ + final PasswordView pwdView = new PasswordView(this, PasswordView.NEW_PWD_VIEW); + final PasswordView pwdViewRepeat = new PasswordView(this, PasswordView.RPT_PWD_VIEW); + setContentView(pwdView); + pwdView.setOnFinishInput(new OnPasswordInputFinish() { + @Override + public void inputFinish() { + setContentView(pwdViewRepeat); + Toast.makeText(NoteEditActivity.this, pwdView.getStrPassword(), Toast.LENGTH_SHORT).show(); + } + }); + pwdView.getCancelImageView().setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + Toast.makeText(NoteEditActivity.this, "Return from Step1", Toast.LENGTH_SHORT).show(); + finish(); + } + }); + + pwdViewRepeat.setOnFinishInput(new OnPasswordInputFinish() { + @Override + public void inputFinish() { + + final AlertDialog.Builder builder_c1 = new AlertDialog.Builder(NoteEditActivity.this); + builder_c1.setTitle(getString(R.string.alert_title_encrypt)); + builder_c1.setIcon(android.R.drawable.ic_dialog_info); + if( pwdView.getStrPassword().equals(pwdViewRepeat.getStrPassword()) ){ + builder_c1.setMessage(getString(R.string.alert_message_encrypt,pwdViewRepeat.getStrPassword())); + mWorkingNote.setPassword(pwdViewRepeat.getStrPassword()); + }else{ + builder_c1.setMessage(getString(R.string.alert_message_encrypt_error)); + } + + builder_c1.setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener(){ + @Override + public void onClick(DialogInterface dialogInterface, int i) { + finish(); + } + }); + builder_c1.show(); + } + }); + +// /** +// * 可以用自finish();定义控件中暴露出来的cancelImageView方法,重新提供相应 +// * 如果写了,会覆盖我们在自定义控件中提供的响应 +// * 可以看到这里toast显示 "Biu Biu Biu"而不是"Cancel"*/ + pwdViewRepeat.getCancelImageView().setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + Toast.makeText(NoteEditActivity.this, "Return from Step2", Toast.LENGTH_SHORT).show(); + finish(); + } + }); + } + + private void deleteEncryption(){ + mWorkingNote.setPassword(""); + AlertDialog.Builder builder_c2 = new AlertDialog.Builder(this); + builder_c2.setTitle(getString(R.string.alert_title_encrypt)); + builder_c2.setIcon(android.R.drawable.ic_dialog_info); + builder_c2.setMessage(getString(R.string.alert_message_remove_encrypt)); + builder_c2.setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener(){ + @Override + public void onClick(DialogInterface dialogInterface, int i) { + finish(); + } + }); + builder_c2.show(); + } + + /** + * 设置提醒 + */ + private void setReminder() { + //实例化一个时间日期选择器的对话框,进行提醒日期的设置 + DateTimePickerDialog d = new DateTimePickerDialog(this, System.currentTimeMillis()); + d.setOnDateTimeSetListener(new OnDateTimeSetListener() { + public void OnDateTimeSet(AlertDialog dialog, long date) { + mWorkingNote.setAlertDate(date , true); + } + }); + //显示该控件 + d.show(); + } + + /** + * Share note to apps that support {@link Intent#ACTION_SEND} action + * and {@text/plain} type + */ + private void sendTo(Context context, String info) { + Intent intent = new Intent(Intent.ACTION_SEND); + intent.putExtra(Intent.EXTRA_TEXT, info); + intent.setType("text/plain"); + context.startActivity(intent); + } + + /** + * 创建新便签 + */ + private void createNewNote() { + // Firstly, save current editing notes + //首先保存当前编辑的便签 + saveNote(); + + // For safety, start a new NoteEditActivity + //结束当前活动周期,重新激活便签编辑Activity + finish(); + Intent intent = new Intent(this, NoteEditActivity.class); + intent.setAction(Intent.ACTION_INSERT_OR_EDIT); + intent.putExtra(Notes.INTENT_EXTRA_FOLDER_ID, mWorkingNote.getFolderId()); + startActivity(intent); + } + + /** + * 删除当前便签 + */ + private void deleteCurrentNote() { + if (mWorkingNote.existInDatabase()) { + HashSet ids = new HashSet(); + long id = mWorkingNote.getNoteId(); + /** + * 如果删除的便签Id不是根目录的ID,否则提示错误 + */ + if (id != Notes.ID_ROOT_FOLDER) { + ids.add(id); + } else { + Log.d(TAG, "Wrong note id, should not happen"); + } + /** + * 如果不是同步模式,删除便签 + * 否则,将便签移入垃圾箱中 + */ + if (!isSyncMode()) { + if (!DataUtils.batchDeleteNotes(getContentResolver(), ids)) { + Log.e(TAG, "Delete Note error"); + } + } else { + if (!DataUtils.batchMoveToFolder(getContentResolver(), ids, Notes.ID_TRASH_FOLER)) { + Log.e(TAG, "Move notes to trash folder error, should not happens"); + } + } + } + //更改工作便签的删除标记 + mWorkingNote.markDeleted(true); + } + + /** + * 判断是否为同步模式 + * @return boolean + */ + private boolean isSyncMode() { + //从NotesPreferenceActivity中获取同步账号名,如果存在则返回true + return NotesPreferenceActivity.getSyncAccountName(this).trim().length() > 0; + } + + /** + * 监听时钟提醒的变化 + * @param date 提醒时间 + * @param set + */ + public void onClockAlertChanged(long date, boolean set) { + /** + * User could set clock to an unsaved note, so before setting the + * alert clock, we should save the note first + * 如果设置提醒的便签未保存,则先保存 + */ + if (!mWorkingNote.existInDatabase()) { + saveNote(); + } + /** + * 如果便签Id存在(worthsaving,已编辑过) + */ + if (mWorkingNote.getNoteId() > 0) { + //设置向AlarmReceiver发送的Intent + Intent intent = new Intent(this, AlarmReceiver.class); + //设置其Data域为附加便签Id后的表示内容的Uri + intent.setData(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, mWorkingNote.getNoteId())); + //设置延迟触发Intent + PendingIntent pendingIntent = PendingIntent.getBroadcast(this, 0, intent, 0); + //获得系统的提醒服务 + AlarmManager alarmManager = ((AlarmManager) getSystemService(ALARM_SERVICE)); + //显示提醒标头 + showAlertHeader(); + //如果未设置,则取消当前设置,否则调用系统的提醒服务设置该提醒,在其被唤醒后解析之前设置的pendingIntent + if(!set) { + alarmManager.cancel(pendingIntent); + } else { + alarmManager.set(AlarmManager.RTC_WAKEUP, date, pendingIntent); + } + } else { + /** + * There is the condition that user has input nothing (the note is + * not worthy saving), we have no note id, remind the user that he + * should input something + * 便签未编辑错误 + */ + Log.e(TAG, "Clock alert setting error"); + //显示消息提示框,为未编辑的便签设置闹钟 + showToast(R.string.error_note_empty_for_clock); + } + } + + /** + * 监听挂件的变化,如果有变化更新挂件 + */ + public void onWidgetChanged() { + updateWidget(); + } + + /** + * 监听文本编辑过程中的删除 + * @param index 删除文本的位置 + * @param text 当前位置后的文本 + */ + public void onEditTextDelete(int index, String text) { + //获取文本列表的总项数 + int childCount = mEditTextList.getChildCount(); + if (childCount == 1) { + return; + } + //将删除文本后面项的索引减1 + for (int i = index + 1; i < childCount; i++) { + ((NoteEditText) mEditTextList.getChildAt(i).findViewById(R.id.et_edit_text)) + .setIndex(i - 1); + } + //移除当前项的视图 + mEditTextList.removeViewAt(index); + NoteEditText edit = null; + //如果原来编辑的索引值为0则编辑当前行,否则编辑上一行 + if(index == 0) { + edit = (NoteEditText) mEditTextList.getChildAt(0).findViewById( + R.id.et_edit_text); + } else { + edit = (NoteEditText) mEditTextList.getChildAt(index - 1).findViewById( + R.id.et_edit_text); + } + //获取当前项的长度 + int length = edit.length(); + //在当前位置后附加文本 + edit.append(text); + //获取当前控件的焦点 + edit.requestFocus(); + //选中该文本块 + edit.setSelection(length); + } + + /** + * 监听文本编辑过程中的换行 + * @param index 换行的位置 + * @param text 当前位置后的文本 + */ + public void onEditTextEnter(int index, String text) { + /** + * Should not happen, check for debug + * 如果便签长度超过了限制,则提示错误 + */ + if(index > mEditTextList.getChildCount()) { + Log.e(TAG, "Index out of mEditTextList boundrary, should not happen"); + } + + View view = getListItem(text, index); + //添加当前项的视图 + mEditTextList.addView(view, index); + NoteEditText edit = (NoteEditText) view.findViewById(R.id.et_edit_text); + //获取控件焦点 + edit.requestFocus(); + //选中当前行的首个位置 + edit.setSelection(0); + //将当前后面项的索引加1 + for (int i = index + 1; i < mEditTextList.getChildCount(); i++) { + ((NoteEditText) mEditTextList.getChildAt(i).findViewById(R.id.et_edit_text)) + .setIndex(i); + } + } + + /** + * 转换到列表模式 + * @param text + */ + private void switchToListMode(String text) { + //清除所有视图 + mEditTextList.removeAllViews(); + //将文本以\n分离 + String[] items = text.split("\n"); + int index = 0; + //从第一个索引块开始添加列表项的视图 + for (String item : items) { + if(!TextUtils.isEmpty(item)) { + mEditTextList.addView(getListItem(item, index)); + index++; + } + } + //添加最后一行的视图 + mEditTextList.addView(getListItem("", index)); + //获取当前列表项焦点 + mEditTextList.getChildAt(index).findViewById(R.id.et_edit_text).requestFocus(); + //文本编辑器设置为不可见 + mNoteEditor.setVisibility(View.GONE); + //文本列表编辑器设置为可见 + mEditTextList.setVisibility(View.VISIBLE); + } + + /** + * 获取匹配到的高亮结果 + * @param fullText 完整的文本 + * @param userQuery 用户的请求 + * @return Spannable类型的文本 + */ + private Spannable getHighlightQueryResult(String fullText, String userQuery) { + //初始化spannable为空字符串 + SpannableString spannable = new SpannableString(fullText == null ? "" : fullText); + if (!TextUtils.isEmpty(userQuery)) { + //将用户的请求编译为正则表达式 + mPattern = Pattern.compile(userQuery); + //在全文本中匹配该请求 + Matcher m = mPattern.matcher(fullText); + int start = 0; + /** + * 将匹配到的部分显示为高亮 + */ + while (m.find(start)) { + spannable.setSpan( + new BackgroundColorSpan(this.getResources().getColor( + R.color.user_query_highlight)), m.start(), m.end(), + Spannable.SPAN_INCLUSIVE_EXCLUSIVE); + start = m.end(); + } + } + return spannable; + } + + /** + * 获取列表项 + * @param item 以字符串格式存储的列表项 + * @param index 当前项的索引 + * @return View 列表项的视图 + */ + private View getListItem(String item, int index) { + View view = LayoutInflater.from(this).inflate(R.layout.note_edit_list_item, null); + final NoteEditText edit = (NoteEditText) view.findViewById(R.id.et_edit_text); + edit.setTextAppearance(this, TextAppearanceResources.getTexAppearanceResource(mFontSizeId)); + //实例化标签框 + CheckBox cb = ((CheckBox) view.findViewById(R.id.cb_edit_item)); + //监听是否已标识 + cb.setOnCheckedChangeListener(new OnCheckedChangeListener() { + public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) { + if (isChecked) { + edit.setPaintFlags(edit.getPaintFlags() | Paint.STRIKE_THRU_TEXT_FLAG); + } else { + edit.setPaintFlags(Paint.ANTI_ALIAS_FLAG | Paint.DEV_KERN_TEXT_FLAG); + } + } + }); + /** + * 如果列表项含有的标识创建相应的标签框 + */ + if (item.startsWith(TAG_CHECKED)) { + cb.setChecked(true); + edit.setPaintFlags(edit.getPaintFlags() | Paint.STRIKE_THRU_TEXT_FLAG); + item = item.substring(TAG_CHECKED.length(), item.length()).trim(); + } else if (item.startsWith(TAG_UNCHECKED)) { + cb.setChecked(false); + edit.setPaintFlags(Paint.ANTI_ALIAS_FLAG | Paint.DEV_KERN_TEXT_FLAG); + item = item.substring(TAG_UNCHECKED.length(), item.length()).trim(); + } + //监听文本视图的变化 + edit.setOnTextViewChangeListener(this); + //将索引值设置为当前索引 + edit.setIndex(index); + //设置高亮 + edit.setText(getHighlightQueryResult(item, mUserQuery)); + return view; + } + + /** + * 监听文本的变化 + * @param index 发生变化位置的索引 + * @param hasText 是否有文本 + */ + public void onTextChange(int index, boolean hasText) { + //如果索引超过了当前文本内容,报告错误 + if (index >= mEditTextList.getChildCount()) { + Log.e(TAG, "Wrong index, should not happen"); + return; + } + /** + * 如果当前位置有文本则设置为可见,否则设置为不可见 + */ + if(hasText) { + mEditTextList.getChildAt(index).findViewById(R.id.cb_edit_item).setVisibility(View.VISIBLE); + } else { + mEditTextList.getChildAt(index).findViewById(R.id.cb_edit_item).setVisibility(View.GONE); + } + } + + /** + * 监听清单模式的变化 + * @param oldMode is previous mode before change + * @param newMode is new mode + */ + public void onCheckListModeChanged(int oldMode, int newMode) { + //如果新模式为列表模式,则调用switchToListMode()方法进行转化 + if (newMode == TextNote.MODE_CHECK_LIST) { + switchToListMode(mNoteEditor.getText().toString()); + } else { + //如果没有保存工作文本,则进行保存该部分文本 + if (!getWorkingText()) { + mWorkingNote.setWorkingText(mWorkingNote.getContent().replace(TAG_UNCHECKED + " ", + "")); + } + //设置高亮文本 + mNoteEditor.setText(getHighlightQueryResult(mWorkingNote.getContent(), mUserQuery)); + //取消文本列表视图 + mEditTextList.setVisibility(View.GONE); + //设置文本编辑为可见 + mNoteEditor.setVisibility(View.VISIBLE); + } + } + + /** + * 获取当前活动便签的文本并保存到数据库中 + * @return boolean + */ + private boolean getWorkingText() { + //初始化hasChecked变量 + boolean hasChecked = false; + /** + * 如果当前工作便签为清单模式,转化为文字形式保存其数据 + * 否则直接保存文字数据到数据库中 + */ + if (mWorkingNote.getCheckListMode() == TextNote.MODE_CHECK_LIST) { + StringBuilder sb = new StringBuilder(); + for (int i = 0; i < mEditTextList.getChildCount(); i++) { + //获取当前文本编辑列表的第i项 + View view = mEditTextList.getChildAt(i); + NoteEditText edit = (NoteEditText) view.findViewById(R.id.et_edit_text); + /** + * 如果当前便签文本编辑部分不为空 + */ + if (!TextUtils.isEmpty(edit.getText())) { + /** + * 如果已标记当前项,则在文本前添加“TAG_CHECKED” + * 如果未标记当前项,则在文本前添加“TAG_CHECKED” + */ + if (((CheckBox) view.findViewById(R.id.cb_edit_item)).isChecked()) { + sb.append(TAG_CHECKED).append(" ").append(edit.getText()).append("\n"); + hasChecked = true; + } else { + sb.append(TAG_UNCHECKED).append(" ").append(edit.getText()).append("\n"); + } + } + } + //使用建立好的文本内容设置当前活动便签的内容 + mWorkingNote.setWorkingText(sb.toString()); + } else { + mWorkingNote.setWorkingText(mNoteEditor.getText().toString()); + } + //返回便签是否已标记 + return hasChecked; + } + + /** + * 保存便签 + * @return boolean + */ + private boolean saveNote() { + //获取当前文本并存储 + getWorkingText(); + //调用WorkingNote的saveNote()方法保存便签 + boolean saved = mWorkingNote.saveNote(); + //如果已保存,则设置结果为已保存 + if (saved) { + /** + * There are two modes from List view to edit view, open one note, + * create/edit a node. Opening node requires to the original + * position in the list when back from edit view, while creating a + * new node requires to the top of the list. This code + * {@link #RESULT_OK} is used to identify the create/edit state + */ + setResult(RESULT_OK); + } + return saved; + } + + /** + * 将便签发送至桌面 + */ + private void sendToDesktop() { + /** + * Before send message to home, we should make sure that current + * editing note is exists in databases. So, for new note, firstly + * save it + * 在发送消息至主页之前,先保存当前编辑的便签 + */ + if (!mWorkingNote.existInDatabase()) { + saveNote(); + } + /** + * 如果当前便签具有Id(已编辑) + */ + if (mWorkingNote.getNoteId() > 0) { + Intent sender = new Intent(); + Intent shortcutIntent = new Intent(this, NoteEditActivity.class); + //设置快捷访问的Intent,将其保存至sender中,以便直接快速调用NoteEditActivity + shortcutIntent.setAction(Intent.ACTION_VIEW); + shortcutIntent.putExtra(Intent.EXTRA_UID, mWorkingNote.getNoteId()); + sender.putExtra(Intent.EXTRA_SHORTCUT_INTENT, shortcutIntent); + sender.putExtra(Intent.EXTRA_SHORTCUT_NAME, + makeShortcutIconTitle(mWorkingNote.getContent())); + sender.putExtra(Intent.EXTRA_SHORTCUT_ICON_RESOURCE, + Intent.ShortcutIconResource.fromContext(this, R.drawable.icon_app)); + sender.putExtra("duplicate", true); + sender.setAction("com.android.launcher.action.INSTALL_SHORTCUT"); + //显示消息提示框,表示文本以发送至桌面 + showToast(R.string.info_note_enter_desktop); + //将sender以广播的形式发出 + sendBroadcast(sender); + } else { + /** + * There is the condition that user has input nothing (the note is + * not worthy saving), we have no note id, remind the user that he + * should input something + */ + Log.e(TAG, "Send to desktop error"); + //显示消息提示框,将空便签发送到桌面 + showToast(R.string.error_note_empty_for_send_to_desktop); + } + } + + /** + * 制作快捷访问图标的题目,如果其长度大于最大表示长度,则截断 + * @param content 便签内容 + * @return 返回修剪过的内容字符串 + */ + private String makeShortcutIconTitle(String content) { + content = content.replace(TAG_CHECKED, ""); + content = content.replace(TAG_UNCHECKED, ""); + return content.length() > SHORTCUT_ICON_TITLE_MAX_LEN ? content.substring(0, + SHORTCUT_ICON_TITLE_MAX_LEN) : content; + } + + /** + * 显示消息提示框 + * @param resId 结果标识(不同的消息) + */ + private void showToast(int resId) { + showToast(resId, Toast.LENGTH_SHORT); + } + + + /** + * 显示消息提示框 + * @param resId 结果标识(不同的消息) + * @param duration 显示时长 + */ + private void showToast(int resId, int duration) { + Toast.makeText(this, resId, duration).show(); + } +} diff --git a/app/src/main/java/net/micode/notes/ui/NoteEditText.java b/app/src/main/java/net/micode/notes/ui/NoteEditText.java new file mode 100644 index 0000000..b85b724 --- /dev/null +++ b/app/src/main/java/net/micode/notes/ui/NoteEditText.java @@ -0,0 +1,278 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.ui; + +import android.content.Context; +import android.graphics.Rect; +import android.text.Layout; +import android.text.Selection; +import android.text.Spanned; +import android.text.TextUtils; +import android.text.style.URLSpan; +import android.util.AttributeSet; +import android.util.Log; +import android.view.ContextMenu; +import android.view.KeyEvent; +import android.view.MenuItem; +import android.view.MenuItem.OnMenuItemClickListener; +import android.view.MotionEvent; +import android.widget.EditText; + +import net.micode.notes.R; + +import java.util.HashMap; +import java.util.Map; + +//类:便签编辑文本类,继承了Android控件EditText +public class NoteEditText extends EditText { + //语句:常量标识 + private static final String TAG = "NoteEditText"; + //语句:声明整型变量,文本索引 + private int mIndex; + //语句:声明整型变量 + private int mSelectionStartBeforeDelete; + + //语句:声明字符串常量,标志电话、网址、邮件 + private static final String SCHEME_TEL = "tel:" ; + private static final String SCHEME_HTTP = "http:" ; + private static final String SCHEME_EMAIL = "mailto:" ; + + //语句块:设置映射,将文本内容(电话、网址、邮件)做链接处理 + private static final Map sSchemaActionResMap = new HashMap(); + static { + sSchemaActionResMap.put(SCHEME_TEL, R.string.note_link_tel); + sSchemaActionResMap.put(SCHEME_HTTP, R.string.note_link_web); + sSchemaActionResMap.put(SCHEME_EMAIL, R.string.note_link_email); + } + + /** + * Call by the {@link NoteEditActivity} to delete or add edit text + * 接口:该接口用于实现对TextView组件中的文字信息进行修改 + */ + public interface OnTextViewChangeListener { + /** + * Delete current edit text when {@link KeyEvent#KEYCODE_DEL} happens + * and the text is null + * 方法:当delete键按下时删除当前编辑的文字块 + */ + void onEditTextDelete(int index, String text); + + /** + * Add edit text after current edit text when {@link KeyEvent#KEYCODE_ENTER} + * happen + * 方法:当enter键按下时添加一个文字编辑块 + */ + void onEditTextEnter(int index, String text); + + /** + * Hide or show item option when text change + * 方法:当文字发生变化时隐藏或者显示设置 + */ + void onTextChange(int index, boolean hasText); + } + + //语句:声明文本视图变化监听器 + private OnTextViewChangeListener mOnTextViewChangeListener; + + //方法:构造方法,实例化NoteEditText + public NoteEditText(Context context) { + super(context, null); + mIndex = 0; + } + + //方法:设置索引号 + public void setIndex(int index) { + mIndex = index; + } + + //方法:设置文本视图变化监听器 + public void setOnTextViewChangeListener(OnTextViewChangeListener listener) { + mOnTextViewChangeListener = listener; + } + + //方法:构造方法,是由参数集(文本编辑风格)实例化NoteEditText + public NoteEditText(Context context, AttributeSet attrs) { + super(context, attrs, android.R.attr.editTextStyle); + } + //方法:构造方法,是由参数集(文本编辑风格、定义风格)实例化NoteEditText + public NoteEditText(Context context, AttributeSet attrs, int defStyle) { + super(context, attrs, defStyle); + // TODO Auto-generated constructor stub + } + + //方法:监听触摸事件 + @Override + public boolean onTouchEvent(MotionEvent event) { + switch (event.getAction()) { + case MotionEvent.ACTION_DOWN: + + int x = (int) event.getX(); + int y = (int) event.getY(); + x -= getTotalPaddingLeft(); + y -= getTotalPaddingTop(); + x += getScrollX(); + y += getScrollY(); + + //语句:获取布局 + Layout layout = getLayout(); + //语句:获取纵向的行数 + int line = layout.getLineForVertical(y); + //语句:获取横向的偏移量 + int off = layout.getOffsetForHorizontal(line, x); + Selection.setSelection(getText(), off); + break; + } + //语句:继续调用父类的监听事件方法 + return super.onTouchEvent(event); + } + + /** + * 方法:监听键盘按键按下 + * @param keyCode 键盘按键的编码 + * @param event 按键事件 + * @return boolean + */ + @Override + public boolean onKeyDown(int keyCode, KeyEvent event) { + switch (keyCode) { + //语句块:按下回车键 + case KeyEvent.KEYCODE_ENTER: + //语句块:如果文本视图没有变化 + if (mOnTextViewChangeListener != null) { + return false; + } + break; + //语句块:按下删除键 + case KeyEvent.KEYCODE_DEL: + //语句:获取删除文本的开始位置 + mSelectionStartBeforeDelete = getSelectionStart(); + break; + default: + break; + } + return super.onKeyDown(keyCode, event); + } + + + /** + * 方法:监听按键抬起 + * @param keyCode + * @param event + * @return + */ + @Override + public boolean onKeyUp(int keyCode, KeyEvent event) { + switch(keyCode) { + //语句块:抬起删除键 + case KeyEvent.KEYCODE_DEL: + //语句块:如果文本视图发生变化 + if (mOnTextViewChangeListener != null) { + //语句块:选择了删除的文字 + if (0 == mSelectionStartBeforeDelete && mIndex != 0) { + //语句:监听文本的删除 + mOnTextViewChangeListener.onEditTextDelete(mIndex, getText().toString()); + return true; + } + } else { + //语句:报告文本视图变化监听器没有设置 + Log.d(TAG, "OnTextViewChangeListener was not seted"); + } + break; + //语句块:抬起回车键 + case KeyEvent.KEYCODE_ENTER: + //语句块:如果文本视图发生变化 + if (mOnTextViewChangeListener != null) { + //语句:获取选择区域的起点位置 + int selectionStart = getSelectionStart(); + //语句:获取选择区域后面的文本信息 + String text = getText().subSequence(selectionStart, length()).toString(); + //语句:实现文本换行的功能 + setText(getText().subSequence(0, selectionStart)); + //语句:将选择区域内的文字移到下一行 + mOnTextViewChangeListener.onEditTextEnter(mIndex + 1, text); + } else { + //语句:报告文本视图变化监听器没有设置 + Log.d(TAG, "OnTextViewChangeListener was not seted"); + } + break; + default: + break; + } + return super.onKeyUp(keyCode, event); + } + + /** + * 处理当前视图下的焦点改变事件 + * @param focused 代表获得或失去焦点 + * @param direction + * @param previouslyFocusedRect 上一个访问的焦点区域 + */ + @Override + protected void onFocusChanged(boolean focused, int direction, Rect previouslyFocusedRect) { + //语句块:如果文本视图发生变化 + if (mOnTextViewChangeListener != null) { + //语句块:当焦点存在或者当前文本不为空时,监听文本的变化 + if (!focused && TextUtils.isEmpty(getText())) { + mOnTextViewChangeListener.onTextChange(mIndex, false); + } else { + mOnTextViewChangeListener.onTextChange(mIndex, true); + } + } + super.onFocusChanged(focused, direction, previouslyFocusedRect); + } + + /** + * 方法:创建环境菜单 + */ + @Override + protected void onCreateContextMenu(ContextMenu menu) { + if (getText() instanceof Spanned) { + //语句块:获取高亮元素 + int selStart = getSelectionStart(); + int selEnd = getSelectionEnd(); + + int min = Math.min(selStart, selEnd); + int max = Math.max(selStart, selEnd); + + final URLSpan[] urls = ((Spanned) getText()).getSpans(min, max, URLSpan.class); + //语句块:针对不同的高亮元素,使用不同的操作进行处理 + if (urls.length == 1) { + int defaultResId = 0; + for(String schema: sSchemaActionResMap.keySet()) { + if(urls[0].getURL().indexOf(schema) >= 0) { + defaultResId = sSchemaActionResMap.get(schema); + break; + } + } + + if (defaultResId == 0) { + defaultResId = R.string.note_link_other; + } + //语句块:添加环境菜单的点击事件 + menu.add(0, 0, 0, defaultResId).setOnMenuItemClickListener( + new OnMenuItemClickListener() { + public boolean onMenuItemClick(MenuItem item) { + // goto a new intent + urls[0].onClick(NoteEditText.this); + return true; + } + }); + } + } + super.onCreateContextMenu(menu); + } +} diff --git a/app/src/main/java/net/micode/notes/ui/NoteItemData.java b/app/src/main/java/net/micode/notes/ui/NoteItemData.java new file mode 100644 index 0000000..94fdab2 --- /dev/null +++ b/app/src/main/java/net/micode/notes/ui/NoteItemData.java @@ -0,0 +1,239 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.ui; + +import android.content.Context; +import android.database.Cursor; +import android.text.TextUtils; + +import net.micode.notes.data.Contact; +import net.micode.notes.data.Notes; +import net.micode.notes.data.Notes.NoteColumns; +import net.micode.notes.tool.DataUtils; + + +public class NoteItemData { + static final String [] PROJECTION = new String [] { + NoteColumns.ID, + NoteColumns.ALERTED_DATE, + NoteColumns.BG_COLOR_ID, + NoteColumns.CREATED_DATE, + NoteColumns.HAS_ATTACHMENT, + NoteColumns.MODIFIED_DATE, + NoteColumns.NOTES_COUNT, + NoteColumns.PARENT_ID, + NoteColumns.SNIPPET, + NoteColumns.TYPE, + NoteColumns.WIDGET_ID, + NoteColumns.WIDGET_TYPE, + NoteColumns.PASSWORD, + NoteColumns.IMPORTANCE + }; + + private static final int ID_COLUMN = 0; + private static final int ALERTED_DATE_COLUMN = 1; + private static final int BG_COLOR_ID_COLUMN = 2; + private static final int CREATED_DATE_COLUMN = 3; + private static final int HAS_ATTACHMENT_COLUMN = 4; + private static final int MODIFIED_DATE_COLUMN = 5; + private static final int NOTES_COUNT_COLUMN = 6; + private static final int PARENT_ID_COLUMN = 7; + private static final int SNIPPET_COLUMN = 8; + private static final int TYPE_COLUMN = 9; + private static final int WIDGET_ID_COLUMN = 10; + private static final int WIDGET_TYPE_COLUMN = 11; + private static final int PASSWORD = 12; + private static final int IMPORTANCE = 13; + + private long mId; + private long mAlertDate; + private int mBgColorId; + private long mCreatedDate; + private boolean mHasAttachment; + private long mModifiedDate; + private int mNotesCount; + private long mParentId; + private String mSnippet; + private int mType; + private int mWidgetId; + private int mWidgetType; + private String mName; + private String mPhoneNumber; + private String mPassword; + private int mImportance; + + private boolean mIsLastItem; + private boolean mIsFirstItem; + private boolean mIsOnlyOneItem; + private boolean mIsOneNoteFollowingFolder; + private boolean mIsMultiNotesFollowingFolder; + + public NoteItemData(Context context, Cursor cursor) { + mId = cursor.getLong(ID_COLUMN); + mAlertDate = cursor.getLong(ALERTED_DATE_COLUMN); + mBgColorId = cursor.getInt(BG_COLOR_ID_COLUMN); + mCreatedDate = cursor.getLong(CREATED_DATE_COLUMN); + mHasAttachment = (cursor.getInt(HAS_ATTACHMENT_COLUMN) > 0) ? true : false; + mModifiedDate = cursor.getLong(MODIFIED_DATE_COLUMN); + mNotesCount = cursor.getInt(NOTES_COUNT_COLUMN); + mParentId = cursor.getLong(PARENT_ID_COLUMN); + mSnippet = cursor.getString(SNIPPET_COLUMN); + mSnippet = mSnippet.replace(NoteEditActivity.TAG_CHECKED, "").replace( + NoteEditActivity.TAG_UNCHECKED, ""); + mType = cursor.getInt(TYPE_COLUMN); + mWidgetId = cursor.getInt(WIDGET_ID_COLUMN); + mWidgetType = cursor.getInt(WIDGET_TYPE_COLUMN); + mPassword = cursor.getString(PASSWORD); + mImportance = cursor.getInt(IMPORTANCE); + + mPhoneNumber = ""; + if (mParentId == Notes.ID_CALL_RECORD_FOLDER) { + mPhoneNumber = DataUtils.getCallNumberByNoteId(context.getContentResolver(), mId); + if (!TextUtils.isEmpty(mPhoneNumber)) { + mName = Contact.getContact(context, mPhoneNumber); + if (mName == null) { + mName = mPhoneNumber; + } + } + } + + if (mName == null) { + mName = ""; + } + checkPostion(cursor); + } + + private void checkPostion(Cursor cursor) { + mIsLastItem = cursor.isLast() ? true : false; + mIsFirstItem = cursor.isFirst() ? true : false; + mIsOnlyOneItem = (cursor.getCount() == 1); + mIsMultiNotesFollowingFolder = false; + mIsOneNoteFollowingFolder = false; + + if (mType == Notes.TYPE_NOTE && !mIsFirstItem) { + int position = cursor.getPosition(); + if (cursor.moveToPrevious()) { + if (cursor.getInt(TYPE_COLUMN) == Notes.TYPE_FOLDER + || cursor.getInt(TYPE_COLUMN) == Notes.TYPE_SYSTEM) { + if (cursor.getCount() > (position + 1)) { + mIsMultiNotesFollowingFolder = true; + } else { + mIsOneNoteFollowingFolder = true; + } + } + if (!cursor.moveToNext()) { + throw new IllegalStateException("cursor move to previous but can't move back"); + } + } + } + } + public boolean hasPassword() { return !mPassword.equals(""); } + + public String getPassword() { return mPassword; } + + public boolean hasImportance() { return (mImportance > 0); } + + public int getImportance() { return mImportance; } + + public boolean isOneFollowingFolder() { + return mIsOneNoteFollowingFolder; + } + + public boolean isMultiFollowingFolder() { + return mIsMultiNotesFollowingFolder; + } + + public boolean isLast() { + return mIsLastItem; + } + + public String getCallName() { + return mName; + } + + public boolean isFirst() { + return mIsFirstItem; + } + + public boolean isSingle() { + return mIsOnlyOneItem; + } + + public long getId() { + return mId; + } + + public long getAlertDate() { + return mAlertDate; + } + + public long getCreatedDate() { + return mCreatedDate; + } + + public boolean hasAttachment() { + return mHasAttachment; + } + + public long getModifiedDate() { + return mModifiedDate; + } + + public int getBgColorId() { + return mBgColorId; + } + + public long getParentId() { + return mParentId; + } + + public int getNotesCount() { + return mNotesCount; + } + + public long getFolderId () { + return mParentId; + } + + public int getType() { + return mType; + } + + public int getWidgetType() { + return mWidgetType; + } + + public int getWidgetId() { + return mWidgetId; + } + + public String getSnippet() { + return mSnippet; + } + + public boolean hasAlert() { + return (mAlertDate > 0); + } + + public boolean isCallRecord() { + return (mParentId == Notes.ID_CALL_RECORD_FOLDER && !TextUtils.isEmpty(mPhoneNumber)); + } + + public static int getNoteType(Cursor cursor) { + return cursor.getInt(TYPE_COLUMN); + } +} diff --git a/app/src/main/java/net/micode/notes/ui/NotesListActivity.java b/app/src/main/java/net/micode/notes/ui/NotesListActivity.java new file mode 100644 index 0000000..7a4c375 --- /dev/null +++ b/app/src/main/java/net/micode/notes/ui/NotesListActivity.java @@ -0,0 +1,959 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.ui; + +import android.app.Activity; +import android.app.AlertDialog; +import android.app.Dialog; +import android.appwidget.AppWidgetManager; +import android.content.AsyncQueryHandler; +import android.content.ContentResolver; +import android.content.ContentValues; +import android.content.Context; +import android.content.DialogInterface; +import android.content.Intent; +import android.content.SharedPreferences; +import android.database.Cursor; +import android.os.AsyncTask; +import android.os.Bundle; +import android.preference.PreferenceManager; +import android.text.Editable; +import android.text.TextUtils; +import android.text.TextWatcher; +import android.util.Log; +import android.view.ActionMode; +import android.view.ContextMenu; +import android.view.ContextMenu.ContextMenuInfo; +import android.view.Display; +import android.view.HapticFeedbackConstants; +import android.view.LayoutInflater; +import android.view.Menu; +import android.view.MenuItem; +import android.view.MenuItem.OnMenuItemClickListener; +import android.view.MotionEvent; +import android.view.View; +import android.view.View.OnClickListener; +import android.view.View.OnCreateContextMenuListener; +import android.view.View.OnTouchListener; +import android.view.inputmethod.InputMethodManager; +import android.widget.AdapterView; +import android.widget.AdapterView.OnItemClickListener; +import android.widget.AdapterView.OnItemLongClickListener; +import android.widget.Button; +import android.widget.EditText; +import android.widget.ListView; +import android.widget.PopupMenu; +import android.widget.TextView; +import android.widget.Toast; + +import net.micode.notes.R; +import net.micode.notes.data.Notes; +import net.micode.notes.data.Notes.NoteColumns; +import net.micode.notes.gtask.remote.GTaskSyncService; +import net.micode.notes.model.WorkingNote; +import net.micode.notes.tool.BackupUtils; +import net.micode.notes.tool.DataUtils; +import net.micode.notes.tool.ResourceParser; +import net.micode.notes.ui.NotesListAdapter.AppWidgetAttribute; +import net.micode.notes.widget.NoteWidgetProvider_2x; +import net.micode.notes.widget.NoteWidgetProvider_4x; + +import java.io.BufferedReader; +import java.io.IOException; +import java.io.InputStream; +import java.io.InputStreamReader; +import java.util.HashSet; + +public class NotesListActivity extends Activity implements OnClickListener, OnItemLongClickListener { + private static final int FOLDER_NOTE_LIST_QUERY_TOKEN = 0; + + private static final int FOLDER_LIST_QUERY_TOKEN = 1; + + private static final int MENU_FOLDER_DELETE = 0; + + private static final int MENU_FOLDER_VIEW = 1; + + private static final int MENU_FOLDER_CHANGE_NAME = 2; + + private static final String PREFERENCE_ADD_INTRODUCTION = "net.micode.notes.introduction"; + + private enum ListEditState { + NOTE_LIST, SUB_FOLDER, CALL_RECORD_FOLDER + }; + + private ListEditState mState; + + private BackgroundQueryHandler mBackgroundQueryHandler; + + private NotesListAdapter mNotesListAdapter; + + private ListView mNotesListView; + + private Button mAddNewNote; + + private boolean mDispatch; + + private int mOriginY; + + private int mDispatchY; + + private TextView mTitleBar; + + private long mCurrentFolderId; + + private ContentResolver mContentResolver; + + private ModeCallback mModeCallBack; + + private static final String TAG = "NotesListActivity"; + + public static final int NOTES_LISTVIEW_SCROLL_RATE = 30; + + private NoteItemData mFocusNoteDataItem; + + private static final String NORMAL_SELECTION = NoteColumns.PARENT_ID + "=?"; + + private static final String ROOT_FOLDER_SELECTION = "(" + NoteColumns.TYPE + "<>" + + Notes.TYPE_SYSTEM + " AND " + NoteColumns.PARENT_ID + "=?)" + " OR (" + + NoteColumns.ID + "=" + Notes.ID_CALL_RECORD_FOLDER + " AND " + + NoteColumns.NOTES_COUNT + ">0)"; + + private final static int REQUEST_CODE_OPEN_NODE = 102; + private final static int REQUEST_CODE_NEW_NODE = 103; + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setContentView(R.layout.note_list); + initResources(); + + /** + * Insert an introduction when user firstly use this application + */ + setAppInfoFromRawRes(); + } + + @Override + protected void onActivityResult(int requestCode, int resultCode, Intent data) { + if (resultCode == RESULT_OK + && (requestCode == REQUEST_CODE_OPEN_NODE || requestCode == REQUEST_CODE_NEW_NODE)) { + mNotesListAdapter.changeCursor(null); + } else { + super.onActivityResult(requestCode, resultCode, data); + } + } + + private void setAppInfoFromRawRes() { + SharedPreferences sp = PreferenceManager.getDefaultSharedPreferences(this); + if (!sp.getBoolean(PREFERENCE_ADD_INTRODUCTION, false)) { + StringBuilder sb = new StringBuilder(); + InputStream in = null; + try { + in = getResources().openRawResource(R.raw.introduction); + if (in != null) { + InputStreamReader isr = new InputStreamReader(in); + BufferedReader br = new BufferedReader(isr); + char [] buf = new char[1024]; + int len = 0; + while ((len = br.read(buf)) > 0) { + sb.append(buf, 0, len); + } + } else { + Log.e(TAG, "Read introduction file error"); + return; + } + } catch (IOException e) { + e.printStackTrace(); + return; + } finally { + if(in != null) { + try { + in.close(); + } catch (IOException e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } + } + } + + WorkingNote note = WorkingNote.createEmptyNote(this, Notes.ID_ROOT_FOLDER, + AppWidgetManager.INVALID_APPWIDGET_ID, Notes.TYPE_WIDGET_INVALIDE, + ResourceParser.RED); + note.setWorkingText(sb.toString()); + if (note.saveNote()) { + sp.edit().putBoolean(PREFERENCE_ADD_INTRODUCTION, true).commit(); + } else { + Log.e(TAG, "Save introduction note error"); + return; + } + } + } + + @Override + protected void onStart() { + super.onStart(); + startAsyncNotesListQuery(); + } + + private void initResources() { + mContentResolver = this.getContentResolver(); + mBackgroundQueryHandler = new BackgroundQueryHandler(this.getContentResolver()); + mCurrentFolderId = Notes.ID_ROOT_FOLDER; + mNotesListView = (ListView) findViewById(R.id.notes_list); + mNotesListView.addFooterView(LayoutInflater.from(this).inflate(R.layout.note_list_footer, null), + null, false); + mNotesListView.setOnItemClickListener(new OnListItemClickListener()); + mNotesListView.setOnItemLongClickListener(this); + mNotesListAdapter = new NotesListAdapter(this); + mNotesListView.setAdapter(mNotesListAdapter); + mAddNewNote = (Button) findViewById(R.id.btn_new_note); + mAddNewNote.setOnClickListener(this); + mAddNewNote.setOnTouchListener(new NewNoteOnTouchListener()); + mDispatch = false; + mDispatchY = 0; + mOriginY = 0; + mTitleBar = (TextView) findViewById(R.id.tv_title_bar); + mState = ListEditState.NOTE_LIST; + mModeCallBack = new ModeCallback(); + } + + private class ModeCallback implements ListView.MultiChoiceModeListener, OnMenuItemClickListener { + private DropdownMenu mDropDownMenu; + private ActionMode mActionMode; + private MenuItem mMoveMenu; + + public boolean onCreateActionMode(ActionMode mode, Menu menu) { + getMenuInflater().inflate(R.menu.note_list_options, menu); + menu.findItem(R.id.delete).setOnMenuItemClickListener(this); + mMoveMenu = menu.findItem(R.id.move); + if (mFocusNoteDataItem.getParentId() == Notes.ID_CALL_RECORD_FOLDER + || DataUtils.getUserFolderCount(mContentResolver) == 0) { + mMoveMenu.setVisible(false); + } else { + mMoveMenu.setVisible(true); + mMoveMenu.setOnMenuItemClickListener(this); + } + mActionMode = mode; + mNotesListAdapter.setChoiceMode(true); + mNotesListView.setLongClickable(false); + mAddNewNote.setVisibility(View.GONE); + + View customView = LayoutInflater.from(NotesListActivity.this).inflate( + R.layout.note_list_dropdown_menu, null); + mode.setCustomView(customView); + mDropDownMenu = new DropdownMenu(NotesListActivity.this, + (Button) customView.findViewById(R.id.selection_menu), + R.menu.note_list_dropdown); + mDropDownMenu.setOnDropdownMenuItemClickListener(new PopupMenu.OnMenuItemClickListener(){ + public boolean onMenuItemClick(MenuItem item) { + mNotesListAdapter.selectAll(!mNotesListAdapter.isAllSelected()); + updateMenu(); + return true; + } + + }); + return true; + } + + private void updateMenu() { + int selectedCount = mNotesListAdapter.getSelectedCount(); + // Update dropdown menu + String format = getResources().getString(R.string.menu_select_title, selectedCount); + mDropDownMenu.setTitle(format); + MenuItem item = mDropDownMenu.findItem(R.id.action_select_all); + if (item != null) { + if (mNotesListAdapter.isAllSelected()) { + item.setChecked(true); + item.setTitle(R.string.menu_deselect_all); + } else { + item.setChecked(false); + item.setTitle(R.string.menu_select_all); + } + } + } + + public boolean onPrepareActionMode(ActionMode mode, Menu menu) { + // TODO Auto-generated method stub + return false; + } + + public boolean onActionItemClicked(ActionMode mode, MenuItem item) { + // TODO Auto-generated method stub + return false; + } + + public void onDestroyActionMode(ActionMode mode) { + mNotesListAdapter.setChoiceMode(false); + mNotesListView.setLongClickable(true); + mAddNewNote.setVisibility(View.VISIBLE); + } + + public void finishActionMode() { + mActionMode.finish(); + } + + public void onItemCheckedStateChanged(ActionMode mode, int position, long id, + boolean checked) { + mNotesListAdapter.setCheckedItem(position, checked); + updateMenu(); + } + + public boolean onMenuItemClick(MenuItem item) { + if (mNotesListAdapter.getSelectedCount() == 0) { + Toast.makeText(NotesListActivity.this, getString(R.string.menu_select_none), + Toast.LENGTH_SHORT).show(); + return true; + } + + switch (item.getItemId()) { + case R.id.delete: + AlertDialog.Builder builder = new AlertDialog.Builder(NotesListActivity.this); + builder.setTitle(getString(R.string.alert_title_delete)); + builder.setIcon(android.R.drawable.ic_dialog_alert); + builder.setMessage(getString(R.string.alert_message_delete_notes, + mNotesListAdapter.getSelectedCount())); + builder.setPositiveButton(android.R.string.ok, + new DialogInterface.OnClickListener() { + public void onClick(DialogInterface dialog, + int which) { + batchDelete(); + } + }); + builder.setNegativeButton(android.R.string.cancel, null); + builder.show(); + break; + case R.id.move: + startQueryDestinationFolders(); + break; + default: + return false; + } + return true; + } + } + + private class NewNoteOnTouchListener implements OnTouchListener { + + public boolean onTouch(View v, MotionEvent event) { + switch (event.getAction()) { + case MotionEvent.ACTION_DOWN: { + Display display = getWindowManager().getDefaultDisplay(); + int screenHeight = display.getHeight(); + int newNoteViewHeight = mAddNewNote.getHeight(); + int start = screenHeight - newNoteViewHeight; + int eventY = start + (int) event.getY(); + /** + * Minus TitleBar's height + */ + if (mState == ListEditState.SUB_FOLDER) { + eventY -= mTitleBar.getHeight(); + start -= mTitleBar.getHeight(); + } + /** + * HACKME:When click the transparent part of "New Note" button, dispatch + * the event to the list view behind this button. The transparent part of + * "New Note" button could be expressed by formula y=-0.12x+94(Unit:pixel) + * and the line top of the button. The coordinate based on left of the "New + * Note" button. The 94 represents maximum height of the transparent part. + * Notice that, if the background of the button changes, the formula should + * also change. This is very bad, just for the UI designer's strong requirement. + */ + if (event.getY() < (event.getX() * (-0.12) + 94)) { + View view = mNotesListView.getChildAt(mNotesListView.getChildCount() - 1 + - mNotesListView.getFooterViewsCount()); + if (view != null && view.getBottom() > start + && (view.getTop() < (start + 94))) { + mOriginY = (int) event.getY(); + mDispatchY = eventY; + event.setLocation(event.getX(), mDispatchY); + mDispatch = true; + return mNotesListView.dispatchTouchEvent(event); + } + } + break; + } + case MotionEvent.ACTION_MOVE: { + if (mDispatch) { + mDispatchY += (int) event.getY() - mOriginY; + event.setLocation(event.getX(), mDispatchY); + return mNotesListView.dispatchTouchEvent(event); + } + break; + } + default: { + if (mDispatch) { + event.setLocation(event.getX(), mDispatchY); + mDispatch = false; + return mNotesListView.dispatchTouchEvent(event); + } + break; + } + } + return false; + } + + }; + + private void startAsyncNotesListQuery() { + String selection = (mCurrentFolderId == Notes.ID_ROOT_FOLDER) ? ROOT_FOLDER_SELECTION + : NORMAL_SELECTION; + mBackgroundQueryHandler.startQuery(FOLDER_NOTE_LIST_QUERY_TOKEN, null, + Notes.CONTENT_NOTE_URI, NoteItemData.PROJECTION, selection, new String[] { + String.valueOf(mCurrentFolderId) + }, NoteColumns.TYPE + " DESC," + NoteColumns.MODIFIED_DATE + " DESC"); + } + + private final class BackgroundQueryHandler extends AsyncQueryHandler { + public BackgroundQueryHandler(ContentResolver contentResolver) { + super(contentResolver); + } + + @Override + protected void onQueryComplete(int token, Object cookie, Cursor cursor) { + switch (token) { + case FOLDER_NOTE_LIST_QUERY_TOKEN: + mNotesListAdapter.changeCursor(cursor); + break; + case FOLDER_LIST_QUERY_TOKEN: + if (cursor != null && cursor.getCount() > 0) { + showFolderListMenu(cursor); + } else { + Log.e(TAG, "Query folder failed"); + } + break; + default: + return; + } + } + } + + /** + * 显示文件夹列表菜单,用于在选中一个到多个便签后选择文件夹进行移动时的界面,并在完成后显示相关信息 + * @param cursor + */ + private void showFolderListMenu(Cursor cursor) { + AlertDialog.Builder builder = new AlertDialog.Builder(NotesListActivity.this); + builder.setTitle(R.string.menu_title_select_folder); + final FoldersListAdapter adapter = new FoldersListAdapter(this, cursor); + builder.setAdapter(adapter, new DialogInterface.OnClickListener() { + + public void onClick(DialogInterface dialog, int which) { + DataUtils.batchMoveToFolder(mContentResolver, + mNotesListAdapter.getSelectedItemIds(), adapter.getItemId(which)); + Toast.makeText( + NotesListActivity.this, + getString(R.string.format_move_notes_to_folder, + mNotesListAdapter.getSelectedCount(), + adapter.getFolderName(NotesListActivity.this, which)), + Toast.LENGTH_SHORT).show(); + mModeCallBack.finishActionMode(); + } + }); + builder.show(); + } + + private void createNewNote() { + Intent intent = new Intent(this, NoteEditActivity.class); + intent.setAction(Intent.ACTION_INSERT_OR_EDIT); + intent.putExtra(Notes.INTENT_EXTRA_FOLDER_ID, mCurrentFolderId); + this.startActivityForResult(intent, REQUEST_CODE_NEW_NODE); + } + + private void batchDelete() { + new AsyncTask>() { + protected HashSet doInBackground(Void... unused) { + HashSet widgets = mNotesListAdapter.getSelectedWidget(); + if (!isSyncMode()) { + // if not synced, delete notes directly + if (DataUtils.batchDeleteNotes(mContentResolver, mNotesListAdapter + .getSelectedItemIds())) { + } else { + Log.e(TAG, "Delete notes error, should not happens"); + } + } else { + // in sync mode, we'll move the deleted note into the trash + // folder + if (!DataUtils.batchMoveToFolder(mContentResolver, mNotesListAdapter + .getSelectedItemIds(), Notes.ID_TRASH_FOLER)) { + Log.e(TAG, "Move notes to trash folder error, should not happens"); + } + } + return widgets; + } + + @Override + protected void onPostExecute(HashSet widgets) { + if (widgets != null) { + for (AppWidgetAttribute widget : widgets) { + if (widget.widgetId != AppWidgetManager.INVALID_APPWIDGET_ID + && widget.widgetType != Notes.TYPE_WIDGET_INVALIDE) { + updateWidget(widget.widgetId, widget.widgetType); + } + } + } + mModeCallBack.finishActionMode(); + } + }.execute(); + } + + private void deleteFolder(long folderId) { + if (folderId == Notes.ID_ROOT_FOLDER) { + Log.e(TAG, "Wrong folder id, should not happen " + folderId); + return; + } + + HashSet ids = new HashSet(); + ids.add(folderId); + HashSet widgets = DataUtils.getFolderNoteWidget(mContentResolver, + folderId); + if (!isSyncMode()) { + // if not synced, delete folder directly + DataUtils.batchDeleteNotes(mContentResolver, ids); + } else { + // in sync mode, we'll move the deleted folder into the trash folder + DataUtils.batchMoveToFolder(mContentResolver, ids, Notes.ID_TRASH_FOLER); + } + if (widgets != null) { + for (AppWidgetAttribute widget : widgets) { + if (widget.widgetId != AppWidgetManager.INVALID_APPWIDGET_ID + && widget.widgetType != Notes.TYPE_WIDGET_INVALIDE) { + updateWidget(widget.widgetId, widget.widgetType); + } + } + } + } + + private void openNode(NoteItemData data) { + Intent intent = new Intent(this, NoteEditActivity.class); + intent.setAction(Intent.ACTION_VIEW); + intent.putExtra(Intent.EXTRA_UID, data.getId()); + this.startActivityForResult(intent, REQUEST_CODE_OPEN_NODE); + + } + + private void openFolder(NoteItemData data) { + mCurrentFolderId = data.getId(); + startAsyncNotesListQuery(); + if (data.getId() == Notes.ID_CALL_RECORD_FOLDER) { + mState = ListEditState.CALL_RECORD_FOLDER; + mAddNewNote.setVisibility(View.GONE); + } else { + mState = ListEditState.SUB_FOLDER; + } + if (data.getId() == Notes.ID_CALL_RECORD_FOLDER) { + mTitleBar.setText(R.string.call_record_folder_name); + } else { + mTitleBar.setText(data.getSnippet()); + } + mTitleBar.setVisibility(View.VISIBLE); + } + + public void onClick(View v) { + switch (v.getId()) { + case R.id.btn_new_note: + createNewNote(); + break; + default: + break; + } + } + + private void showSoftInput() { + InputMethodManager inputMethodManager = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE); + if (inputMethodManager != null) { + inputMethodManager.toggleSoftInput(InputMethodManager.SHOW_FORCED, 0); + } + } + + private void hideSoftInput(View view) { + InputMethodManager inputMethodManager = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE); + inputMethodManager.hideSoftInputFromWindow(view.getWindowToken(), 0); + } + + private void showCreateOrModifyFolderDialog(final boolean create) { + final AlertDialog.Builder builder = new AlertDialog.Builder(this); + View view = LayoutInflater.from(this).inflate(R.layout.dialog_edit_text, null); + final EditText etName = (EditText) view.findViewById(R.id.et_foler_name); + showSoftInput(); + if (!create) { + if (mFocusNoteDataItem != null) { + etName.setText(mFocusNoteDataItem.getSnippet()); + builder.setTitle(getString(R.string.menu_folder_change_name)); + } else { + Log.e(TAG, "The long click data item is null"); + return; + } + } else { + etName.setText(""); + builder.setTitle(this.getString(R.string.menu_create_folder)); + } + + builder.setPositiveButton(android.R.string.ok, null); + builder.setNegativeButton(android.R.string.cancel, new DialogInterface.OnClickListener() { + public void onClick(DialogInterface dialog, int which) { + hideSoftInput(etName); + } + }); + + final Dialog dialog = builder.setView(view).show(); + final Button positive = (Button)dialog.findViewById(android.R.id.button1); + positive.setOnClickListener(new OnClickListener() { + public void onClick(View v) { + hideSoftInput(etName); + String name = etName.getText().toString(); + if (DataUtils.checkVisibleFolderName(mContentResolver, name)) { + Toast.makeText(NotesListActivity.this, getString(R.string.folder_exist, name), + Toast.LENGTH_LONG).show(); + etName.setSelection(0, etName.length()); + return; + } + if (!create) { + if (!TextUtils.isEmpty(name)) { + ContentValues values = new ContentValues(); + values.put(NoteColumns.SNIPPET, name); + values.put(NoteColumns.TYPE, Notes.TYPE_FOLDER); + values.put(NoteColumns.LOCAL_MODIFIED, 1); + mContentResolver.update(Notes.CONTENT_NOTE_URI, values, NoteColumns.ID + + "=?", new String[] { + String.valueOf(mFocusNoteDataItem.getId()) + }); + } + } else if (!TextUtils.isEmpty(name)) { + ContentValues values = new ContentValues(); + values.put(NoteColumns.SNIPPET, name); + values.put(NoteColumns.TYPE, Notes.TYPE_FOLDER); + mContentResolver.insert(Notes.CONTENT_NOTE_URI, values); + } + dialog.dismiss(); + } + }); + + if (TextUtils.isEmpty(etName.getText())) { + positive.setEnabled(false); + } + /** + * When the name edit text is null, disable the positive button + */ + etName.addTextChangedListener(new TextWatcher() { + public void beforeTextChanged(CharSequence s, int start, int count, int after) { + // TODO Auto-generated method stub + + } + + public void onTextChanged(CharSequence s, int start, int before, int count) { + if (TextUtils.isEmpty(etName.getText())) { + positive.setEnabled(false); + } else { + positive.setEnabled(true); + } + } + + public void afterTextChanged(Editable s) { + // TODO Auto-generated method stub + + } + }); + } + + @Override + public void onBackPressed() { + switch (mState) { + case SUB_FOLDER: + mCurrentFolderId = Notes.ID_ROOT_FOLDER; + mState = ListEditState.NOTE_LIST; + startAsyncNotesListQuery(); + mTitleBar.setVisibility(View.GONE); + break; + case CALL_RECORD_FOLDER: + mCurrentFolderId = Notes.ID_ROOT_FOLDER; + mState = ListEditState.NOTE_LIST; + mAddNewNote.setVisibility(View.VISIBLE); + mTitleBar.setVisibility(View.GONE); + startAsyncNotesListQuery(); + break; + case NOTE_LIST: + super.onBackPressed(); + break; + default: + break; + } + } + + private void updateWidget(int appWidgetId, int appWidgetType) { + Intent intent = new Intent(AppWidgetManager.ACTION_APPWIDGET_UPDATE); + if (appWidgetType == Notes.TYPE_WIDGET_2X) { + intent.setClass(this, NoteWidgetProvider_2x.class); + } else if (appWidgetType == Notes.TYPE_WIDGET_4X) { + intent.setClass(this, NoteWidgetProvider_4x.class); + } else { + Log.e(TAG, "Unspported widget type"); + return; + } + + intent.putExtra(AppWidgetManager.EXTRA_APPWIDGET_IDS, new int[] { + appWidgetId + }); + + sendBroadcast(intent); + setResult(RESULT_OK, intent); + } + + private final OnCreateContextMenuListener mFolderOnCreateContextMenuListener = new OnCreateContextMenuListener() { + public void onCreateContextMenu(ContextMenu menu, View v, ContextMenuInfo menuInfo) { + if (mFocusNoteDataItem != null) { + menu.setHeaderTitle(mFocusNoteDataItem.getSnippet()); + menu.add(0, MENU_FOLDER_VIEW, 0, R.string.menu_folder_view); + menu.add(0, MENU_FOLDER_DELETE, 0, R.string.menu_folder_delete); + menu.add(0, MENU_FOLDER_CHANGE_NAME, 0, R.string.menu_folder_change_name); + } + } + }; + + @Override + public void onContextMenuClosed(Menu menu) { + if (mNotesListView != null) { + mNotesListView.setOnCreateContextMenuListener(null); + } + super.onContextMenuClosed(menu); + } + + @Override + public boolean onContextItemSelected(MenuItem item) { + if (mFocusNoteDataItem == null) { + Log.e(TAG, "The long click data item is null"); + return false; + } + switch (item.getItemId()) { + case MENU_FOLDER_VIEW: + openFolder(mFocusNoteDataItem); + break; + case MENU_FOLDER_DELETE: + AlertDialog.Builder builder = new AlertDialog.Builder(this); + builder.setTitle(getString(R.string.alert_title_delete)); + builder.setIcon(android.R.drawable.ic_dialog_alert); + builder.setMessage(getString(R.string.alert_message_delete_folder)); + builder.setPositiveButton(android.R.string.ok, + new DialogInterface.OnClickListener() { + public void onClick(DialogInterface dialog, int which) { + deleteFolder(mFocusNoteDataItem.getId()); + } + }); + builder.setNegativeButton(android.R.string.cancel, null); + builder.show(); + break; + case MENU_FOLDER_CHANGE_NAME: + showCreateOrModifyFolderDialog(false); + break; + default: + break; + } + + return true; + } + + @Override + public boolean onPrepareOptionsMenu(Menu menu) { + menu.clear(); + if (mState == ListEditState.NOTE_LIST) { + getMenuInflater().inflate(R.menu.note_list, menu); + // set sync or sync_cancel + menu.findItem(R.id.menu_sync).setTitle( + GTaskSyncService.isSyncing() ? R.string.menu_sync_cancel : R.string.menu_sync); + } else if (mState == ListEditState.SUB_FOLDER) { + getMenuInflater().inflate(R.menu.sub_folder, menu); + } else if (mState == ListEditState.CALL_RECORD_FOLDER) { + getMenuInflater().inflate(R.menu.call_record_folder, menu); + } else { + Log.e(TAG, "Wrong state:" + mState); + } + return true; + } + + @Override + public boolean onOptionsItemSelected(MenuItem item) { + switch (item.getItemId()) { + case R.id.menu_new_folder: { + showCreateOrModifyFolderDialog(true); + break; + } + case R.id.menu_export_text: { + exportNoteToText(); + break; + } + case R.id.menu_sync: { + if (isSyncMode()) { + if (TextUtils.equals(item.getTitle(), getString(R.string.menu_sync))) { + GTaskSyncService.startSync(this); + } else { + GTaskSyncService.cancelSync(this); + } + } else { + startPreferenceActivity(); + } + break; + } + case R.id.menu_setting: { + startPreferenceActivity(); + break; + } + case R.id.menu_new_note: { + createNewNote(); + break; + } + case R.id.menu_search: + onSearchRequested(); + break; + default: + break; + } + return true; + } + + @Override + public boolean onSearchRequested() { + startSearch(null, false, null /* appData */, false); + return true; + } + + private void exportNoteToText() { + final BackupUtils backup = BackupUtils.getInstance(NotesListActivity.this); + new AsyncTask() { + + @Override + protected Integer doInBackground(Void... unused) { + return backup.exportToText(); + } + + @Override + protected void onPostExecute(Integer result) { + if (result == BackupUtils.STATE_SD_CARD_UNMOUONTED) { + AlertDialog.Builder builder = new AlertDialog.Builder(NotesListActivity.this); + builder.setTitle(NotesListActivity.this + .getString(R.string.failed_sdcard_export)); + builder.setMessage(NotesListActivity.this + .getString(R.string.error_sdcard_unmounted)); + builder.setPositiveButton(android.R.string.ok, null); + builder.show(); + } else if (result == BackupUtils.STATE_SUCCESS) { + AlertDialog.Builder builder = new AlertDialog.Builder(NotesListActivity.this); + builder.setTitle(NotesListActivity.this + .getString(R.string.success_sdcard_export)); + builder.setMessage(NotesListActivity.this.getString( + R.string.format_exported_file_location, backup + .getExportedTextFileName(), backup.getExportedTextFileDir())); + builder.setPositiveButton(android.R.string.ok, null); + builder.show(); + } else if (result == BackupUtils.STATE_SYSTEM_ERROR) { + AlertDialog.Builder builder = new AlertDialog.Builder(NotesListActivity.this); + builder.setTitle(NotesListActivity.this + .getString(R.string.failed_sdcard_export)); + builder.setMessage(NotesListActivity.this + .getString(R.string.error_sdcard_export)); + builder.setPositiveButton(android.R.string.ok, null); + builder.show(); + } + } + + }.execute(); + } + + private boolean isSyncMode() { + return NotesPreferenceActivity.getSyncAccountName(this).trim().length() > 0; + } + + private void startPreferenceActivity() { + Activity from = getParent() != null ? getParent() : this; + Intent intent = new Intent(from, NotesPreferenceActivity.class); + from.startActivityIfNeeded(intent, -1); + } + + private class OnListItemClickListener implements OnItemClickListener { + + public void onItemClick(AdapterView parent, View view, int position, long id) { + if (view instanceof NotesListItem) { + NoteItemData item = ((NotesListItem) view).getItemData(); + if (mNotesListAdapter.isInChoiceMode()) { + if (item.getType() == Notes.TYPE_NOTE) { + position = position - mNotesListView.getHeaderViewsCount(); + mModeCallBack.onItemCheckedStateChanged(null, position, id, + !mNotesListAdapter.isSelectedItem(position)); + } + return; + } + + switch (mState) { + case NOTE_LIST: + if (item.getType() == Notes.TYPE_FOLDER + || item.getType() == Notes.TYPE_SYSTEM) { + openFolder(item); + } else if (item.getType() == Notes.TYPE_NOTE) { + openNode(item); + } else { + Log.e(TAG, "Wrong note type in NOTE_LIST"); + } + break; + case SUB_FOLDER: + case CALL_RECORD_FOLDER: + if (item.getType() == Notes.TYPE_NOTE) { + openNode(item); + } else { + Log.e(TAG, "Wrong note type in SUB_FOLDER"); + } + break; + default: + break; + } + } + } + + } + + private void startQueryDestinationFolders() { + String selection = NoteColumns.TYPE + "=? AND " + NoteColumns.PARENT_ID + "<>? AND " + NoteColumns.ID + "<>?"; + selection = (mState == ListEditState.NOTE_LIST) ? selection: + "(" + selection + ") OR (" + NoteColumns.ID + "=" + Notes.ID_ROOT_FOLDER + ")"; + + mBackgroundQueryHandler.startQuery(FOLDER_LIST_QUERY_TOKEN, + null, + Notes.CONTENT_NOTE_URI, + FoldersListAdapter.PROJECTION, + selection, + new String[] { + String.valueOf(Notes.TYPE_FOLDER), + String.valueOf(Notes.ID_TRASH_FOLER), + String.valueOf(mCurrentFolderId) + }, + NoteColumns.MODIFIED_DATE + " DESC"); + } + + public boolean onItemLongClick(AdapterView parent, View view, int position, long id) { + if (view instanceof NotesListItem) { + mFocusNoteDataItem = ((NotesListItem) view).getItemData(); + if (mFocusNoteDataItem.getType() == Notes.TYPE_NOTE && !mNotesListAdapter.isInChoiceMode()) { + if (mNotesListView.startActionMode(mModeCallBack) != null) { + mModeCallBack.onItemCheckedStateChanged(null, position, id, true); + mNotesListView.performHapticFeedback(HapticFeedbackConstants.LONG_PRESS); + } else { + Log.e(TAG, "startActionMode fails"); + } + } else if (mFocusNoteDataItem.getType() == Notes.TYPE_FOLDER) { + mNotesListView.setOnCreateContextMenuListener(mFolderOnCreateContextMenuListener); + } + } + return false; + } +} diff --git a/app/src/main/java/net/micode/notes/ui/NotesListAdapter.java b/app/src/main/java/net/micode/notes/ui/NotesListAdapter.java new file mode 100644 index 0000000..51c9cb9 --- /dev/null +++ b/app/src/main/java/net/micode/notes/ui/NotesListAdapter.java @@ -0,0 +1,184 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.ui; + +import android.content.Context; +import android.database.Cursor; +import android.util.Log; +import android.view.View; +import android.view.ViewGroup; +import android.widget.CursorAdapter; + +import net.micode.notes.data.Notes; + +import java.util.Collection; +import java.util.HashMap; +import java.util.HashSet; +import java.util.Iterator; + + +public class NotesListAdapter extends CursorAdapter { + private static final String TAG = "NotesListAdapter"; + private Context mContext; + private HashMap mSelectedIndex; + private int mNotesCount; + private boolean mChoiceMode; + + public static class AppWidgetAttribute { + public int widgetId; + public int widgetType; + }; + + public NotesListAdapter(Context context) { + super(context, null); + mSelectedIndex = new HashMap(); + mContext = context; + mNotesCount = 0; + } + + @Override + public View newView(Context context, Cursor cursor, ViewGroup parent) { + return new NotesListItem(context); + } + + @Override + public void bindView(View view, Context context, Cursor cursor) { + if (view instanceof NotesListItem) { + NoteItemData itemData = new NoteItemData(context, cursor); + ((NotesListItem) view).bind(context, itemData, mChoiceMode, + isSelectedItem(cursor.getPosition())); + } + } + + public void setCheckedItem(final int position, final boolean checked) { + mSelectedIndex.put(position, checked); + notifyDataSetChanged(); + } + + public boolean isInChoiceMode() { + return mChoiceMode; + } + + public void setChoiceMode(boolean mode) { + mSelectedIndex.clear(); + mChoiceMode = mode; + } + + public void selectAll(boolean checked) { + Cursor cursor = getCursor(); + for (int i = 0; i < getCount(); i++) { + if (cursor.moveToPosition(i)) { + if (NoteItemData.getNoteType(cursor) == Notes.TYPE_NOTE) { + setCheckedItem(i, checked); + } + } + } + } + + public HashSet getSelectedItemIds() { + HashSet itemSet = new HashSet(); + for (Integer position : mSelectedIndex.keySet()) { + if (mSelectedIndex.get(position) == true) { + Long id = getItemId(position); + if (id == Notes.ID_ROOT_FOLDER) { + Log.d(TAG, "Wrong item id, should not happen"); + } else { + itemSet.add(id); + } + } + } + + return itemSet; + } + + public HashSet getSelectedWidget() { + HashSet itemSet = new HashSet(); + for (Integer position : mSelectedIndex.keySet()) { + if (mSelectedIndex.get(position) == true) { + Cursor c = (Cursor) getItem(position); + if (c != null) { + AppWidgetAttribute widget = new AppWidgetAttribute(); + NoteItemData item = new NoteItemData(mContext, c); + widget.widgetId = item.getWidgetId(); + widget.widgetType = item.getWidgetType(); + itemSet.add(widget); + /** + * Don't close cursor here, only the adapter could close it + */ + } else { + Log.e(TAG, "Invalid cursor"); + return null; + } + } + } + return itemSet; + } + + public int getSelectedCount() { + Collection values = mSelectedIndex.values(); + if (null == values) { + return 0; + } + Iterator iter = values.iterator(); + int count = 0; + while (iter.hasNext()) { + if (true == iter.next()) { + count++; + } + } + return count; + } + + public boolean isAllSelected() { + int checkedCount = getSelectedCount(); + return (checkedCount != 0 && checkedCount == mNotesCount); + } + + public boolean isSelectedItem(final int position) { + if (null == mSelectedIndex.get(position)) { + return false; + } + return mSelectedIndex.get(position); + } + + @Override + protected void onContentChanged() { + super.onContentChanged(); + calcNotesCount(); + } + + @Override + public void changeCursor(Cursor cursor) { + super.changeCursor(cursor); + calcNotesCount(); + } + + private void calcNotesCount() { + mNotesCount = 0; + for (int i = 0; i < getCount(); i++) { + Cursor c = (Cursor) getItem(i); + if (c != null) { + if (NoteItemData.getNoteType(c) == Notes.TYPE_NOTE) { + mNotesCount++; + } + } else { + Log.e(TAG, "Invalid cursor"); + return; + } + } + } +} diff --git a/app/src/main/java/net/micode/notes/ui/NotesListItem.java b/app/src/main/java/net/micode/notes/ui/NotesListItem.java new file mode 100644 index 0000000..8172014 --- /dev/null +++ b/app/src/main/java/net/micode/notes/ui/NotesListItem.java @@ -0,0 +1,157 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.ui; + +import android.content.Context; +import android.text.format.DateUtils; +import android.view.View; +import android.widget.CheckBox; +import android.widget.ImageView; +import android.widget.LinearLayout; +import android.widget.TextView; + +import net.micode.notes.R; +import net.micode.notes.data.Notes; +import net.micode.notes.tool.DataUtils; +import net.micode.notes.tool.ResourceParser.NoteItemBgResources; + + +public class NotesListItem extends LinearLayout { + private ImageView mAlert; + private ImageView mLock; + private TextView mTitle; + private TextView mTime; + private TextView mCallName; + private NoteItemData mItemData; + private CheckBox mCheckBox; + private ImageView mLabel; + + public NotesListItem(Context context) { + super(context); + inflate(context, R.layout.note_item, this); + mAlert = (ImageView) findViewById(R.id.iv_alert_icon); + mLock = (ImageView) findViewById(R.id.iv_lock_icon); + mTitle = (TextView) findViewById(R.id.tv_title); + mTime = (TextView) findViewById(R.id.tv_time); + mCallName = (TextView) findViewById(R.id.tv_name); + mCheckBox = (CheckBox) findViewById(android.R.id.checkbox); + mLabel= (ImageView) findViewById(R.id.iv_importance); + } + + public void bind(Context context, NoteItemData data, boolean choiceMode, boolean checked) { + if (choiceMode && data.getType() == Notes.TYPE_NOTE) { + mCheckBox.setVisibility(View.VISIBLE); + mCheckBox.setChecked(checked); + } else { + mCheckBox.setVisibility(View.GONE); + } + + mItemData = data; + if (data.getId() == Notes.ID_CALL_RECORD_FOLDER) { + mCallName.setVisibility(View.GONE); + mAlert.setVisibility(View.VISIBLE); + mTitle.setTextAppearance(context, R.style.TextAppearancePrimaryItem); + mTitle.setText(context.getString(R.string.call_record_folder_name) + + context.getString(R.string.format_folder_files_count, data.getNotesCount())); + mAlert.setImageResource(R.drawable.call_record); + } else if (data.getParentId() == Notes.ID_CALL_RECORD_FOLDER) { + mCallName.setVisibility(View.VISIBLE); + mCallName.setText(data.getCallName()); + mTitle.setTextAppearance(context,R.style.TextAppearanceSecondaryItem); + mTitle.setText(DataUtils.getFormattedSnippet(data.getSnippet())); + if (data.hasAlert()) { + mAlert.setImageResource(R.drawable.clock); + mAlert.setVisibility(View.VISIBLE); + } else { + mAlert.setVisibility(View.GONE); + } + } else { + mCallName.setVisibility(View.GONE); + mTitle.setTextAppearance(context, R.style.TextAppearancePrimaryItem); + + if (data.getType() == Notes.TYPE_FOLDER) { + mTitle.setText(data.getSnippet() + + context.getString(R.string.format_folder_files_count, + data.getNotesCount())); + mAlert.setVisibility(View.GONE); + } else { + mTitle.setText(DataUtils.getFormattedSnippet(data.getSnippet())); + if (data.hasAlert()) { + mAlert.setImageResource(R.drawable.clock); + mAlert.setVisibility(View.VISIBLE); + } else { + mAlert.setVisibility(View.GONE); + } + if (data.hasPassword()) { + mLock.setImageResource(R.drawable.lock); + mLock.setVisibility(View.VISIBLE); + } else { + mLock.setVisibility(View.GONE); + } + } + } + mTime.setText(DateUtils.getRelativeTimeSpanString(data.getModifiedDate())); + + if(data.hasImportance()){ + switch (data.getImportance()) { + case 1: + mLabel.setImageResource(R.drawable.attention1); + break; + case 2: + mLabel.setImageResource(R.drawable.attention2); + break; + case 3: + mLabel.setImageResource(R.drawable.attention3); + break; + case 4: + mLabel.setImageResource(R.drawable.attention4); + break; + case 5: + mLabel.setImageResource(R.drawable.attention5); + break; + default: + // mLabel.setImageResource(R.drawable.attention0); + + } + }else{ + //mLabel.setImageResource(R.drawable.attention0); + } + mLabel.setVisibility(View.VISIBLE); + setBackground(data); + } + + private void setBackground(NoteItemData data) { + int id = data.getBgColorId(); + if (data.getType() == Notes.TYPE_NOTE) { + if (data.isSingle() || data.isOneFollowingFolder()) { + setBackgroundResource(NoteItemBgResources.getNoteBgSingleRes(id)); + } else if (data.isLast()) { + setBackgroundResource(NoteItemBgResources.getNoteBgLastRes(id)); + } else if (data.isFirst() || data.isMultiFollowingFolder()) { + setBackgroundResource(NoteItemBgResources.getNoteBgFirstRes(id)); + } else { + setBackgroundResource(NoteItemBgResources.getNoteBgNormalRes(id)); + } + } else { + setBackgroundResource(NoteItemBgResources.getFolderBgRes()); + } + } + + public NoteItemData getItemData() { + return mItemData; + } +} diff --git a/app/src/main/java/net/micode/notes/ui/NotesPreferenceActivity.java b/app/src/main/java/net/micode/notes/ui/NotesPreferenceActivity.java new file mode 100644 index 0000000..07c5f7e --- /dev/null +++ b/app/src/main/java/net/micode/notes/ui/NotesPreferenceActivity.java @@ -0,0 +1,388 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.ui; + +import android.accounts.Account; +import android.accounts.AccountManager; +import android.app.ActionBar; +import android.app.AlertDialog; +import android.content.BroadcastReceiver; +import android.content.ContentValues; +import android.content.Context; +import android.content.DialogInterface; +import android.content.Intent; +import android.content.IntentFilter; +import android.content.SharedPreferences; +import android.os.Bundle; +import android.preference.Preference; +import android.preference.Preference.OnPreferenceClickListener; +import android.preference.PreferenceActivity; +import android.preference.PreferenceCategory; +import android.text.TextUtils; +import android.text.format.DateFormat; +import android.view.LayoutInflater; +import android.view.Menu; +import android.view.MenuItem; +import android.view.View; +import android.widget.Button; +import android.widget.TextView; +import android.widget.Toast; + +import net.micode.notes.R; +import net.micode.notes.data.Notes; +import net.micode.notes.data.Notes.NoteColumns; +import net.micode.notes.gtask.remote.GTaskSyncService; + + +public class NotesPreferenceActivity extends PreferenceActivity { + public static final String PREFERENCE_NAME = "notes_preferences"; + + public static final String PREFERENCE_SYNC_ACCOUNT_NAME = "pref_key_account_name"; + + public static final String PREFERENCE_LAST_SYNC_TIME = "pref_last_sync_time"; + + public static final String PREFERENCE_SET_BG_COLOR_KEY = "pref_key_bg_random_appear"; + + private static final String PREFERENCE_SYNC_ACCOUNT_KEY = "pref_sync_account_key"; + + private static final String AUTHORITIES_FILTER_KEY = "authorities"; + + private PreferenceCategory mAccountCategory; + + private GTaskReceiver mReceiver; + + private Account[] mOriAccounts; + + private boolean mHasAddedAccount; + + @Override + protected void onCreate(Bundle icicle) { + super.onCreate(icicle); + + /* using the app icon for navigation */ + getActionBar().setDisplayHomeAsUpEnabled(true); + + addPreferencesFromResource(R.xml.preferences); + mAccountCategory = (PreferenceCategory) findPreference(PREFERENCE_SYNC_ACCOUNT_KEY); + mReceiver = new GTaskReceiver(); + IntentFilter filter = new IntentFilter(); + filter.addAction(GTaskSyncService.GTASK_SERVICE_BROADCAST_NAME); + registerReceiver(mReceiver, filter); + + mOriAccounts = null; + View header = LayoutInflater.from(this).inflate(R.layout.settings_header, null); + getListView().addHeaderView(header, null, true); + } + + @Override + protected void onResume() { + super.onResume(); + + // need to set sync account automatically if user has added a new + // account + if (mHasAddedAccount) { + Account[] accounts = getGoogleAccounts(); + if (mOriAccounts != null && accounts.length > mOriAccounts.length) { + for (Account accountNew : accounts) { + boolean found = false; + for (Account accountOld : mOriAccounts) { + if (TextUtils.equals(accountOld.name, accountNew.name)) { + found = true; + break; + } + } + if (!found) { + setSyncAccount(accountNew.name); + break; + } + } + } + } + + refreshUI(); + } + + @Override + protected void onDestroy() { + if (mReceiver != null) { + unregisterReceiver(mReceiver); + } + super.onDestroy(); + } + + private void loadAccountPreference() { + mAccountCategory.removeAll(); + + Preference accountPref = new Preference(this); + final String defaultAccount = getSyncAccountName(this); + accountPref.setTitle(getString(R.string.preferences_account_title)); + accountPref.setSummary(getString(R.string.preferences_account_summary)); + accountPref.setOnPreferenceClickListener(new OnPreferenceClickListener() { + public boolean onPreferenceClick(Preference preference) { + if (!GTaskSyncService.isSyncing()) { + if (TextUtils.isEmpty(defaultAccount)) { + // the first time to set account + showSelectAccountAlertDialog(); + } else { + // if the account has already been set, we need to promp + // user about the risk + showChangeAccountConfirmAlertDialog(); + } + } else { + Toast.makeText(NotesPreferenceActivity.this, + R.string.preferences_toast_cannot_change_account, Toast.LENGTH_SHORT) + .show(); + } + return true; + } + }); + + mAccountCategory.addPreference(accountPref); + } + + private void loadSyncButton() { + Button syncButton = (Button) findViewById(R.id.preference_sync_button); + TextView lastSyncTimeView = (TextView) findViewById(R.id.prefenerece_sync_status_textview); + + // set button state + if (GTaskSyncService.isSyncing()) { + syncButton.setText(getString(R.string.preferences_button_sync_cancel)); + syncButton.setOnClickListener(new View.OnClickListener() { + public void onClick(View v) { + GTaskSyncService.cancelSync(NotesPreferenceActivity.this); + } + }); + } else { + syncButton.setText(getString(R.string.preferences_button_sync_immediately)); + syncButton.setOnClickListener(new View.OnClickListener() { + public void onClick(View v) { + GTaskSyncService.startSync(NotesPreferenceActivity.this); + } + }); + } + syncButton.setEnabled(!TextUtils.isEmpty(getSyncAccountName(this))); + + // set last sync time + if (GTaskSyncService.isSyncing()) { + lastSyncTimeView.setText(GTaskSyncService.getProgressString()); + lastSyncTimeView.setVisibility(View.VISIBLE); + } else { + long lastSyncTime = getLastSyncTime(this); + if (lastSyncTime != 0) { + lastSyncTimeView.setText(getString(R.string.preferences_last_sync_time, + DateFormat.format(getString(R.string.preferences_last_sync_time_format), + lastSyncTime))); + lastSyncTimeView.setVisibility(View.VISIBLE); + } else { + lastSyncTimeView.setVisibility(View.GONE); + } + } + } + + private void refreshUI() { + loadAccountPreference(); + loadSyncButton(); + } + + private void showSelectAccountAlertDialog() { + AlertDialog.Builder dialogBuilder = new AlertDialog.Builder(this); + + View titleView = LayoutInflater.from(this).inflate(R.layout.account_dialog_title, null); + TextView titleTextView = (TextView) titleView.findViewById(R.id.account_dialog_title); + titleTextView.setText(getString(R.string.preferences_dialog_select_account_title)); + TextView subtitleTextView = (TextView) titleView.findViewById(R.id.account_dialog_subtitle); + subtitleTextView.setText(getString(R.string.preferences_dialog_select_account_tips)); + + dialogBuilder.setCustomTitle(titleView); + dialogBuilder.setPositiveButton(null, null); + + Account[] accounts = getGoogleAccounts(); + String defAccount = getSyncAccountName(this); + + mOriAccounts = accounts; + mHasAddedAccount = false; + + if (accounts.length > 0) { + CharSequence[] items = new CharSequence[accounts.length]; + final CharSequence[] itemMapping = items; + int checkedItem = -1; + int index = 0; + for (Account account : accounts) { + if (TextUtils.equals(account.name, defAccount)) { + checkedItem = index; + } + items[index++] = account.name; + } + dialogBuilder.setSingleChoiceItems(items, checkedItem, + new DialogInterface.OnClickListener() { + public void onClick(DialogInterface dialog, int which) { + setSyncAccount(itemMapping[which].toString()); + dialog.dismiss(); + refreshUI(); + } + }); + } + + View addAccountView = LayoutInflater.from(this).inflate(R.layout.add_account_text, null); + dialogBuilder.setView(addAccountView); + + final AlertDialog dialog = dialogBuilder.show(); + addAccountView.setOnClickListener(new View.OnClickListener() { + public void onClick(View v) { + mHasAddedAccount = true; + Intent intent = new Intent("android.settings.ADD_ACCOUNT_SETTINGS"); + intent.putExtra(AUTHORITIES_FILTER_KEY, new String[] { + "gmail-ls" + }); + startActivityForResult(intent, -1); + dialog.dismiss(); + } + }); + } + + private void showChangeAccountConfirmAlertDialog() { + AlertDialog.Builder dialogBuilder = new AlertDialog.Builder(this); + + View titleView = LayoutInflater.from(this).inflate(R.layout.account_dialog_title, null); + TextView titleTextView = (TextView) titleView.findViewById(R.id.account_dialog_title); + titleTextView.setText(getString(R.string.preferences_dialog_change_account_title, + getSyncAccountName(this))); + TextView subtitleTextView = (TextView) titleView.findViewById(R.id.account_dialog_subtitle); + subtitleTextView.setText(getString(R.string.preferences_dialog_change_account_warn_msg)); + dialogBuilder.setCustomTitle(titleView); + + CharSequence[] menuItemArray = new CharSequence[] { + getString(R.string.preferences_menu_change_account), + getString(R.string.preferences_menu_remove_account), + getString(R.string.preferences_menu_cancel) + }; + dialogBuilder.setItems(menuItemArray, new DialogInterface.OnClickListener() { + public void onClick(DialogInterface dialog, int which) { + if (which == 0) { + showSelectAccountAlertDialog(); + } else if (which == 1) { + removeSyncAccount(); + refreshUI(); + } + } + }); + dialogBuilder.show(); + } + + private Account[] getGoogleAccounts() { + AccountManager accountManager = AccountManager.get(this); + return accountManager.getAccountsByType("com.google"); + } + + private void setSyncAccount(String account) { + if (!getSyncAccountName(this).equals(account)) { + SharedPreferences settings = getSharedPreferences(PREFERENCE_NAME, Context.MODE_PRIVATE); + SharedPreferences.Editor editor = settings.edit(); + if (account != null) { + editor.putString(PREFERENCE_SYNC_ACCOUNT_NAME, account); + } else { + editor.putString(PREFERENCE_SYNC_ACCOUNT_NAME, ""); + } + editor.commit(); + + // clean up last sync time + setLastSyncTime(this, 0); + + // clean up local gtask related info + new Thread(new Runnable() { + public void run() { + ContentValues values = new ContentValues(); + values.put(NoteColumns.GTASK_ID, ""); + values.put(NoteColumns.SYNC_ID, 0); + getContentResolver().update(Notes.CONTENT_NOTE_URI, values, null, null); + } + }).start(); + + Toast.makeText(NotesPreferenceActivity.this, + getString(R.string.preferences_toast_success_set_accout, account), + Toast.LENGTH_SHORT).show(); + } + } + + private void removeSyncAccount() { + SharedPreferences settings = getSharedPreferences(PREFERENCE_NAME, Context.MODE_PRIVATE); + SharedPreferences.Editor editor = settings.edit(); + if (settings.contains(PREFERENCE_SYNC_ACCOUNT_NAME)) { + editor.remove(PREFERENCE_SYNC_ACCOUNT_NAME); + } + if (settings.contains(PREFERENCE_LAST_SYNC_TIME)) { + editor.remove(PREFERENCE_LAST_SYNC_TIME); + } + editor.commit(); + + // clean up local gtask related info + new Thread(new Runnable() { + public void run() { + ContentValues values = new ContentValues(); + values.put(NoteColumns.GTASK_ID, ""); + values.put(NoteColumns.SYNC_ID, 0); + getContentResolver().update(Notes.CONTENT_NOTE_URI, values, null, null); + } + }).start(); + } + + public static String getSyncAccountName(Context context) { + SharedPreferences settings = context.getSharedPreferences(PREFERENCE_NAME, + Context.MODE_PRIVATE); + return settings.getString(PREFERENCE_SYNC_ACCOUNT_NAME, ""); + } + + public static void setLastSyncTime(Context context, long time) { + SharedPreferences settings = context.getSharedPreferences(PREFERENCE_NAME, + Context.MODE_PRIVATE); + SharedPreferences.Editor editor = settings.edit(); + editor.putLong(PREFERENCE_LAST_SYNC_TIME, time); + editor.commit(); + } + + public static long getLastSyncTime(Context context) { + SharedPreferences settings = context.getSharedPreferences(PREFERENCE_NAME, + Context.MODE_PRIVATE); + return settings.getLong(PREFERENCE_LAST_SYNC_TIME, 0); + } + + private class GTaskReceiver extends BroadcastReceiver { + + @Override + public void onReceive(Context context, Intent intent) { + refreshUI(); + if (intent.getBooleanExtra(GTaskSyncService.GTASK_SERVICE_BROADCAST_IS_SYNCING, false)) { + TextView syncStatus = (TextView) findViewById(R.id.prefenerece_sync_status_textview); + syncStatus.setText(intent + .getStringExtra(GTaskSyncService.GTASK_SERVICE_BROADCAST_PROGRESS_MSG)); + } + + } + } + + public boolean onOptionsItemSelected(MenuItem item) { + switch (item.getItemId()) { + case android.R.id.home: + Intent intent = new Intent(this, NotesListActivity.class); + intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP); + startActivity(intent); + return true; + default: + return false; + } + } +} diff --git a/app/src/main/java/net/micode/notes/ui/OnPasswordInputFinish.java b/app/src/main/java/net/micode/notes/ui/OnPasswordInputFinish.java new file mode 100644 index 0000000..1023419 --- /dev/null +++ b/app/src/main/java/net/micode/notes/ui/OnPasswordInputFinish.java @@ -0,0 +1,5 @@ +package net.micode.notes.ui; + +public interface OnPasswordInputFinish { + void inputFinish(); +} diff --git a/app/src/main/java/net/micode/notes/ui/PasswordView.java b/app/src/main/java/net/micode/notes/ui/PasswordView.java new file mode 100644 index 0000000..2399968 --- /dev/null +++ b/app/src/main/java/net/micode/notes/ui/PasswordView.java @@ -0,0 +1,219 @@ +package net.micode.notes.ui; + +import android.text.Editable; +import android.text.TextWatcher; +import android.view.View; +import android.view.ViewGroup; +import android.widget.AdapterView; +import android.widget.BaseAdapter; +import android.widget.RelativeLayout; +import android.content.Context; +import android.util.AttributeSet; +import android.widget.ImageView; +import android.widget.GridView; +import android.widget.TextView; +import android.widget.Toast; + +import net.micode.notes.R; + +import java.util.HashMap; +import java.util.ArrayList; +import java.util.Map; + +public class PasswordView extends RelativeLayout implements View.OnClickListener { + Context context; + + private String strPassword; //输入的密码 + private TextView[] tvList; //用数组保存4个TextView + private GridView gridView; //GridView布局键盘 + private ArrayList> valueList; //要用Adapter中适配,用数组不能往adapter中填充 + + private ImageView imgCancel; + + private int currentIndex = -1; //用于记录当前输入密码格位置 + + /** + * 声明整型常量用于描述三种不同的口令输入界面 + */ + public static final int NEW_PWD_VIEW = 0; //表示“设置便签访问密码”界面的序号 + public static final int RPT_PWD_VIEW = 1; //表示“确认设置访问密码”界面的序号 + public static final int CUR_PWD_VIEW = 2; //表示“根据密码访问便签”界面的序号 + + + public PasswordView(Context context, int mode) { + this(context, null, mode); + } + + /** + * 该构造方法用于在界面上方创建便签输入的界面 + * @param context 便签密码输入界面的上下文 + * @param attrs 便签密码输入界面的控件参数 + * @param mode 便签密码输入界面的序号 + */ + public PasswordView(Context context, AttributeSet attrs, int mode) { + //调用父类方法处理参数 + super(context, attrs); + this.context = context; + View view; + /** + * 根据输入参数mode跳转到不同的界面 + */ + switch (mode) { + case NEW_PWD_VIEW: + view = View.inflate(context, R.layout.note_encryption, null); + break; + case RPT_PWD_VIEW: + view = View.inflate(context, R.layout.note_encryption_repeat, null); + break; + case CUR_PWD_VIEW: + view = View.inflate(context, R.layout.note_decryption, null); + break; + default: + view = View.inflate(context, R.layout.homepage, null); + } + + valueList = new ArrayList>(); + tvList = new TextView[4]; + + imgCancel = (ImageView) view.findViewById(R.id.img_cancel); + imgCancel.setOnClickListener(this); + + tvList[0] = (TextView) view.findViewById(R.id.tv_pass1); + tvList[1] = (TextView) view.findViewById(R.id.tv_pass2); + tvList[2] = (TextView) view.findViewById(R.id.tv_pass3); + tvList[3] = (TextView) view.findViewById(R.id.tv_pass4); + + gridView = (GridView) view.findViewById(R.id.gv_keyboard); + + setView(); + addView(view); //必须要,不然不显示控件 + } + + @Override + public void onClick(View v) { + switch (v.getId()) { + case R.id.img_cancel: + Toast.makeText(context, "Cancel", Toast.LENGTH_SHORT).show(); + break; + } + } + + private void setView() { + /* 初始化按钮上应该显示的数字 */ + for (int i = 1; i < 13; i++) { + Map map = new HashMap(); + if (i < 10) { + map.put("name", String.valueOf(i)); + } else if (i == 10) { + map.put("name", ""); + } else if (i == 12) { + map.put("name", "<<-"); + } else if (i == 11) { + map.put("name", String.valueOf(0)); + } + valueList.add(map); + } + + gridView.setAdapter(adapter); + gridView.setOnItemClickListener(new AdapterView.OnItemClickListener() { + @Override + public void onItemClick(AdapterView parent, View view, int position, long id) { + if (position < 11 && position != 9) { //点击0~9按钮 + if (currentIndex >= -1 && currentIndex < 3) { //判断输入位置————要小心数组越界 + tvList[++currentIndex].setText(valueList.get(position).get("name")); + } + } else { + if (position == 11) { //点击退格键 + if (currentIndex - 1 >= -1) { //判断是否删除完毕————要小心数组越界 + tvList[currentIndex--].setText(""); + } + } + } + } + }); + } + + //设置监听方法,在第6位输入完成后触发 + public void setOnFinishInput(final OnPasswordInputFinish pass) { + tvList[3].addTextChangedListener(new TextWatcher() { + @Override + public void beforeTextChanged(CharSequence s, int start, int count, int after) { + + } + + @Override + public void onTextChanged(CharSequence s, int start, int before, int count) { + + } + + @Override + public void afterTextChanged(Editable s) { + if (s.toString().length() == 1) { + strPassword = ""; //每次触发都要先将strPassword置空,再重新获取,避免由于输入删除再输入造成混乱 + for (int i = 0; i < 4; i++) { + strPassword += tvList[i].getText().toString().trim(); + } + pass.inputFinish(); //接口中要实现的方法,完成密码输入完成后的响应逻辑 + } + } + }); + } + + /* 获取输入的密码 */ + public String getStrPassword() { + return strPassword; + } + + /* 暴露取消支付的按钮,可以灵活改变响应 */ + public ImageView getCancelImageView() { + return imgCancel; + } + + //GridView的适配器 + BaseAdapter adapter = new BaseAdapter() { + @Override + public int getCount() { + return valueList.size(); + } + + @Override + public Object getItem(int position) { + return valueList.get(position); + } + + @Override + public long getItemId(int position) { + return position; + } + + @Override + public View getView(int position, View convertView, ViewGroup parent) { + ViewHolder viewHolder; + if (convertView == null) { + convertView = View.inflate(context, R.layout.item_grid, null); + viewHolder = new ViewHolder(); + viewHolder.btnKey = (TextView) convertView.findViewById(R.id.btn_keys); + convertView.setTag(viewHolder); + } else { + viewHolder = (ViewHolder) convertView.getTag(); + } + viewHolder.btnKey.setText(valueList.get(position).get("name")); + if(position == 9){ + viewHolder.btnKey.setBackgroundResource(R.drawable.selector_key_del); + viewHolder.btnKey.setEnabled(false); + } + if(position == 11){ + viewHolder.btnKey.setBackgroundResource(R.drawable.selector_key_del); + } + + return convertView; + } + }; + + /** + * 存放控件 + */ + public final class ViewHolder { + public TextView btnKey; + } +} diff --git a/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider.java b/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider.java new file mode 100644 index 0000000..ec6f819 --- /dev/null +++ b/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider.java @@ -0,0 +1,132 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.widget; +import android.app.PendingIntent; +import android.appwidget.AppWidgetManager; +import android.appwidget.AppWidgetProvider; +import android.content.ContentValues; +import android.content.Context; +import android.content.Intent; +import android.database.Cursor; +import android.util.Log; +import android.widget.RemoteViews; + +import net.micode.notes.R; +import net.micode.notes.data.Notes; +import net.micode.notes.data.Notes.NoteColumns; +import net.micode.notes.tool.ResourceParser; +import net.micode.notes.ui.NoteEditActivity; +import net.micode.notes.ui.NotesListActivity; + +public abstract class NoteWidgetProvider extends AppWidgetProvider { + public static final String [] PROJECTION = new String [] { + NoteColumns.ID, + NoteColumns.BG_COLOR_ID, + NoteColumns.SNIPPET + }; + + public static final int COLUMN_ID = 0; + public static final int COLUMN_BG_COLOR_ID = 1; + public static final int COLUMN_SNIPPET = 2; + + private static final String TAG = "NoteWidgetProvider"; + + @Override + public void onDeleted(Context context, int[] appWidgetIds) { + ContentValues values = new ContentValues(); + values.put(NoteColumns.WIDGET_ID, AppWidgetManager.INVALID_APPWIDGET_ID); + for (int i = 0; i < appWidgetIds.length; i++) { + context.getContentResolver().update(Notes.CONTENT_NOTE_URI, + values, + NoteColumns.WIDGET_ID + "=?", + new String[] { String.valueOf(appWidgetIds[i])}); + } + } + + private Cursor getNoteWidgetInfo(Context context, int widgetId) { + return context.getContentResolver().query(Notes.CONTENT_NOTE_URI, + PROJECTION, + NoteColumns.WIDGET_ID + "=? AND " + NoteColumns.PARENT_ID + "<>?", + new String[] { String.valueOf(widgetId), String.valueOf(Notes.ID_TRASH_FOLER) }, + null); + } + + protected void update(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) { + update(context, appWidgetManager, appWidgetIds, false); + } + + private void update(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds, + boolean privacyMode) { + for (int i = 0; i < appWidgetIds.length; i++) { + if (appWidgetIds[i] != AppWidgetManager.INVALID_APPWIDGET_ID) { + int bgId = ResourceParser.getDefaultBgId(context); + String snippet = ""; + Intent intent = new Intent(context, NoteEditActivity.class); + intent.setFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP); + intent.putExtra(Notes.INTENT_EXTRA_WIDGET_ID, appWidgetIds[i]); + intent.putExtra(Notes.INTENT_EXTRA_WIDGET_TYPE, getWidgetType()); + + Cursor c = getNoteWidgetInfo(context, appWidgetIds[i]); + if (c != null && c.moveToFirst()) { + if (c.getCount() > 1) { + Log.e(TAG, "Multiple message with same widget id:" + appWidgetIds[i]); + c.close(); + return; + } + snippet = c.getString(COLUMN_SNIPPET); + bgId = c.getInt(COLUMN_BG_COLOR_ID); + intent.putExtra(Intent.EXTRA_UID, c.getLong(COLUMN_ID)); + intent.setAction(Intent.ACTION_VIEW); + } else { + snippet = context.getResources().getString(R.string.widget_havenot_content); + intent.setAction(Intent.ACTION_INSERT_OR_EDIT); + } + + if (c != null) { + c.close(); + } + + RemoteViews rv = new RemoteViews(context.getPackageName(), getLayoutId()); + rv.setImageViewResource(R.id.widget_bg_image, getBgResourceId(bgId)); + intent.putExtra(Notes.INTENT_EXTRA_BACKGROUND_ID, bgId); + /** + * Generate the pending intent to start host for the widget + */ + PendingIntent pendingIntent = null; + if (privacyMode) { + rv.setTextViewText(R.id.widget_text, + context.getString(R.string.widget_under_visit_mode)); + pendingIntent = PendingIntent.getActivity(context, appWidgetIds[i], new Intent( + context, NotesListActivity.class), PendingIntent.FLAG_UPDATE_CURRENT); + } else { + rv.setTextViewText(R.id.widget_text, snippet); + pendingIntent = PendingIntent.getActivity(context, appWidgetIds[i], intent, + PendingIntent.FLAG_UPDATE_CURRENT); + } + + rv.setOnClickPendingIntent(R.id.widget_text, pendingIntent); + appWidgetManager.updateAppWidget(appWidgetIds[i], rv); + } + } + } + + protected abstract int getBgResourceId(int bgId); + + protected abstract int getLayoutId(); + + protected abstract int getWidgetType(); +} diff --git a/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider_2x.java b/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider_2x.java new file mode 100644 index 0000000..adcb2f7 --- /dev/null +++ b/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider_2x.java @@ -0,0 +1,47 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.widget; + +import android.appwidget.AppWidgetManager; +import android.content.Context; + +import net.micode.notes.R; +import net.micode.notes.data.Notes; +import net.micode.notes.tool.ResourceParser; + + +public class NoteWidgetProvider_2x extends NoteWidgetProvider { + @Override + public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) { + super.update(context, appWidgetManager, appWidgetIds); + } + + @Override + protected int getLayoutId() { + return R.layout.widget_2x; + } + + @Override + protected int getBgResourceId(int bgId) { + return ResourceParser.WidgetBgResources.getWidget2xBgResource(bgId); + } + + @Override + protected int getWidgetType() { + return Notes.TYPE_WIDGET_2X; + } +} diff --git a/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider_4x.java b/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider_4x.java new file mode 100644 index 0000000..c12a02e --- /dev/null +++ b/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider_4x.java @@ -0,0 +1,46 @@ +/* + * Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net) + * + * 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. + */ + +package net.micode.notes.widget; + +import android.appwidget.AppWidgetManager; +import android.content.Context; + +import net.micode.notes.R; +import net.micode.notes.data.Notes; +import net.micode.notes.tool.ResourceParser; + + +public class NoteWidgetProvider_4x extends NoteWidgetProvider { + @Override + public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) { + super.update(context, appWidgetManager, appWidgetIds); + } + + protected int getLayoutId() { + return R.layout.widget_4x; + } + + @Override + protected int getBgResourceId(int bgId) { + return ResourceParser.WidgetBgResources.getWidget4xBgResource(bgId); + } + + @Override + protected int getWidgetType() { + return Notes.TYPE_WIDGET_4X; + } +} diff --git a/app/src/main/res/color/primary_text_dark.xml b/app/src/main/res/color/primary_text_dark.xml new file mode 100644 index 0000000..8ad98e3 --- /dev/null +++ b/app/src/main/res/color/primary_text_dark.xml @@ -0,0 +1,22 @@ + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/color/secondary_text_dark.xml b/app/src/main/res/color/secondary_text_dark.xml new file mode 100644 index 0000000..9cf8a1a --- /dev/null +++ b/app/src/main/res/color/secondary_text_dark.xml @@ -0,0 +1,20 @@ + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable-hdpi/attention0.png b/app/src/main/res/drawable-hdpi/attention0.png new file mode 100644 index 0000000..64c25b6 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/attention0.png differ diff --git a/app/src/main/res/drawable-hdpi/attention1.png b/app/src/main/res/drawable-hdpi/attention1.png new file mode 100644 index 0000000..e559a95 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/attention1.png differ diff --git a/app/src/main/res/drawable-hdpi/attention2.png b/app/src/main/res/drawable-hdpi/attention2.png new file mode 100644 index 0000000..f29288a Binary files /dev/null and b/app/src/main/res/drawable-hdpi/attention2.png differ diff --git a/app/src/main/res/drawable-hdpi/attention3.png b/app/src/main/res/drawable-hdpi/attention3.png new file mode 100644 index 0000000..460d1d4 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/attention3.png differ diff --git a/app/src/main/res/drawable-hdpi/attention4.png b/app/src/main/res/drawable-hdpi/attention4.png new file mode 100644 index 0000000..983e48e Binary files /dev/null and b/app/src/main/res/drawable-hdpi/attention4.png differ diff --git a/app/src/main/res/drawable-hdpi/attention5.png b/app/src/main/res/drawable-hdpi/attention5.png new file mode 100644 index 0000000..c43d0b4 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/attention5.png differ diff --git a/app/src/main/res/drawable-hdpi/bg_btn_set_color.png b/app/src/main/res/drawable-hdpi/bg_btn_set_color.png new file mode 100644 index 0000000..5eb5d44 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/bg_btn_set_color.png differ diff --git a/app/src/main/res/drawable-hdpi/bg_color_btn_mask.png b/app/src/main/res/drawable-hdpi/bg_color_btn_mask.png new file mode 100644 index 0000000..100db77 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/bg_color_btn_mask.png differ diff --git a/app/src/main/res/drawable-hdpi/call_record.png b/app/src/main/res/drawable-hdpi/call_record.png new file mode 100644 index 0000000..fb88ca4 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/call_record.png differ diff --git a/app/src/main/res/drawable-hdpi/cancel.png b/app/src/main/res/drawable-hdpi/cancel.png new file mode 100644 index 0000000..96463e5 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/cancel.png differ diff --git a/app/src/main/res/drawable-hdpi/clock.png b/app/src/main/res/drawable-hdpi/clock.png new file mode 100644 index 0000000..5f2ae9a Binary files /dev/null and b/app/src/main/res/drawable-hdpi/clock.png differ diff --git a/app/src/main/res/drawable-hdpi/delete.png b/app/src/main/res/drawable-hdpi/delete.png new file mode 100644 index 0000000..643de3e Binary files /dev/null and b/app/src/main/res/drawable-hdpi/delete.png differ diff --git a/app/src/main/res/drawable-hdpi/dropdown_icon.9.png b/app/src/main/res/drawable-hdpi/dropdown_icon.9.png new file mode 100644 index 0000000..5525025 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/dropdown_icon.9.png differ diff --git a/app/src/main/res/drawable-hdpi/edit_blue.9.png b/app/src/main/res/drawable-hdpi/edit_blue.9.png new file mode 100644 index 0000000..55a1856 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/edit_blue.9.png differ diff --git a/app/src/main/res/drawable-hdpi/edit_green.9.png b/app/src/main/res/drawable-hdpi/edit_green.9.png new file mode 100644 index 0000000..2cb2d60 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/edit_green.9.png differ diff --git a/app/src/main/res/drawable-hdpi/edit_red.9.png b/app/src/main/res/drawable-hdpi/edit_red.9.png new file mode 100644 index 0000000..bae944a Binary files /dev/null and b/app/src/main/res/drawable-hdpi/edit_red.9.png differ diff --git a/app/src/main/res/drawable-hdpi/edit_title_blue.9.png b/app/src/main/res/drawable-hdpi/edit_title_blue.9.png new file mode 100644 index 0000000..96e6092 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/edit_title_blue.9.png differ diff --git a/app/src/main/res/drawable-hdpi/edit_title_green.9.png b/app/src/main/res/drawable-hdpi/edit_title_green.9.png new file mode 100644 index 0000000..08d8644 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/edit_title_green.9.png differ diff --git a/app/src/main/res/drawable-hdpi/edit_title_red.9.png b/app/src/main/res/drawable-hdpi/edit_title_red.9.png new file mode 100644 index 0000000..9c430e5 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/edit_title_red.9.png differ diff --git a/app/src/main/res/drawable-hdpi/edit_title_white.9.png b/app/src/main/res/drawable-hdpi/edit_title_white.9.png new file mode 100644 index 0000000..19e8d95 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/edit_title_white.9.png differ diff --git a/app/src/main/res/drawable-hdpi/edit_title_yellow.9.png b/app/src/main/res/drawable-hdpi/edit_title_yellow.9.png new file mode 100644 index 0000000..bf8f580 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/edit_title_yellow.9.png differ diff --git a/app/src/main/res/drawable-hdpi/edit_white.9.png b/app/src/main/res/drawable-hdpi/edit_white.9.png new file mode 100644 index 0000000..918f7a6 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/edit_white.9.png differ diff --git a/app/src/main/res/drawable-hdpi/edit_yellow.9.png b/app/src/main/res/drawable-hdpi/edit_yellow.9.png new file mode 100644 index 0000000..10cb642 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/edit_yellow.9.png differ diff --git a/app/src/main/res/drawable-hdpi/font_large.png b/app/src/main/res/drawable-hdpi/font_large.png new file mode 100644 index 0000000..78cf2e6 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/font_large.png differ diff --git a/app/src/main/res/drawable-hdpi/font_normal.png b/app/src/main/res/drawable-hdpi/font_normal.png new file mode 100644 index 0000000..9de7ced Binary files /dev/null and b/app/src/main/res/drawable-hdpi/font_normal.png differ diff --git a/app/src/main/res/drawable-hdpi/font_size_selector_bg.9.png b/app/src/main/res/drawable-hdpi/font_size_selector_bg.9.png new file mode 100644 index 0000000..be8e64c Binary files /dev/null and b/app/src/main/res/drawable-hdpi/font_size_selector_bg.9.png differ diff --git a/app/src/main/res/drawable-hdpi/font_small.png b/app/src/main/res/drawable-hdpi/font_small.png new file mode 100644 index 0000000..d3ff104 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/font_small.png differ diff --git a/app/src/main/res/drawable-hdpi/font_super.png b/app/src/main/res/drawable-hdpi/font_super.png new file mode 100644 index 0000000..85b13a1 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/font_super.png differ diff --git a/app/src/main/res/drawable-hdpi/icon_app.png b/app/src/main/res/drawable-hdpi/icon_app.png new file mode 100644 index 0000000..418aadc Binary files /dev/null and b/app/src/main/res/drawable-hdpi/icon_app.png differ diff --git a/app/src/main/res/drawable-hdpi/list_background.png b/app/src/main/res/drawable-hdpi/list_background.png new file mode 100644 index 0000000..087e1f9 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_background.png differ diff --git a/app/src/main/res/drawable-hdpi/list_blue_down.9.png b/app/src/main/res/drawable-hdpi/list_blue_down.9.png new file mode 100644 index 0000000..b88eebf Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_blue_down.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_blue_middle.9.png b/app/src/main/res/drawable-hdpi/list_blue_middle.9.png new file mode 100644 index 0000000..96b1c8b Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_blue_middle.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_blue_single.9.png b/app/src/main/res/drawable-hdpi/list_blue_single.9.png new file mode 100644 index 0000000..d7e7206 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_blue_single.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_blue_up.9.png b/app/src/main/res/drawable-hdpi/list_blue_up.9.png new file mode 100644 index 0000000..632e88c Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_blue_up.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_folder.9.png b/app/src/main/res/drawable-hdpi/list_folder.9.png new file mode 100644 index 0000000..829f61b Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_folder.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_footer_bg.9.png b/app/src/main/res/drawable-hdpi/list_footer_bg.9.png new file mode 100644 index 0000000..5325c25 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_footer_bg.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_green_down.9.png b/app/src/main/res/drawable-hdpi/list_green_down.9.png new file mode 100644 index 0000000..64a39d9 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_green_down.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_green_middle.9.png b/app/src/main/res/drawable-hdpi/list_green_middle.9.png new file mode 100644 index 0000000..897325a Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_green_middle.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_green_single.9.png b/app/src/main/res/drawable-hdpi/list_green_single.9.png new file mode 100644 index 0000000..c83405f Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_green_single.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_green_up.9.png b/app/src/main/res/drawable-hdpi/list_green_up.9.png new file mode 100644 index 0000000..141f9e1 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_green_up.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_red_down.9.png b/app/src/main/res/drawable-hdpi/list_red_down.9.png new file mode 100644 index 0000000..4224309 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_red_down.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_red_middle.9.png b/app/src/main/res/drawable-hdpi/list_red_middle.9.png new file mode 100644 index 0000000..9988f17 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_red_middle.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_red_single.9.png b/app/src/main/res/drawable-hdpi/list_red_single.9.png new file mode 100644 index 0000000..587c348 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_red_single.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_red_up.9.png b/app/src/main/res/drawable-hdpi/list_red_up.9.png new file mode 100644 index 0000000..46b4757 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_red_up.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_white_down.9.png b/app/src/main/res/drawable-hdpi/list_white_down.9.png new file mode 100644 index 0000000..29f9d8c Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_white_down.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_white_middle.9.png b/app/src/main/res/drawable-hdpi/list_white_middle.9.png new file mode 100644 index 0000000..77a4ab4 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_white_middle.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_white_single.9.png b/app/src/main/res/drawable-hdpi/list_white_single.9.png new file mode 100644 index 0000000..3e79189 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_white_single.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_white_up.9.png b/app/src/main/res/drawable-hdpi/list_white_up.9.png new file mode 100644 index 0000000..e23cd5c Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_white_up.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_yellow_down.9.png b/app/src/main/res/drawable-hdpi/list_yellow_down.9.png new file mode 100644 index 0000000..31cfc1e Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_yellow_down.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_yellow_middle.9.png b/app/src/main/res/drawable-hdpi/list_yellow_middle.9.png new file mode 100644 index 0000000..b6549b2 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_yellow_middle.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_yellow_single.9.png b/app/src/main/res/drawable-hdpi/list_yellow_single.9.png new file mode 100644 index 0000000..3faf507 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_yellow_single.9.png differ diff --git a/app/src/main/res/drawable-hdpi/list_yellow_up.9.png b/app/src/main/res/drawable-hdpi/list_yellow_up.9.png new file mode 100644 index 0000000..4ae791c Binary files /dev/null and b/app/src/main/res/drawable-hdpi/list_yellow_up.9.png differ diff --git a/app/src/main/res/drawable-hdpi/lock.png b/app/src/main/res/drawable-hdpi/lock.png new file mode 100644 index 0000000..d19b9ac Binary files /dev/null and b/app/src/main/res/drawable-hdpi/lock.png differ diff --git a/app/src/main/res/drawable-hdpi/menu_delete.png b/app/src/main/res/drawable-hdpi/menu_delete.png new file mode 100644 index 0000000..ccdfc4b Binary files /dev/null and b/app/src/main/res/drawable-hdpi/menu_delete.png differ diff --git a/app/src/main/res/drawable-hdpi/menu_move.png b/app/src/main/res/drawable-hdpi/menu_move.png new file mode 100644 index 0000000..1140b71 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/menu_move.png differ diff --git a/app/src/main/res/drawable-hdpi/new_note_normal.png b/app/src/main/res/drawable-hdpi/new_note_normal.png new file mode 100644 index 0000000..e24e0d1 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/new_note_normal.png differ diff --git a/app/src/main/res/drawable-hdpi/new_note_pressed.png b/app/src/main/res/drawable-hdpi/new_note_pressed.png new file mode 100644 index 0000000..c748936 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/new_note_pressed.png differ diff --git a/app/src/main/res/drawable-hdpi/note_edit_color_selector_panel.png b/app/src/main/res/drawable-hdpi/note_edit_color_selector_panel.png new file mode 100644 index 0000000..fc49552 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/note_edit_color_selector_panel.png differ diff --git a/app/src/main/res/drawable-hdpi/notification.png b/app/src/main/res/drawable-hdpi/notification.png new file mode 100644 index 0000000..b13ab4a Binary files /dev/null and b/app/src/main/res/drawable-hdpi/notification.png differ diff --git a/app/src/main/res/drawable-hdpi/search_result.png b/app/src/main/res/drawable-hdpi/search_result.png new file mode 100644 index 0000000..ff2befd Binary files /dev/null and b/app/src/main/res/drawable-hdpi/search_result.png differ diff --git a/app/src/main/res/drawable-hdpi/selected.png b/app/src/main/res/drawable-hdpi/selected.png new file mode 100644 index 0000000..b889bef Binary files /dev/null and b/app/src/main/res/drawable-hdpi/selected.png differ diff --git a/app/src/main/res/drawable-hdpi/title_alert.png b/app/src/main/res/drawable-hdpi/title_alert.png new file mode 100644 index 0000000..544ee9c Binary files /dev/null and b/app/src/main/res/drawable-hdpi/title_alert.png differ diff --git a/app/src/main/res/drawable-hdpi/title_bar_bg.9.png b/app/src/main/res/drawable-hdpi/title_bar_bg.9.png new file mode 100644 index 0000000..eb6bff0 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/title_bar_bg.9.png differ diff --git a/app/src/main/res/drawable-hdpi/widget_2x_blue.png b/app/src/main/res/drawable-hdpi/widget_2x_blue.png new file mode 100644 index 0000000..a1707f4 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/widget_2x_blue.png differ diff --git a/app/src/main/res/drawable-hdpi/widget_2x_green.png b/app/src/main/res/drawable-hdpi/widget_2x_green.png new file mode 100644 index 0000000..f86886c Binary files /dev/null and b/app/src/main/res/drawable-hdpi/widget_2x_green.png differ diff --git a/app/src/main/res/drawable-hdpi/widget_2x_red.png b/app/src/main/res/drawable-hdpi/widget_2x_red.png new file mode 100644 index 0000000..0e66c29 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/widget_2x_red.png differ diff --git a/app/src/main/res/drawable-hdpi/widget_2x_white.png b/app/src/main/res/drawable-hdpi/widget_2x_white.png new file mode 100644 index 0000000..5f0619a Binary files /dev/null and b/app/src/main/res/drawable-hdpi/widget_2x_white.png differ diff --git a/app/src/main/res/drawable-hdpi/widget_2x_yellow.png b/app/src/main/res/drawable-hdpi/widget_2x_yellow.png new file mode 100644 index 0000000..12d1c2b Binary files /dev/null and b/app/src/main/res/drawable-hdpi/widget_2x_yellow.png differ diff --git a/app/src/main/res/drawable-hdpi/widget_4x_blue.png b/app/src/main/res/drawable-hdpi/widget_4x_blue.png new file mode 100644 index 0000000..9183738 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/widget_4x_blue.png differ diff --git a/app/src/main/res/drawable-hdpi/widget_4x_green.png b/app/src/main/res/drawable-hdpi/widget_4x_green.png new file mode 100644 index 0000000..fa8b452 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/widget_4x_green.png differ diff --git a/app/src/main/res/drawable-hdpi/widget_4x_red.png b/app/src/main/res/drawable-hdpi/widget_4x_red.png new file mode 100644 index 0000000..62de074 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/widget_4x_red.png differ diff --git a/app/src/main/res/drawable-hdpi/widget_4x_white.png b/app/src/main/res/drawable-hdpi/widget_4x_white.png new file mode 100644 index 0000000..a37d67c Binary files /dev/null and b/app/src/main/res/drawable-hdpi/widget_4x_white.png differ diff --git a/app/src/main/res/drawable-hdpi/widget_4x_yellow.png b/app/src/main/res/drawable-hdpi/widget_4x_yellow.png new file mode 100644 index 0000000..d7c5fa4 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/widget_4x_yellow.png differ diff --git a/app/src/main/res/drawable/new_note.xml b/app/src/main/res/drawable/new_note.xml new file mode 100644 index 0000000..2154ebc --- /dev/null +++ b/app/src/main/res/drawable/new_note.xml @@ -0,0 +1,23 @@ + + + + + + + + diff --git a/app/src/main/res/drawable/selector_grid.xml b/app/src/main/res/drawable/selector_grid.xml new file mode 100644 index 0000000..e2d3f48 --- /dev/null +++ b/app/src/main/res/drawable/selector_grid.xml @@ -0,0 +1,18 @@ + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/selector_key_del.xml b/app/src/main/res/drawable/selector_key_del.xml new file mode 100644 index 0000000..91e8c4d --- /dev/null +++ b/app/src/main/res/drawable/selector_key_del.xml @@ -0,0 +1,18 @@ + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/account_dialog_title.xml b/app/src/main/res/layout/account_dialog_title.xml new file mode 100644 index 0000000..0b72974 --- /dev/null +++ b/app/src/main/res/layout/account_dialog_title.xml @@ -0,0 +1,41 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/add_account_text.xml b/app/src/main/res/layout/add_account_text.xml new file mode 100644 index 0000000..c799178 --- /dev/null +++ b/app/src/main/res/layout/add_account_text.xml @@ -0,0 +1,32 @@ + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/current_password_head.xml b/app/src/main/res/layout/current_password_head.xml new file mode 100644 index 0000000..6979527 --- /dev/null +++ b/app/src/main/res/layout/current_password_head.xml @@ -0,0 +1,27 @@ + + + + + + + + + + + + + diff --git a/app/src/main/res/layout/datetime_picker.xml b/app/src/main/res/layout/datetime_picker.xml new file mode 100644 index 0000000..f10d592 --- /dev/null +++ b/app/src/main/res/layout/datetime_picker.xml @@ -0,0 +1,56 @@ + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/dialog_edit_text.xml b/app/src/main/res/layout/dialog_edit_text.xml new file mode 100644 index 0000000..361b39a --- /dev/null +++ b/app/src/main/res/layout/dialog_edit_text.xml @@ -0,0 +1,23 @@ + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/folder_list_item.xml b/app/src/main/res/layout/folder_list_item.xml new file mode 100644 index 0000000..77e8148 --- /dev/null +++ b/app/src/main/res/layout/folder_list_item.xml @@ -0,0 +1,29 @@ + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/homepage.xml b/app/src/main/res/layout/homepage.xml new file mode 100644 index 0000000..0159f78 --- /dev/null +++ b/app/src/main/res/layout/homepage.xml @@ -0,0 +1,33 @@ + + + + + + + + + diff --git a/app/src/main/res/layout/item_grid.xml b/app/src/main/res/layout/item_grid.xml new file mode 100644 index 0000000..6e4189d --- /dev/null +++ b/app/src/main/res/layout/item_grid.xml @@ -0,0 +1,15 @@ + + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/layout.xml b/app/src/main/res/layout/layout.xml new file mode 100644 index 0000000..ebe748a --- /dev/null +++ b/app/src/main/res/layout/layout.xml @@ -0,0 +1,90 @@ + + + + + + + +