+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/rnotes/app/app.iml b/rnotes/app/app.iml
new file mode 100644
index 0000000..ecc5f77
--- /dev/null
+++ b/rnotes/app/app.iml
@@ -0,0 +1,94 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ generateDebugSources
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/rnotes/app/build.gradle b/rnotes/app/build.gradle
new file mode 100644
index 0000000..72bf031
--- /dev/null
+++ b/rnotes/app/build.gradle
@@ -0,0 +1,20 @@
+apply plugin: 'com.android.application'
+
+android {
+ compileSdkVersion 28
+ useLibrary 'org.apache.http.legacy'
+ buildToolsVersion "33.0.2"
+
+ defaultConfig {
+ applicationId "net.micode.notes"
+ minSdkVersion 14
+ targetSdkVersion 14
+ }
+
+ buildTypes {
+ release {
+ minifyEnabled false
+ proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt'
+ }
+ }
+}
diff --git a/rnotes/app/build/generated/not_namespaced_r_class_sources/debug/r/net/micode/notes/R.java b/rnotes/app/build/generated/not_namespaced_r_class_sources/debug/r/net/micode/notes/R.java
new file mode 100644
index 0000000..3781701
--- /dev/null
+++ b/rnotes/app/build/generated/not_namespaced_r_class_sources/debug/r/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/rnotes/app/build/generated/source/buildConfig/androidTest/debug/net/micode/notes/test/BuildConfig.java b/rnotes/app/build/generated/source/buildConfig/androidTest/debug/net/micode/notes/test/BuildConfig.java
new file mode 100644
index 0000000..888388c
--- /dev/null
+++ b/rnotes/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/rnotes/app/build/generated/source/buildConfig/debug/net/micode/notes/BuildConfig.java b/rnotes/app/build/generated/source/buildConfig/debug/net/micode/notes/BuildConfig.java
new file mode 100644
index 0000000..7325eb3
--- /dev/null
+++ b/rnotes/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/rnotes/app/build/intermediates/annotation_processor_list/debug/annotationProcessors.json b/rnotes/app/build/intermediates/annotation_processor_list/debug/annotationProcessors.json
new file mode 100644
index 0000000..9e26dfe
--- /dev/null
+++ b/rnotes/app/build/intermediates/annotation_processor_list/debug/annotationProcessors.json
@@ -0,0 +1 @@
+{}
\ No newline at end of file
diff --git a/rnotes/app/build/intermediates/apk_list/debug/mainApkListPersistenceDebug/apk-list.gson b/rnotes/app/build/intermediates/apk_list/debug/mainApkListPersistenceDebug/apk-list.gson
new file mode 100644
index 0000000..6360b7c
--- /dev/null
+++ b/rnotes/app/build/intermediates/apk_list/debug/mainApkListPersistenceDebug/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/rnotes/app/build/intermediates/blame/res/debug/multi-v2/debug.json b/rnotes/app/build/intermediates/blame/res/debug/multi-v2/debug.json
new file mode 100644
index 0000000..6d177cf
--- /dev/null
+++ b/rnotes/app/build/intermediates/blame/res/debug/multi-v2/debug.json
@@ -0,0 +1,186 @@
+{
+ "logs": [
+ {
+ "outputFile": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\values-zh-rCN_values-zh-rCN.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\values-zh-rCN\\arrays.xml",
+ "from": {
+ "startLines": "18",
+ "startColumns": "4",
+ "startOffsets": "730",
+ "endLines": "21",
+ "endColumns": "19",
+ "endOffsets": "838"
+ },
+ "to": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "105",
+ "endLines": "5",
+ "endColumns": "19",
+ "endOffsets": "210"
+ }
+ },
+ {
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\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": "6653,3566,3499,3425,3374,846,887,936,6195,6241,6598,6547,1225,3938,4007,3878,3812,3748,4682,4621,4557,4141,2937,1398,1452,4196,3640,6299,3314,3097,1836,2123,2374,1890,2876,2822,2770,2571,2522,2426,2475,2618,2666,2167,3254,2717,3141,2079,2326,2269,2213,3041,2034,2998,1941,1983,3194,1346,1657,1755,1609,1707,1561,1515,1173,1119,5064,5004,5207,6120,5523,5453,5588,5667,5852,5778,5140,5397,5265,5331,4954,5957,6041,6508,6399,6350,6445,1288,4085,4497,4797,4738,4865,4448,4402,4353,4301,985,1052",
+ "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": "6827,3634,3560,3493,3419,881,930,979,6235,6293,6647,6592,1282,4001,4079,3932,3872,3806,4732,4676,4615,4190,2992,1446,1509,4276,3716,6344,3368,3135,1884,2161,2420,1935,2931,2870,2816,2612,2565,2469,2516,2660,2711,2207,3308,2764,3188,2117,2368,2320,2263,3091,2073,3035,1977,2028,3248,1392,1701,1799,1651,1749,1603,1555,1219,1167,5134,5058,5259,6189,5582,5517,5661,5772,5951,5846,5201,5447,5325,5391,4998,6035,6114,6541,6439,6393,6502,1340,4135,4551,4859,4791,4922,4491,4442,4396,4347,1046,1113"
+ },
+ "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"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\values_values.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\values\\dimens.xml",
+ "from": {
+ "startLines": "19,20,21,22,18",
+ "startColumns": "4,4,4,4,4",
+ "startOffsets": "783,836,890,944,730",
+ "endColumns": "51,52,52,51,51",
+ "endOffsets": "830,884,938,991,777"
+ },
+ "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": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\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": "2112,2322,2704,2539,917,1104,1293,1484,1693,730,1905",
+ "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": "2314,2531,2910,2696,1098,1287,1476,1685,1897,911,2104"
+ },
+ "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": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\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": "8136,3970,4234,4137,4067,846,890,943,7624,7674,8077,8025,1308,4694,4789,4622,4537,4453,5668,5584,5481,4967,2043,1991,3461,1515,1569,5029,2138,4318,7738,3898,3649,2198,2519,2825,2257,3389,3327,3269,3043,2990,2885,2939,3094,3145,2567,3831,3206,3699,2471,2769,2680,2621,3586,2420,3540,2315,2359,3763,1459,1784,1894,1736,1840,1679,1630,1252,1198,6131,6063,6375,7525,6744,6662,6819,6909,7153,7073,6216,6292,6602,6440,6521,6007,7298,7421,7983,7854,7796,7908,1393,4898,5394,5805,5735,5886,5334,5278,5215,5154,996,1107",
+ "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": "8544,4061,4312,4228,4131,884,937,990,7668,7732,8130,8071,1387,4783,4892,4688,4616,4531,5729,5662,5578,5023,2100,2037,3534,1563,1624,5129,2192,4415,7788,3964,3693,2251,2561,2879,2309,3455,3383,3321,3088,3037,2933,2984,3139,3200,2615,3892,3263,3757,2513,2819,2763,2674,3643,2465,3580,2353,2414,3825,1509,1834,1942,1778,1888,1730,1673,1302,1246,6210,6125,6434,7616,6813,6738,6903,7067,7292,7147,6286,6369,6656,6515,6596,6057,7415,7519,8019,7902,7848,7977,1453,4961,5475,5880,5799,5975,5388,5328,5272,5209,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",
+ "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"
+ }
+ },
+ {
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\values\\arrays.xml",
+ "from": {
+ "startLines": "19,26",
+ "startColumns": "4,4",
+ "startOffsets": "758,1073",
+ "endLines": "24,29",
+ "endColumns": "19,19",
+ "endOffsets": "1065,1191"
+ },
+ "to": {
+ "startLines": "2,8",
+ "startColumns": "4,4",
+ "startOffsets": "105,412",
+ "endLines": "7,11",
+ "endColumns": "19,19",
+ "endOffsets": "407,527"
+ }
+ },
+ {
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\values\\colors.xml",
+ "from": {
+ "startLines": "18",
+ "startColumns": "4",
+ "startOffsets": "730",
+ "endColumns": "56",
+ "endOffsets": "782"
+ },
+ "to": {
+ "startLines": "12",
+ "startColumns": "4",
+ "startOffsets": "532",
+ "endColumns": "56",
+ "endOffsets": "584"
+ }
+ }
+ ]
+ },
+ {
+ "outputFile": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\values-zh-rTW_values-zh-rTW.arsc.flat",
+ "map": [
+ {
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\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": "6629,3647,3580,3506,3455,846,887,936,6169,6215,6574,6523,1225,3911,3980,3851,3784,3720,4654,4593,4529,4114,3018,1398,1452,4169,1805,6273,3395,3178,1917,2204,2455,1971,2957,2903,2851,2652,2603,2507,2556,2699,2747,2248,3335,2798,3222,2160,2407,2350,2294,3122,2115,3079,2022,2064,3275,1346,1657,1755,1609,1707,1561,1515,1173,1119,5036,4976,5179,6092,5495,5425,5560,5639,5824,5750,5112,5369,5237,5303,4926,5929,6013,6484,6375,6326,6421,1288,4058,4469,4769,4710,4837,4420,4374,4325,4273,985,1052",
+ "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": "6803,3714,3641,3574,3500,881,930,979,6209,6267,6623,6568,1282,3974,4052,3905,3845,3778,4704,4648,4587,4163,3073,1446,1509,4248,1880,6318,3449,3216,1965,2242,2501,2016,3012,2951,2897,2693,2646,2550,2597,2741,2792,2288,3389,2845,3269,2198,2449,2401,2344,3172,2154,3116,2058,2109,3329,1392,1701,1799,1651,1749,1603,1555,1219,1167,5106,5030,5231,6161,5554,5489,5633,5744,5923,5818,5173,5419,5297,5363,4970,6007,6086,6517,6415,6369,6478,1340,4108,4523,4831,4763,4894,4463,4414,4368,4319,1046,1113"
+ },
+ "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"
+ }
+ },
+ {
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\values-zh-rTW\\arrays.xml",
+ "from": {
+ "startLines": "18",
+ "startColumns": "4",
+ "startOffsets": "730",
+ "endLines": "21",
+ "endColumns": "19",
+ "endOffsets": "838"
+ },
+ "to": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "105",
+ "endLines": "5",
+ "endColumns": "19",
+ "endOffsets": "210"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/rnotes/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rCN.json b/rnotes/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rCN.json
new file mode 100644
index 0000000..5be1ed4
--- /dev/null
+++ b/rnotes/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rCN.json
@@ -0,0 +1,47 @@
+{
+ "logs": [
+ {
+ "outputFile": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-zh-rCN\\values-zh-rCN.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\values-zh-rCN\\arrays.xml",
+ "from": {
+ "startLines": "18",
+ "startColumns": "4",
+ "startOffsets": "730",
+ "endLines": "21",
+ "endColumns": "19",
+ "endOffsets": "838"
+ },
+ "to": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "105",
+ "endLines": "5",
+ "endColumns": "19",
+ "endOffsets": "210"
+ }
+ },
+ {
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\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": "6653,3566,3499,3425,3374,846,887,936,6195,6241,6598,6547,1225,3938,4007,3878,3812,3748,4682,4621,4557,4141,2937,1398,1452,4196,3640,6299,3314,3097,1836,2123,2374,1890,2876,2822,2770,2571,2522,2426,2475,2618,2666,2167,3254,2717,3141,2079,2326,2269,2213,3041,2034,2998,1941,1983,3194,1346,1657,1755,1609,1707,1561,1515,1173,1119,5064,5004,5207,6120,5523,5453,5588,5667,5852,5778,5140,5397,5265,5331,4954,5957,6041,6508,6399,6350,6445,1288,4085,4497,4797,4738,4865,4448,4402,4353,4301,985,1052",
+ "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": "6827,3634,3560,3493,3419,881,930,979,6235,6293,6647,6592,1282,4001,4079,3932,3872,3806,4732,4676,4615,4190,2992,1446,1509,4276,3716,6344,3368,3135,1884,2161,2420,1935,2931,2870,2816,2612,2565,2469,2516,2660,2711,2207,3308,2764,3188,2117,2368,2320,2263,3091,2073,3035,1977,2028,3248,1392,1701,1799,1651,1749,1603,1555,1219,1167,5134,5058,5259,6189,5582,5517,5661,5772,5951,5846,5201,5447,5325,5391,4998,6035,6114,6541,6439,6393,6502,1340,4135,4551,4859,4791,4922,4491,4442,4396,4347,1046,1113"
+ },
+ "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/rnotes/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rTW.json b/rnotes/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rTW.json
new file mode 100644
index 0000000..cca38f3
--- /dev/null
+++ b/rnotes/app/build/intermediates/blame/res/debug/multi-v2/values-zh-rTW.json
@@ -0,0 +1,47 @@
+{
+ "logs": [
+ {
+ "outputFile": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values-zh-rTW\\values-zh-rTW.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\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": "6629,3647,3580,3506,3455,846,887,936,6169,6215,6574,6523,1225,3911,3980,3851,3784,3720,4654,4593,4529,4114,3018,1398,1452,4169,1805,6273,3395,3178,1917,2204,2455,1971,2957,2903,2851,2652,2603,2507,2556,2699,2747,2248,3335,2798,3222,2160,2407,2350,2294,3122,2115,3079,2022,2064,3275,1346,1657,1755,1609,1707,1561,1515,1173,1119,5036,4976,5179,6092,5495,5425,5560,5639,5824,5750,5112,5369,5237,5303,4926,5929,6013,6484,6375,6326,6421,1288,4058,4469,4769,4710,4837,4420,4374,4325,4273,985,1052",
+ "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": "6803,3714,3641,3574,3500,881,930,979,6209,6267,6623,6568,1282,3974,4052,3905,3845,3778,4704,4648,4587,4163,3073,1446,1509,4248,1880,6318,3449,3216,1965,2242,2501,2016,3012,2951,2897,2693,2646,2550,2597,2741,2792,2288,3389,2845,3269,2198,2449,2401,2344,3172,2154,3116,2058,2109,3329,1392,1701,1799,1651,1749,1603,1555,1219,1167,5106,5030,5231,6161,5554,5489,5633,5744,5923,5818,5173,5419,5297,5363,4970,6007,6086,6517,6415,6369,6478,1340,4108,4523,4831,4763,4894,4463,4414,4368,4319,1046,1113"
+ },
+ "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"
+ }
+ },
+ {
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\values-zh-rTW\\arrays.xml",
+ "from": {
+ "startLines": "18",
+ "startColumns": "4",
+ "startOffsets": "730",
+ "endLines": "21",
+ "endColumns": "19",
+ "endOffsets": "838"
+ },
+ "to": {
+ "startLines": "2",
+ "startColumns": "4",
+ "startOffsets": "105",
+ "endLines": "5",
+ "endColumns": "19",
+ "endOffsets": "210"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/rnotes/app/build/intermediates/blame/res/debug/multi-v2/values.json b/rnotes/app/build/intermediates/blame/res/debug/multi-v2/values.json
new file mode 100644
index 0000000..71050f7
--- /dev/null
+++ b/rnotes/app/build/intermediates/blame/res/debug/multi-v2/values.json
@@ -0,0 +1,100 @@
+{
+ "logs": [
+ {
+ "outputFile": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\incremental\\mergeDebugResources\\merged.dir\\values\\values.xml",
+ "map": [
+ {
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\values\\dimens.xml",
+ "from": {
+ "startLines": "19,20,21,22,18",
+ "startColumns": "4,4,4,4,4",
+ "startOffsets": "783,836,890,944,730",
+ "endColumns": "51,52,52,51,51",
+ "endOffsets": "830,884,938,991,777"
+ },
+ "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": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\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": "2112,2322,2704,2539,917,1104,1293,1484,1693,730,1905",
+ "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": "2314,2531,2910,2696,1098,1287,1476,1685,1897,911,2104"
+ },
+ "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": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\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": "8136,3970,4234,4137,4067,846,890,943,7624,7674,8077,8025,1308,4694,4789,4622,4537,4453,5668,5584,5481,4967,2043,1991,3461,1515,1569,5029,2138,4318,7738,3898,3649,2198,2519,2825,2257,3389,3327,3269,3043,2990,2885,2939,3094,3145,2567,3831,3206,3699,2471,2769,2680,2621,3586,2420,3540,2315,2359,3763,1459,1784,1894,1736,1840,1679,1630,1252,1198,6131,6063,6375,7525,6744,6662,6819,6909,7153,7073,6216,6292,6602,6440,6521,6007,7298,7421,7983,7854,7796,7908,1393,4898,5394,5805,5735,5886,5334,5278,5215,5154,996,1107",
+ "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": "8544,4061,4312,4228,4131,884,937,990,7668,7732,8130,8071,1387,4783,4892,4688,4616,4531,5729,5662,5578,5023,2100,2037,3534,1563,1624,5129,2192,4415,7788,3964,3693,2251,2561,2879,2309,3455,3383,3321,3088,3037,2933,2984,3139,3200,2615,3892,3263,3757,2513,2819,2763,2674,3643,2465,3580,2353,2414,3825,1509,1834,1942,1778,1888,1730,1673,1302,1246,6210,6125,6434,7616,6813,6738,6903,7067,7292,7147,6286,6369,6656,6515,6596,6057,7415,7519,8019,7902,7848,7977,1453,4961,5475,5880,5799,5975,5388,5328,5272,5209,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",
+ "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"
+ }
+ },
+ {
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\values\\arrays.xml",
+ "from": {
+ "startLines": "19,26",
+ "startColumns": "4,4",
+ "startOffsets": "758,1073",
+ "endLines": "24,29",
+ "endColumns": "19,19",
+ "endOffsets": "1065,1191"
+ },
+ "to": {
+ "startLines": "2,8",
+ "startColumns": "4,4",
+ "startOffsets": "105,412",
+ "endLines": "7,11",
+ "endColumns": "19,19",
+ "endOffsets": "407,527"
+ }
+ },
+ {
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\values\\colors.xml",
+ "from": {
+ "startLines": "18",
+ "startColumns": "4",
+ "startOffsets": "730",
+ "endColumns": "56",
+ "endOffsets": "782"
+ },
+ "to": {
+ "startLines": "12",
+ "startColumns": "4",
+ "startOffsets": "532",
+ "endColumns": "56",
+ "endOffsets": "584"
+ }
+ }
+ ]
+ }
+ ]
+}
\ No newline at end of file
diff --git a/rnotes/app/build/intermediates/blame/res/debug/single/debug.json b/rnotes/app/build/intermediates/blame/res/debug/single/debug.json
new file mode 100644
index 0000000..d5ad127
--- /dev/null
+++ b/rnotes/app/build/intermediates/blame/res/debug/single/debug.json
@@ -0,0 +1,382 @@
+[
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_edit.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\menu\\note_edit.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_down.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_green_down.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_red.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_red.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\xml_searchable.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\xml\\searchable.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list_dropdown_menu.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\note_list_dropdown_menu.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_white.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\edit_title_white.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\menu\\note_list.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_folder.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_folder.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_blue.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\edit_blue.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_add_account_text.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\add_account_text.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_datetime_picker.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\datetime_picker.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_red.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_red.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_selected.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\selected.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\raw_introduction.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\raw\\introduction"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_new_note_pressed.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\new_note_pressed.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_red.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\edit_red.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_middle.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_blue_middle.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_up.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_red_up.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_blue.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_blue.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_note_edit_color_selector_panel.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\note_edit_color_selector_panel.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_single.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_single.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_normal.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\font_normal.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_large.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\font_large.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_down.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_blue_down.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_green.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\edit_green.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_up.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_green_up.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_yellow.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_yellow.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_delete.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\delete.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_up.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_blue_up.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_account_dialog_title.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\account_dialog_title.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_green.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\edit_title_green.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_middle.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_middle.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_clock.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\clock.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_blue.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_blue.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_single.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_green_single.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_blue.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\edit_title_blue.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_settings_header.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\settings_header.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_menu_move.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\menu_move.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\color_primary_text_dark.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\color\\primary_text_dark.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list_footer.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\note_list_footer.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_yellow.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\edit_yellow.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\raw-zh-rCN_introduction.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\raw-zh-rCN\\introduction"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_call_record.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\call_record.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\xml_widget_4x_info.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\xml\\widget_4x_info.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_small.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\font_small.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_down.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_down.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_search_result.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\search_result.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_icon_app.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\icon_app.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_white.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\edit_white.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_middle.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_white_middle.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_single.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_white_single.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_background.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_background.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_menu_delete.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\menu_delete.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\note_list.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_bg_btn_set_color.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\bg_btn_set_color.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_widget_2x.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\widget_2x.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_edit.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\note_edit.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_middle.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_red_middle.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_middle.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_green_middle.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\color_secondary_text_dark.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\color\\secondary_text_dark.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_edit_list_item.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\note_edit_list_item.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_dropdown_icon.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\dropdown_icon.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_title_alert.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\title_alert.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_red.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\edit_title_red.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list_dropdown.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\menu\\note_list_dropdown.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_green.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_green.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\xml_preferences.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\xml\\preferences.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_title_bar_bg.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\title_bar_bg.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_up.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_white_up.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_down.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_white_down.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_white.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_white.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_item.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\note_item.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\menu_call_note_edit.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\menu\\call_note_edit.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable_new_note.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable\\new_note.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_yellow.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_yellow.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_new_note_normal.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\new_note_normal.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_footer_bg.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_footer_bg.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_up.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_up.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_widget_4x.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\widget_4x.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_single.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_red_single.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_single.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_blue_single.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list_options.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\menu\\note_list_options.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_white.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_white.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_green.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_green.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\xml_widget_2x_info.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\xml\\widget_2x_info.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_yellow.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\edit_title_yellow.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_notification.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\notification.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_size_selector_bg.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\font_size_selector_bg.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\menu_call_record_folder.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\menu\\call_record_folder.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_super.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\font_super.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_bg_color_btn_mask.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\bg_color_btn_mask.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\menu_sub_folder.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\menu\\sub_folder.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_folder_list_item.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\folder_list_item.xml"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_down.9.png.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_red_down.9.png"
+ },
+ {
+ "merged": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_dialog_edit_text.xml.flat",
+ "source": "C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\dialog_edit_text.xml"
+ }
+]
\ No newline at end of file
diff --git a/rnotes/app/build/intermediates/bundle_manifest/debug/processDebugManifest/bundle-manifest/AndroidManifest.xml b/rnotes/app/build/intermediates/bundle_manifest/debug/processDebugManifest/bundle-manifest/AndroidManifest.xml
new file mode 100644
index 0000000..f237bf5
--- /dev/null
+++ b/rnotes/app/build/intermediates/bundle_manifest/debug/processDebugManifest/bundle-manifest/AndroidManifest.xml
@@ -0,0 +1,151 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/rnotes/app/build/intermediates/bundle_manifest/debug/processDebugManifest/bundle-manifest/output.json b/rnotes/app/build/intermediates/bundle_manifest/debug/processDebugManifest/bundle-manifest/output.json
new file mode 100644
index 0000000..b81025e
--- /dev/null
+++ b/rnotes/app/build/intermediates/bundle_manifest/debug/processDebugManifest/bundle-manifest/output.json
@@ -0,0 +1 @@
+[{"outputType":{"type":"BUNDLE_MANIFEST"},"apkData":{"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/rnotes/app/build/intermediates/compatible_screen_manifest/debug/createDebugCompatibleScreenManifests/out/output.json b/rnotes/app/build/intermediates/compatible_screen_manifest/debug/createDebugCompatibleScreenManifests/out/output.json
new file mode 100644
index 0000000..0637a08
--- /dev/null
+++ b/rnotes/app/build/intermediates/compatible_screen_manifest/debug/createDebugCompatibleScreenManifests/out/output.json
@@ -0,0 +1 @@
+[]
\ No newline at end of file
diff --git a/rnotes/app/build/intermediates/dex/debug/mergeDexDebug/out/classes.dex b/rnotes/app/build/intermediates/dex/debug/mergeDexDebug/out/classes.dex
new file mode 100644
index 0000000..4cfd7c2
Binary files /dev/null and b/rnotes/app/build/intermediates/dex/debug/mergeDexDebug/out/classes.dex differ
diff --git a/rnotes/app/build/intermediates/incremental/debug-mergeJavaRes/merge-state b/rnotes/app/build/intermediates/incremental/debug-mergeJavaRes/merge-state
new file mode 100644
index 0000000..e84314e
Binary files /dev/null and b/rnotes/app/build/intermediates/incremental/debug-mergeJavaRes/merge-state differ
diff --git a/rnotes/app/build/intermediates/incremental/debug-mergeNativeLibs/merge-state b/rnotes/app/build/intermediates/incremental/debug-mergeNativeLibs/merge-state
new file mode 100644
index 0000000..c28bfbc
Binary files /dev/null and b/rnotes/app/build/intermediates/incremental/debug-mergeNativeLibs/merge-state differ
diff --git a/rnotes/app/build/intermediates/incremental/mergeDebugAssets/merger.xml b/rnotes/app/build/intermediates/incremental/mergeDebugAssets/merger.xml
new file mode 100644
index 0000000..b438dc0
--- /dev/null
+++ b/rnotes/app/build/intermediates/incremental/mergeDebugAssets/merger.xml
@@ -0,0 +1,2 @@
+
+
\ No newline at end of file
diff --git a/rnotes/app/build/intermediates/incremental/mergeDebugJniLibFolders/merger.xml b/rnotes/app/build/intermediates/incremental/mergeDebugJniLibFolders/merger.xml
new file mode 100644
index 0000000..1dc9850
--- /dev/null
+++ b/rnotes/app/build/intermediates/incremental/mergeDebugJniLibFolders/merger.xml
@@ -0,0 +1,2 @@
+
+
\ No newline at end of file
diff --git a/rnotes/app/build/intermediates/incremental/mergeDebugResources/compile-file-map.properties b/rnotes/app/build/intermediates/incremental/mergeDebugResources/compile-file-map.properties
new file mode 100644
index 0000000..7fb4060
--- /dev/null
+++ b/rnotes/app/build/intermediates/incremental/mergeDebugResources/compile-file-map.properties
@@ -0,0 +1,96 @@
+#Fri May 05 23:06:56 CST 2023
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\selected.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_selected.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_green.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_green.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\font_large.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_large.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_blue_down.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_down.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\clock.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_clock.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_green_single.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_single.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_down.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_down.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\menu\\call_note_edit.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\menu_call_note_edit.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\edit_red.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_red.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\notification.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_notification.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\edit_title_yellow.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_yellow.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\xml\\widget_4x_info.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\xml_widget_4x_info.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\delete.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_delete.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\widget_2x.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_widget_2x.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\menu_move.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_menu_move.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\raw-zh-rCN\\introduction=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\raw-zh-rCN_introduction.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_yellow.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_yellow.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\edit_title_green.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_green.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\note_list_footer.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list_footer.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable\\new_note.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable_new_note.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_white.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_white.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\call_record.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_call_record.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\search_result.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_search_result.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\title_alert.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_title_alert.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\xml\\preferences.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\xml_preferences.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\menu\\call_record_folder.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\menu_call_record_folder.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\dialog_edit_text.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_dialog_edit_text.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_green_up.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_up.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\xml\\widget_2x_info.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\xml_widget_2x_info.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\menu_delete.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_menu_delete.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\bg_color_btn_mask.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_bg_color_btn_mask.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\font_super.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_super.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_red.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_red.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\color\\secondary_text_dark.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\color_secondary_text_dark.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_green_down.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_down.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\raw\\introduction=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\raw_introduction.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_red.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_red.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_background.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_background.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\edit_title_red.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_red.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\note_edit_list_item.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_edit_list_item.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_footer_bg.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_footer_bg.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\font_small.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_small.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\note_item.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_item.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\edit_yellow.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_yellow.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\edit_white.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_white.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_white_up.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_up.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_middle.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_middle.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\settings_header.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_settings_header.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\widget_4x.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_widget_4x.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\account_dialog_title.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_account_dialog_title.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_folder.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_folder.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_green.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_green.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_red_middle.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_middle.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\folder_list_item.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_folder_list_item.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\bg_btn_set_color.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_bg_btn_set_color.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_single.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_single.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_white_middle.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_middle.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_blue_middle.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_middle.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_yellow_up.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_yellow_up.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\edit_title_blue.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_blue.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\note_edit_color_selector_panel.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_note_edit_color_selector_panel.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\new_note_normal.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_new_note_normal.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\datetime_picker.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_datetime_picker.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\icon_app.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_icon_app.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\font_size_selector_bg.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_size_selector_bg.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_red_single.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_single.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\note_list.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_white_single.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_single.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_blue_single.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_single.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_white.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_white.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\dropdown_icon.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_dropdown_icon.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_red_up.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_up.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\menu\\note_list_options.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list_options.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\note_edit.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_edit.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\menu\\sub_folder.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\menu_sub_folder.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_blue.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_blue.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\edit_title_white.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_title_white.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_red_down.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_red_down.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\new_note_pressed.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_new_note_pressed.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\font_normal.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_font_normal.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\edit_green.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_green.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\add_account_text.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_add_account_text.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_white_down.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_white_down.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\menu\\note_list_dropdown.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list_dropdown.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\menu\\note_list.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_list.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\edit_blue.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_edit_blue.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\layout\\note_list_dropdown_menu.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\layout_note_list_dropdown_menu.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\widget_2x_blue.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_2x_blue.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_blue_up.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_blue_up.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\color\\primary_text_dark.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\color_primary_text_dark.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\list_green_middle.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_list_green_middle.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\menu\\note_edit.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\menu_note_edit.xml.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\title_bar_bg.9.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_title_bar_bg.9.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\drawable-hdpi\\widget_4x_yellow.png=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\drawable-hdpi_widget_4x_yellow.png.flat
+C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\src\\main\\res\\xml\\searchable.xml=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\res\\merged\\debug\\xml_searchable.xml.flat
diff --git a/rnotes/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-zh-rCN/values-zh-rCN.xml b/rnotes/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-zh-rCN/values-zh-rCN.xml
new file mode 100644
index 0000000..d65e0cc
--- /dev/null
+++ b/rnotes/app/build/intermediates/incremental/mergeDebugResources/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/rnotes/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-zh-rTW/values-zh-rTW.xml b/rnotes/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values-zh-rTW/values-zh-rTW.xml
new file mode 100644
index 0000000..226b5bc
--- /dev/null
+++ b/rnotes/app/build/intermediates/incremental/mergeDebugResources/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/rnotes/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values/values.xml b/rnotes/app/build/intermediates/incremental/mergeDebugResources/merged.dir/values/values.xml
new file mode 100644
index 0000000..dfa7135
--- /dev/null
+++ b/rnotes/app/build/intermediates/incremental/mergeDebugResources/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/rnotes/app/build/intermediates/incremental/mergeDebugResources/merger.xml b/rnotes/app/build/intermediates/incremental/mergeDebugResources/merger.xml
new file mode 100644
index 0000000..e7698aa
--- /dev/null
+++ b/rnotes/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 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/rnotes/app/build/intermediates/incremental/mergeDebugShaders/merger.xml b/rnotes/app/build/intermediates/incremental/mergeDebugShaders/merger.xml
new file mode 100644
index 0000000..f601de6
--- /dev/null
+++ b/rnotes/app/build/intermediates/incremental/mergeDebugShaders/merger.xml
@@ -0,0 +1,2 @@
+
+
\ No newline at end of file
diff --git a/rnotes/app/build/intermediates/incremental/packageDebug/tmp/debug/dex-renamer-state.txt b/rnotes/app/build/intermediates/incremental/packageDebug/tmp/debug/dex-renamer-state.txt
new file mode 100644
index 0000000..6cef92d
--- /dev/null
+++ b/rnotes/app/build/intermediates/incremental/packageDebug/tmp/debug/dex-renamer-state.txt
@@ -0,0 +1,4 @@
+#Mon May 08 08:54:52 CST 2023
+base.0=C\:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\dex\\debug\\mergeDexDebug\\out\\classes.dex
+path.0=classes.dex
+renamed.0=classes.dex
diff --git a/rnotes/app/build/intermediates/incremental/packageDebug/tmp/debug/zip-cache/_A0SBdsa6Mm5a3E1RVituvCfqYY= b/rnotes/app/build/intermediates/incremental/packageDebug/tmp/debug/zip-cache/_A0SBdsa6Mm5a3E1RVituvCfqYY=
new file mode 100644
index 0000000..4884df4
Binary files /dev/null and b/rnotes/app/build/intermediates/incremental/packageDebug/tmp/debug/zip-cache/_A0SBdsa6Mm5a3E1RVituvCfqYY= differ
diff --git a/rnotes/app/build/intermediates/instant_app_manifest/debug/AndroidManifest.xml b/rnotes/app/build/intermediates/instant_app_manifest/debug/AndroidManifest.xml
new file mode 100644
index 0000000..72a45c5
--- /dev/null
+++ b/rnotes/app/build/intermediates/instant_app_manifest/debug/AndroidManifest.xml
@@ -0,0 +1,152 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/rnotes/app/build/intermediates/instant_app_manifest/debug/output.json b/rnotes/app/build/intermediates/instant_app_manifest/debug/output.json
new file mode 100644
index 0000000..f52417e
--- /dev/null
+++ b/rnotes/app/build/intermediates/instant_app_manifest/debug/output.json
@@ -0,0 +1 @@
+[{"outputType":{"type":"INSTANT_APP_MANIFEST"},"apkData":{"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/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/BuildConfig.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/BuildConfig.class
new file mode 100644
index 0000000..499705b
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/BuildConfig.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$array.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$array.class
new file mode 100644
index 0000000..eee541e
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$array.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$color.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$color.class
new file mode 100644
index 0000000..312cdc8
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$color.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$dimen.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$dimen.class
new file mode 100644
index 0000000..1e7308a
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$dimen.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$drawable.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$drawable.class
new file mode 100644
index 0000000..046a632
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$drawable.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$id.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$id.class
new file mode 100644
index 0000000..fbfac9b
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$id.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$layout.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$layout.class
new file mode 100644
index 0000000..0ee603a
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$layout.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$menu.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$menu.class
new file mode 100644
index 0000000..435d64f
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$menu.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$plurals.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$plurals.class
new file mode 100644
index 0000000..7ce0e76
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$plurals.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$raw.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$raw.class
new file mode 100644
index 0000000..8d47686
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$raw.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$string.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$string.class
new file mode 100644
index 0000000..f8b6227
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$string.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$style.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$style.class
new file mode 100644
index 0000000..4c6fbc6
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$style.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$xml.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$xml.class
new file mode 100644
index 0000000..6c67f6d
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R$xml.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R.class
new file mode 100644
index 0000000..56fbbd6
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/R.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Contact.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Contact.class
new file mode 100644
index 0000000..7f4f3ef
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Contact.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$CallNote.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$CallNote.class
new file mode 100644
index 0000000..620035c
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$CallNote.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$DataColumns.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$DataColumns.class
new file mode 100644
index 0000000..a4e6edc
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$DataColumns.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$DataConstants.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$DataConstants.class
new file mode 100644
index 0000000..f1092fc
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$DataConstants.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$NoteColumns.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$NoteColumns.class
new file mode 100644
index 0000000..6d8c966
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$NoteColumns.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$TextNote.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$TextNote.class
new file mode 100644
index 0000000..c73d36e
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes$TextNote.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes.class
new file mode 100644
index 0000000..40640b3
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/Notes.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/NotesDatabaseHelper$TABLE.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/NotesDatabaseHelper$TABLE.class
new file mode 100644
index 0000000..4d07390
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/NotesDatabaseHelper$TABLE.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/NotesDatabaseHelper.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/NotesDatabaseHelper.class
new file mode 100644
index 0000000..5312fbd
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/NotesDatabaseHelper.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/NotesProvider.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/NotesProvider.class
new file mode 100644
index 0000000..8558246
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/data/NotesProvider.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/MetaData.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/MetaData.class
new file mode 100644
index 0000000..77ebd87
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/MetaData.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/Node.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/Node.class
new file mode 100644
index 0000000..d129050
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/Node.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/SqlData.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/SqlData.class
new file mode 100644
index 0000000..18d8e62
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/SqlData.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/SqlNote.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/SqlNote.class
new file mode 100644
index 0000000..a575af1
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/SqlNote.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/Task.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/Task.class
new file mode 100644
index 0000000..2004066
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/Task.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/TaskList.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/TaskList.class
new file mode 100644
index 0000000..7fd93af
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/data/TaskList.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/exception/ActionFailureException.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/exception/ActionFailureException.class
new file mode 100644
index 0000000..6a11981
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/exception/ActionFailureException.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/exception/NetworkFailureException.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/exception/NetworkFailureException.class
new file mode 100644
index 0000000..a7ffbfa
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/exception/NetworkFailureException.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskASyncTask$1.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskASyncTask$1.class
new file mode 100644
index 0000000..c6dae5c
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskASyncTask$1.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.class
new file mode 100644
index 0000000..c671684
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskASyncTask.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskASyncTask.class
new file mode 100644
index 0000000..7c9ce61
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskASyncTask.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskClient.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskClient.class
new file mode 100644
index 0000000..3ca8821
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskClient.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskManager.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskManager.class
new file mode 100644
index 0000000..03b143b
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskManager.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskSyncService$1.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskSyncService$1.class
new file mode 100644
index 0000000..12a31cb
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskSyncService$1.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskSyncService.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskSyncService.class
new file mode 100644
index 0000000..4797112
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/gtask/remote/GTaskSyncService.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/model/Note$NoteData.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/model/Note$NoteData.class
new file mode 100644
index 0000000..dd25511
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/model/Note$NoteData.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/model/Note.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/model/Note.class
new file mode 100644
index 0000000..b91202f
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/model/Note.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.class
new file mode 100644
index 0000000..add97e1
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/model/WorkingNote.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/model/WorkingNote.class
new file mode 100644
index 0000000..52cdd89
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/model/WorkingNote.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/BackupUtils$TextExport.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/BackupUtils$TextExport.class
new file mode 100644
index 0000000..47b930b
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/BackupUtils$TextExport.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/BackupUtils.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/BackupUtils.class
new file mode 100644
index 0000000..750d9c6
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/BackupUtils.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/DataUtils.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/DataUtils.class
new file mode 100644
index 0000000..7441e70
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/DataUtils.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/GTaskStringUtils.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/GTaskStringUtils.class
new file mode 100644
index 0000000..0030332
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/GTaskStringUtils.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$NoteBgResources.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$NoteBgResources.class
new file mode 100644
index 0000000..ff81638
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$NoteBgResources.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$NoteItemBgResources.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$NoteItemBgResources.class
new file mode 100644
index 0000000..36b4922
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$NoteItemBgResources.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$TextAppearanceResources.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$TextAppearanceResources.class
new file mode 100644
index 0000000..823ef1b
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$TextAppearanceResources.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$WidgetBgResources.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$WidgetBgResources.class
new file mode 100644
index 0000000..4047d44
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser$WidgetBgResources.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser.class
new file mode 100644
index 0000000..068f824
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/tool/ResourceParser.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/AlarmAlertActivity.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/AlarmAlertActivity.class
new file mode 100644
index 0000000..95fa8a5
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/AlarmAlertActivity.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/AlarmInitReceiver.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/AlarmInitReceiver.class
new file mode 100644
index 0000000..d5771d0
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/AlarmInitReceiver.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/AlarmReceiver.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/AlarmReceiver.class
new file mode 100644
index 0000000..b29a318
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/AlarmReceiver.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$1.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$1.class
new file mode 100644
index 0000000..1927e68
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$1.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$2.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$2.class
new file mode 100644
index 0000000..6359086
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$2.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$3.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$3.class
new file mode 100644
index 0000000..1e6db2c
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$3.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$4.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$4.class
new file mode 100644
index 0000000..54c442c
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$4.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.class
new file mode 100644
index 0000000..4f59cba
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker.class
new file mode 100644
index 0000000..8c369b7
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePicker.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePickerDialog$1.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePickerDialog$1.class
new file mode 100644
index 0000000..cebe2a3
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePickerDialog$1.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.class
new file mode 100644
index 0000000..e4b9fdc
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePickerDialog.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePickerDialog.class
new file mode 100644
index 0000000..3da8eb1
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DateTimePickerDialog.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DropdownMenu$1.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DropdownMenu$1.class
new file mode 100644
index 0000000..7db192e
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DropdownMenu$1.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DropdownMenu.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DropdownMenu.class
new file mode 100644
index 0000000..5eed195
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/DropdownMenu.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/FoldersListAdapter$FolderListItem.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/FoldersListAdapter$FolderListItem.class
new file mode 100644
index 0000000..c166e99
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/FoldersListAdapter$FolderListItem.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/FoldersListAdapter.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/FoldersListAdapter.class
new file mode 100644
index 0000000..51e6b34
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/FoldersListAdapter.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$1.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$1.class
new file mode 100644
index 0000000..d879e16
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$1.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$2.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$2.class
new file mode 100644
index 0000000..b789f1d
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$2.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$3.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$3.class
new file mode 100644
index 0000000..866ec31
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$3.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.class
new file mode 100644
index 0000000..5bd5d69
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity.class
new file mode 100644
index 0000000..d41f333
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditActivity.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditText$1.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditText$1.class
new file mode 100644
index 0000000..e475edd
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditText$1.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.class
new file mode 100644
index 0000000..2ff02fa
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditText.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditText.class
new file mode 100644
index 0000000..6102411
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteEditText.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteItemData.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteItemData.class
new file mode 100644
index 0000000..e14b454
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NoteItemData.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$1.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$1.class
new file mode 100644
index 0000000..d7d0fc9
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$1.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$2.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$2.class
new file mode 100644
index 0000000..7e01406
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$2.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$3.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$3.class
new file mode 100644
index 0000000..f3d88ce
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$3.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$4.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$4.class
new file mode 100644
index 0000000..6ffb6ee
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$4.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$5.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$5.class
new file mode 100644
index 0000000..045dd2a
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$5.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$6.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$6.class
new file mode 100644
index 0000000..664dcbb
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$6.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$7.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$7.class
new file mode 100644
index 0000000..5d985f6
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$7.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$8.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$8.class
new file mode 100644
index 0000000..39ffb21
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$8.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$9.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$9.class
new file mode 100644
index 0000000..6e98dbb
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$9.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.class
new file mode 100644
index 0000000..250f431
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ListEditState.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ListEditState.class
new file mode 100644
index 0000000..88a92d9
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ListEditState.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ModeCallback$1.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ModeCallback$1.class
new file mode 100644
index 0000000..a9bdef5
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ModeCallback$1.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ModeCallback$2.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ModeCallback$2.class
new file mode 100644
index 0000000..7a20028
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ModeCallback$2.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ModeCallback.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ModeCallback.class
new file mode 100644
index 0000000..0930bf9
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$ModeCallback.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.class
new file mode 100644
index 0000000..8d35c85
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.class
new file mode 100644
index 0000000..de885be
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity.class
new file mode 100644
index 0000000..c677232
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListActivity.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.class
new file mode 100644
index 0000000..48e3ed4
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListAdapter.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListAdapter.class
new file mode 100644
index 0000000..c161d09
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListAdapter.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListItem.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListItem.class
new file mode 100644
index 0000000..d361bc6
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesListItem.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$1.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$1.class
new file mode 100644
index 0000000..f6c7814
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$1.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$2.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$2.class
new file mode 100644
index 0000000..88c3a02
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$2.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$3.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$3.class
new file mode 100644
index 0000000..732b6aa
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$3.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$4.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$4.class
new file mode 100644
index 0000000..1e3e0f7
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$4.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$5.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$5.class
new file mode 100644
index 0000000..b8f887a
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$5.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$6.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$6.class
new file mode 100644
index 0000000..282522d
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$6.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$7.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$7.class
new file mode 100644
index 0000000..01a4267
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$7.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$8.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$8.class
new file mode 100644
index 0000000..b4d341e
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$8.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.class
new file mode 100644
index 0000000..9a8fb0c
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity.class
new file mode 100644
index 0000000..fc41031
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/ui/NotesPreferenceActivity.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/widget/NoteWidgetProvider.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/widget/NoteWidgetProvider.class
new file mode 100644
index 0000000..5aea3c1
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/widget/NoteWidgetProvider.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/widget/NoteWidgetProvider_2x.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/widget/NoteWidgetProvider_2x.class
new file mode 100644
index 0000000..29097c7
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/widget/NoteWidgetProvider_2x.class differ
diff --git a/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/widget/NoteWidgetProvider_4x.class b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/widget/NoteWidgetProvider_4x.class
new file mode 100644
index 0000000..a445e4e
Binary files /dev/null and b/rnotes/app/build/intermediates/javac/debug/classes/net/micode/notes/widget/NoteWidgetProvider_4x.class differ
diff --git a/rnotes/app/build/intermediates/manifest_merge_blame_file/debug/manifest-merger-blame-debug-report.txt b/rnotes/app/build/intermediates/manifest_merge_blame_file/debug/manifest-merger-blame-debug-report.txt
new file mode 100644
index 0000000..5fbd772
--- /dev/null
+++ b/rnotes/app/build/intermediates/manifest_merge_blame_file/debug/manifest-merger-blame-debug-report.txt
@@ -0,0 +1,272 @@
+1
+2
+17
+21
+22 C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml
+24 android:targetSdkVersion="14" />
+24-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml
+25
+26
+26-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:23:5-81
+26-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:23:22-78
+27
+27-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:24:5-88
+27-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:24:22-85
+28
+28-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:25:5-67
+28-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:25:22-64
+29
+29-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:26:5-72
+29-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:26:22-69
+30
+30-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:27:5-74
+30-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:27:22-71
+31
+31-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:28:5-80
+31-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:28:22-77
+32
+32-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:29:5-71
+32-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:29:22-68
+33
+33-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:30:5-74
+33-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:30:22-71
+34
+34-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:31:5-81
+34-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:31:22-78
+35
+36 C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:33:5-147:19
+37 android:debuggable="true"
+38 android:icon="@drawable/icon_app"
+38-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:34:9-42
+39 android:label="@string/app_name"
+39-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:35:9-41
+40 android:testOnly="true" >
+41 C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:36:9-49:20
+42 android:name="net.micode.notes.ui.NotesListActivity"
+42-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:37:13-49
+43 android:configChanges="keyboardHidden|orientation|screenSize"
+43-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:38:13-74
+44 android:label="@string/app_name"
+44-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:39:13-45
+45 android:launchMode="singleTop"
+45-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:40:13-43
+46 android:theme="@style/NoteTheme"
+46-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:41:13-45
+47 android:uiOptions="splitActionBarWhenNarrow"
+47-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:42:13-57
+48 android:windowSoftInputMode="adjustPan" >
+48-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:43:13-52
+49
+49-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:45:13-48:29
+50
+50-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:46:17-69
+50-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:46:25-66
+51
+52
+52-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:47:17-77
+52-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:47:27-74
+53
+54
+55 C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:51:9-79:20
+56 android:name="net.micode.notes.ui.NoteEditActivity"
+56-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:52:13-48
+57 android:configChanges="keyboardHidden|orientation|screenSize"
+57-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:53:13-74
+58 android:launchMode="singleTop"
+58-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:54:13-43
+59 android:theme="@style/NoteTheme" >
+59-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:55:13-45
+60
+60-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:57:13-62:29
+61
+61-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:58:17-69
+61-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:58:25-66
+62
+63
+63-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:59:17-76
+63-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:59:27-73
+64
+65
+65-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:60:17-78
+65-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:60:23-75
+66
+66-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:60:17-78
+66-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:60:23-75
+67
+68
+68-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:64:13-69:29
+69
+69-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:65:17-79
+69-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:65:25-76
+70
+71
+71-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:59:17-76
+71-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:59:27-73
+72
+73
+73-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:60:17-78
+73-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:60:23-75
+74
+74-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:60:17-78
+74-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:60:23-75
+75
+76
+76-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:71:13-74:29
+77
+77-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:72:17-71
+77-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:72:25-68
+78
+79
+79-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:59:17-76
+79-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:59:27-73
+80
+81
+82 C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:76:13-78:54
+83 android:name="android.app.searchable"
+83-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:77:17-54
+84 android:resource="@xml/searchable" />
+84-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:78:17-51
+85
+86
+87 C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:81:9-84:43
+88 android:name="net.micode.notes.data.NotesProvider"
+88-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:82:13-63
+89 android:authorities="micode_notes"
+89-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:83:13-47
+90 android:multiprocess="true" />
+90-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:84:13-40
+91
+92 C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:86:9-98:20
+93 android:name="net.micode.notes.widget.NoteWidgetProvider_2x"
+93-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:87:13-57
+94 android:label="@string/app_widget2x2" >
+94-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:88:13-50
+95
+95-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:89:13-93:29
+96
+96-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:90:17-84
+96-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:90:25-81
+97
+97-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:91:17-85
+97-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:91:25-82
+98
+98-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:92:17-85
+98-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:92:25-82
+99
+100
+101 C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:95:13-97:58
+102 android:name="android.appwidget.provider"
+102-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:96:17-58
+103 android:resource="@xml/widget_2x_info" />
+103-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:97:17-55
+104
+105 C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:99:9-112:20
+106 android:name="net.micode.notes.widget.NoteWidgetProvider_4x"
+106-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:100:13-57
+107 android:label="@string/app_widget4x4" >
+107-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:101:13-50
+108
+108-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:89:13-93:29
+109
+109-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:90:17-84
+109-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:90:25-81
+110
+110-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:91:17-85
+110-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:91:25-82
+111
+111-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:92:17-85
+111-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:92:25-82
+112
+113
+114 C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:95:13-97:58
+115 android:name="android.appwidget.provider"
+115-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:96:17-58
+116 android:resource="@xml/widget_4x_info" />
+116-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:97:17-55
+117
+118
+118-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:114:9-118:20
+118-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:114:19-55
+119
+119-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:115:13-117:29
+120
+120-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:116:17-79
+120-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:116:25-76
+121
+122
+123 C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:120:9-123:20
+124 android:name="net.micode.notes.ui.AlarmReceiver"
+124-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:121:13-61
+125 android:process=":remote" >
+125-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:122:13-38
+126
+127
+128 C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:125:9-130:20
+129 android:name="net.micode.notes.ui.AlarmAlertActivity"
+129-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:126:13-50
+130 android:label="@string/app_name"
+130-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:127:13-45
+131 android:launchMode="singleInstance"
+131-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:128:13-48
+132 android:theme="@android:style/Theme.Holo.Wallpaper.NoTitleBar" >
+132-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:129:13-75
+133
+134 C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:132:9-137:20
+135 android:name="net.micode.notes.ui.NotesPreferenceActivity"
+135-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:133:13-71
+136 android:label="@string/preferences_title"
+136-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:134:13-54
+137 android:launchMode="singleTop"
+137-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:135:13-43
+138 android:theme="@android:style/Theme.Holo.Light" >
+138-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:136:13-60
+139
+140
+141 C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:139:9-142:19
+142 android:name="net.micode.notes.gtask.remote.GTaskSyncService"
+142-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:140:13-74
+143 android:exported="false" >
+143-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:141:13-37
+144
+145
+146 C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:144:9-146:52
+147 android:name="android.app.default_searchable"
+147-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:145:13-58
+148 android:value=".ui.NoteEditActivity" />
+148-->C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:146:13-49
+149
+150
+151
diff --git a/rnotes/app/build/intermediates/merged_java_res/debug/out.jar b/rnotes/app/build/intermediates/merged_java_res/debug/out.jar
new file mode 100644
index 0000000..15cb0ec
Binary files /dev/null and b/rnotes/app/build/intermediates/merged_java_res/debug/out.jar differ
diff --git a/rnotes/app/build/intermediates/merged_manifests/debug/AndroidManifest.xml b/rnotes/app/build/intermediates/merged_manifests/debug/AndroidManifest.xml
new file mode 100644
index 0000000..f237bf5
--- /dev/null
+++ b/rnotes/app/build/intermediates/merged_manifests/debug/AndroidManifest.xml
@@ -0,0 +1,151 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/rnotes/app/build/intermediates/merged_manifests/debug/output.json b/rnotes/app/build/intermediates/merged_manifests/debug/output.json
new file mode 100644
index 0000000..1e67bfd
--- /dev/null
+++ b/rnotes/app/build/intermediates/merged_manifests/debug/output.json
@@ -0,0 +1 @@
+[{"outputType":{"type":"MERGED_MANIFESTS"},"apkData":{"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/rnotes/app/build/intermediates/merged_manifests/debugAndroidTest/AndroidManifest.xml b/rnotes/app/build/intermediates/merged_manifests/debugAndroidTest/AndroidManifest.xml
new file mode 100644
index 0000000..485ad0f
--- /dev/null
+++ b/rnotes/app/build/intermediates/merged_manifests/debugAndroidTest/AndroidManifest.xml
@@ -0,0 +1,16 @@
+
+
+
+
+
+
+
+
+
+
+
diff --git a/rnotes/app/build/intermediates/merged_manifests/debugAndroidTest/output.json b/rnotes/app/build/intermediates/merged_manifests/debugAndroidTest/output.json
new file mode 100644
index 0000000..4ec0136
--- /dev/null
+++ b/rnotes/app/build/intermediates/merged_manifests/debugAndroidTest/output.json
@@ -0,0 +1 @@
+[{"outputType":{"type":"MERGED_MANIFESTS"},"apkData":{"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/rnotes/app/build/intermediates/metadata_feature_manifest/debug/processDebugManifest/metadata-feature/output.json b/rnotes/app/build/intermediates/metadata_feature_manifest/debug/processDebugManifest/metadata-feature/output.json
new file mode 100644
index 0000000..2091fd2
--- /dev/null
+++ b/rnotes/app/build/intermediates/metadata_feature_manifest/debug/processDebugManifest/metadata-feature/output.json
@@ -0,0 +1 @@
+[{"outputType":{"type":"METADATA_FEATURE_MANIFEST"},"apkData":{"type":"MAIN","splits":[],"versionCode":1,"versionName":"0.1","enabled":true,"outputFile":"app-debug.apk","fullName":"debug","baseName":"debug"},"path":"AndroidManifest.xml","properties":{}}]
\ No newline at end of file
diff --git a/rnotes/app/build/intermediates/processed_res/debug/processDebugResources/out/output.json b/rnotes/app/build/intermediates/processed_res/debug/processDebugResources/out/output.json
new file mode 100644
index 0000000..ed540dd
--- /dev/null
+++ b/rnotes/app/build/intermediates/processed_res/debug/processDebugResources/out/output.json
@@ -0,0 +1 @@
+[{"outputType":{"type":"PROCESSED_RES"},"apkData":{"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/rnotes/app/build/intermediates/processed_res/debug/processDebugResources/out/resources-debug.ap_ b/rnotes/app/build/intermediates/processed_res/debug/processDebugResources/out/resources-debug.ap_
new file mode 100644
index 0000000..77e954a
Binary files /dev/null and b/rnotes/app/build/intermediates/processed_res/debug/processDebugResources/out/resources-debug.ap_ differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/color_primary_text_dark.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/color_primary_text_dark.xml.flat
new file mode 100644
index 0000000..2c03a06
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/color_primary_text_dark.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/color_secondary_text_dark.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/color_secondary_text_dark.xml.flat
new file mode 100644
index 0000000..8233851
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/color_secondary_text_dark.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_bg_btn_set_color.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_bg_btn_set_color.png.flat
new file mode 100644
index 0000000..6764d83
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_bg_btn_set_color.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_bg_color_btn_mask.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_bg_color_btn_mask.png.flat
new file mode 100644
index 0000000..8d02a95
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_bg_color_btn_mask.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_call_record.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_call_record.png.flat
new file mode 100644
index 0000000..e23439a
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_call_record.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_clock.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_clock.png.flat
new file mode 100644
index 0000000..f5bf7de
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_clock.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_delete.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_delete.png.flat
new file mode 100644
index 0000000..f216751
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_delete.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_dropdown_icon.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_dropdown_icon.9.png.flat
new file mode 100644
index 0000000..eb21000
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_dropdown_icon.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_blue.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_blue.9.png.flat
new file mode 100644
index 0000000..1144326
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_blue.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_green.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_green.9.png.flat
new file mode 100644
index 0000000..0837f94
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_green.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_red.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_red.9.png.flat
new file mode 100644
index 0000000..f572ff1
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_red.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_blue.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_blue.9.png.flat
new file mode 100644
index 0000000..75a3fc7
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_blue.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_green.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_green.9.png.flat
new file mode 100644
index 0000000..ba7dbae
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_green.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_red.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_red.9.png.flat
new file mode 100644
index 0000000..5969da2
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_red.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_white.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_white.9.png.flat
new file mode 100644
index 0000000..864a923
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_white.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_yellow.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_yellow.9.png.flat
new file mode 100644
index 0000000..dd02938
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_title_yellow.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_white.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_white.9.png.flat
new file mode 100644
index 0000000..4e53ab6
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_white.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_yellow.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_yellow.9.png.flat
new file mode 100644
index 0000000..b1d1519
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_edit_yellow.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_font_large.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_font_large.png.flat
new file mode 100644
index 0000000..84ac7ec
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_font_large.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_font_normal.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_font_normal.png.flat
new file mode 100644
index 0000000..ea2ee9b
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_font_normal.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_font_size_selector_bg.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_font_size_selector_bg.9.png.flat
new file mode 100644
index 0000000..dd5e8f7
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_font_size_selector_bg.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_font_small.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_font_small.png.flat
new file mode 100644
index 0000000..2565948
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_font_small.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_font_super.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_font_super.png.flat
new file mode 100644
index 0000000..43a34b7
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_font_super.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_icon_app.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_icon_app.png.flat
new file mode 100644
index 0000000..080f26e
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_icon_app.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_background.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_background.png.flat
new file mode 100644
index 0000000..a489a1a
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_background.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_down.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_down.9.png.flat
new file mode 100644
index 0000000..2b4af11
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_down.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_middle.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_middle.9.png.flat
new file mode 100644
index 0000000..2f05232
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_middle.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_single.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_single.9.png.flat
new file mode 100644
index 0000000..651c6af
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_single.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_up.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_up.9.png.flat
new file mode 100644
index 0000000..47c1fee
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_blue_up.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_folder.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_folder.9.png.flat
new file mode 100644
index 0000000..ab8b097
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_folder.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_footer_bg.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_footer_bg.9.png.flat
new file mode 100644
index 0000000..e4fb5d4
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_footer_bg.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_down.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_down.9.png.flat
new file mode 100644
index 0000000..b15aa65
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_down.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_middle.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_middle.9.png.flat
new file mode 100644
index 0000000..6f4ad23
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_middle.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_single.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_single.9.png.flat
new file mode 100644
index 0000000..43dcf3d
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_single.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_up.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_up.9.png.flat
new file mode 100644
index 0000000..83dd2ff
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_green_up.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_down.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_down.9.png.flat
new file mode 100644
index 0000000..df58ac5
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_down.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_middle.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_middle.9.png.flat
new file mode 100644
index 0000000..eb4448a
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_middle.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_single.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_single.9.png.flat
new file mode 100644
index 0000000..19932ce
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_single.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_up.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_up.9.png.flat
new file mode 100644
index 0000000..27727a7
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_red_up.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_down.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_down.9.png.flat
new file mode 100644
index 0000000..248a318
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_down.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_middle.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_middle.9.png.flat
new file mode 100644
index 0000000..0e3168d
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_middle.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_single.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_single.9.png.flat
new file mode 100644
index 0000000..25d8791
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_single.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_up.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_up.9.png.flat
new file mode 100644
index 0000000..6ff9a3b
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_white_up.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_down.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_down.9.png.flat
new file mode 100644
index 0000000..fc205b7
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_down.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_middle.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_middle.9.png.flat
new file mode 100644
index 0000000..02e4fbd
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_middle.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_single.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_single.9.png.flat
new file mode 100644
index 0000000..10725f8
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_single.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_up.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_up.9.png.flat
new file mode 100644
index 0000000..38eaa02
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_list_yellow_up.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_menu_delete.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_menu_delete.png.flat
new file mode 100644
index 0000000..d41e8de
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_menu_delete.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_menu_move.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_menu_move.png.flat
new file mode 100644
index 0000000..b545651
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_menu_move.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_new_note_normal.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_new_note_normal.png.flat
new file mode 100644
index 0000000..ef4210a
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_new_note_normal.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_new_note_pressed.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_new_note_pressed.png.flat
new file mode 100644
index 0000000..ddb3df1
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_new_note_pressed.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_note_edit_color_selector_panel.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_note_edit_color_selector_panel.png.flat
new file mode 100644
index 0000000..aab7ab8
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_note_edit_color_selector_panel.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_notification.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_notification.png.flat
new file mode 100644
index 0000000..3623a27
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_notification.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_search_result.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_search_result.png.flat
new file mode 100644
index 0000000..d282aa7
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_search_result.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_selected.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_selected.png.flat
new file mode 100644
index 0000000..7450b42
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_selected.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_title_alert.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_title_alert.png.flat
new file mode 100644
index 0000000..3c6e23e
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_title_alert.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_title_bar_bg.9.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_title_bar_bg.9.png.flat
new file mode 100644
index 0000000..0428a58
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_title_bar_bg.9.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_blue.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_blue.png.flat
new file mode 100644
index 0000000..dbdef38
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_blue.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_green.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_green.png.flat
new file mode 100644
index 0000000..796b560
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_green.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_red.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_red.png.flat
new file mode 100644
index 0000000..5b3f635
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_red.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_white.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_white.png.flat
new file mode 100644
index 0000000..6de3948
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_white.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_yellow.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_yellow.png.flat
new file mode 100644
index 0000000..db8e66c
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_2x_yellow.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_blue.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_blue.png.flat
new file mode 100644
index 0000000..1817a4e
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_blue.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_green.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_green.png.flat
new file mode 100644
index 0000000..60fe621
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_green.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_red.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_red.png.flat
new file mode 100644
index 0000000..645ebb6
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_red.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_white.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_white.png.flat
new file mode 100644
index 0000000..bf4f996
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_white.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_yellow.png.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_yellow.png.flat
new file mode 100644
index 0000000..6b5b1e1
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable-hdpi_widget_4x_yellow.png.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/drawable_new_note.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/drawable_new_note.xml.flat
new file mode 100644
index 0000000..6c01cea
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/drawable_new_note.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/layout_account_dialog_title.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/layout_account_dialog_title.xml.flat
new file mode 100644
index 0000000..69c62ed
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/layout_account_dialog_title.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/layout_add_account_text.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/layout_add_account_text.xml.flat
new file mode 100644
index 0000000..d65fec8
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/layout_add_account_text.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/layout_datetime_picker.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/layout_datetime_picker.xml.flat
new file mode 100644
index 0000000..2d023f5
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/layout_datetime_picker.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/layout_dialog_edit_text.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/layout_dialog_edit_text.xml.flat
new file mode 100644
index 0000000..76aeac8
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/layout_dialog_edit_text.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/layout_folder_list_item.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/layout_folder_list_item.xml.flat
new file mode 100644
index 0000000..9757503
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/layout_folder_list_item.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/layout_note_edit.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/layout_note_edit.xml.flat
new file mode 100644
index 0000000..5b194f7
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/layout_note_edit.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/layout_note_edit_list_item.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/layout_note_edit_list_item.xml.flat
new file mode 100644
index 0000000..435bad5
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/layout_note_edit_list_item.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/layout_note_item.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/layout_note_item.xml.flat
new file mode 100644
index 0000000..cadceba
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/layout_note_item.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/layout_note_list.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/layout_note_list.xml.flat
new file mode 100644
index 0000000..cb57747
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/layout_note_list.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/layout_note_list_dropdown_menu.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/layout_note_list_dropdown_menu.xml.flat
new file mode 100644
index 0000000..8af2b38
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/layout_note_list_dropdown_menu.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/layout_note_list_footer.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/layout_note_list_footer.xml.flat
new file mode 100644
index 0000000..5192126
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/layout_note_list_footer.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/layout_settings_header.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/layout_settings_header.xml.flat
new file mode 100644
index 0000000..1e6ce20
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/layout_settings_header.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/layout_widget_2x.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/layout_widget_2x.xml.flat
new file mode 100644
index 0000000..e7c43f9
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/layout_widget_2x.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/layout_widget_4x.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/layout_widget_4x.xml.flat
new file mode 100644
index 0000000..50222c8
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/layout_widget_4x.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/menu_call_note_edit.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/menu_call_note_edit.xml.flat
new file mode 100644
index 0000000..737b170
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/menu_call_note_edit.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/menu_call_record_folder.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/menu_call_record_folder.xml.flat
new file mode 100644
index 0000000..8417047
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/menu_call_record_folder.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/menu_note_edit.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/menu_note_edit.xml.flat
new file mode 100644
index 0000000..076542f
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/menu_note_edit.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/menu_note_list.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/menu_note_list.xml.flat
new file mode 100644
index 0000000..3500550
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/menu_note_list.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/menu_note_list_dropdown.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/menu_note_list_dropdown.xml.flat
new file mode 100644
index 0000000..f0ca778
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/menu_note_list_dropdown.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/menu_note_list_options.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/menu_note_list_options.xml.flat
new file mode 100644
index 0000000..0a20578
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/menu_note_list_options.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/menu_sub_folder.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/menu_sub_folder.xml.flat
new file mode 100644
index 0000000..af1c525
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/menu_sub_folder.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/raw-zh-rCN_introduction.flat b/rnotes/app/build/intermediates/res/merged/debug/raw-zh-rCN_introduction.flat
new file mode 100644
index 0000000..0e4b4d8
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/raw-zh-rCN_introduction.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/raw_introduction.flat b/rnotes/app/build/intermediates/res/merged/debug/raw_introduction.flat
new file mode 100644
index 0000000..9a707a6
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/raw_introduction.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/values-zh-rCN_values-zh-rCN.arsc.flat b/rnotes/app/build/intermediates/res/merged/debug/values-zh-rCN_values-zh-rCN.arsc.flat
new file mode 100644
index 0000000..91c0bb9
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/values-zh-rCN_values-zh-rCN.arsc.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/values-zh-rTW_values-zh-rTW.arsc.flat b/rnotes/app/build/intermediates/res/merged/debug/values-zh-rTW_values-zh-rTW.arsc.flat
new file mode 100644
index 0000000..15f81e3
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/values-zh-rTW_values-zh-rTW.arsc.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/values_values.arsc.flat b/rnotes/app/build/intermediates/res/merged/debug/values_values.arsc.flat
new file mode 100644
index 0000000..798bc88
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/values_values.arsc.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/xml_preferences.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/xml_preferences.xml.flat
new file mode 100644
index 0000000..43f9880
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/xml_preferences.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/xml_searchable.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/xml_searchable.xml.flat
new file mode 100644
index 0000000..49e57dc
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/xml_searchable.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/xml_widget_2x_info.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/xml_widget_2x_info.xml.flat
new file mode 100644
index 0000000..9f17d90
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/xml_widget_2x_info.xml.flat differ
diff --git a/rnotes/app/build/intermediates/res/merged/debug/xml_widget_4x_info.xml.flat b/rnotes/app/build/intermediates/res/merged/debug/xml_widget_4x_info.xml.flat
new file mode 100644
index 0000000..5d41d29
Binary files /dev/null and b/rnotes/app/build/intermediates/res/merged/debug/xml_widget_4x_info.xml.flat differ
diff --git a/rnotes/app/build/intermediates/signing_config/debug/out/signing-config.json b/rnotes/app/build/intermediates/signing_config/debug/out/signing-config.json
new file mode 100644
index 0000000..46d7fd2
--- /dev/null
+++ b/rnotes/app/build/intermediates/signing_config/debug/out/signing-config.json
@@ -0,0 +1 @@
+{"mName":"debug","mStoreFile":"C:\\Users\\19440\\.android\\debug.keystore","mStorePassword":"android","mKeyAlias":"AndroidDebugKey","mKeyPassword":"android","mStoreType":"jks","mV1SigningEnabled":true,"mV2SigningEnabled":true}
\ No newline at end of file
diff --git a/rnotes/app/build/intermediates/symbols/debug/R.txt b/rnotes/app/build/intermediates/symbols/debug/R.txt
new file mode 100644
index 0000000..00d6e91
--- /dev/null
+++ b/rnotes/app/build/intermediates/symbols/debug/R.txt
@@ -0,0 +1,283 @@
+int array format_for_exported_note 0x7f010000
+int array menu_share_ways 0x7f010001
+int color primary_text_dark 0x7f020000
+int color secondary_text_dark 0x7f020001
+int color user_query_highlight 0x7f020002
+int dimen text_font_size_large 0x7f030000
+int dimen text_font_size_medium 0x7f030001
+int dimen text_font_size_normal 0x7f030002
+int dimen text_font_size_small 0x7f030003
+int dimen text_font_size_super 0x7f030004
+int drawable bg_btn_set_color 0x7f040000
+int drawable bg_color_btn_mask 0x7f040001
+int drawable call_record 0x7f040002
+int drawable clock 0x7f040003
+int drawable delete 0x7f040004
+int drawable dropdown_icon 0x7f040005
+int drawable edit_blue 0x7f040006
+int drawable edit_green 0x7f040007
+int drawable edit_red 0x7f040008
+int drawable edit_title_blue 0x7f040009
+int drawable edit_title_green 0x7f04000a
+int drawable edit_title_red 0x7f04000b
+int drawable edit_title_white 0x7f04000c
+int drawable edit_title_yellow 0x7f04000d
+int drawable edit_white 0x7f04000e
+int drawable edit_yellow 0x7f04000f
+int drawable font_large 0x7f040010
+int drawable font_normal 0x7f040011
+int drawable font_size_selector_bg 0x7f040012
+int drawable font_small 0x7f040013
+int drawable font_super 0x7f040014
+int drawable icon_app 0x7f040015
+int drawable list_background 0x7f040016
+int drawable list_blue_down 0x7f040017
+int drawable list_blue_middle 0x7f040018
+int drawable list_blue_single 0x7f040019
+int drawable list_blue_up 0x7f04001a
+int drawable list_folder 0x7f04001b
+int drawable list_footer_bg 0x7f04001c
+int drawable list_green_down 0x7f04001d
+int drawable list_green_middle 0x7f04001e
+int drawable list_green_single 0x7f04001f
+int drawable list_green_up 0x7f040020
+int drawable list_red_down 0x7f040021
+int drawable list_red_middle 0x7f040022
+int drawable list_red_single 0x7f040023
+int drawable list_red_up 0x7f040024
+int drawable list_white_down 0x7f040025
+int drawable list_white_middle 0x7f040026
+int drawable list_white_single 0x7f040027
+int drawable list_white_up 0x7f040028
+int drawable list_yellow_down 0x7f040029
+int drawable list_yellow_middle 0x7f04002a
+int drawable list_yellow_single 0x7f04002b
+int drawable list_yellow_up 0x7f04002c
+int drawable menu_delete 0x7f04002d
+int drawable menu_move 0x7f04002e
+int drawable new_note 0x7f04002f
+int drawable new_note_normal 0x7f040030
+int drawable new_note_pressed 0x7f040031
+int drawable note_edit_color_selector_panel 0x7f040032
+int drawable notification 0x7f040033
+int drawable search_result 0x7f040034
+int drawable selected 0x7f040035
+int drawable title_alert 0x7f040036
+int drawable title_bar_bg 0x7f040037
+int drawable widget_2x_blue 0x7f040038
+int drawable widget_2x_green 0x7f040039
+int drawable widget_2x_red 0x7f04003a
+int drawable widget_2x_white 0x7f04003b
+int drawable widget_2x_yellow 0x7f04003c
+int drawable widget_4x_blue 0x7f04003d
+int drawable widget_4x_green 0x7f04003e
+int drawable widget_4x_red 0x7f04003f
+int drawable widget_4x_white 0x7f040040
+int drawable widget_4x_yellow 0x7f040041
+int id account_dialog_subtitle 0x7f050000
+int id account_dialog_title 0x7f050001
+int id action_select_all 0x7f050002
+int id amPm 0x7f050003
+int id btn_new_note 0x7f050004
+int id btn_set_bg_color 0x7f050005
+int id cb_edit_item 0x7f050006
+int id date 0x7f050007
+int id delete 0x7f050008
+int id et_edit_text 0x7f050009
+int id et_foler_name 0x7f05000a
+int id font_size_selector 0x7f05000b
+int id hour 0x7f05000c
+int id iv_alert_icon 0x7f05000d
+int id iv_bg_blue 0x7f05000e
+int id iv_bg_blue_select 0x7f05000f
+int id iv_bg_green 0x7f050010
+int id iv_bg_green_select 0x7f050011
+int id iv_bg_red 0x7f050012
+int id iv_bg_red_select 0x7f050013
+int id iv_bg_white 0x7f050014
+int id iv_bg_white_select 0x7f050015
+int id iv_bg_yellow 0x7f050016
+int id iv_bg_yellow_select 0x7f050017
+int id iv_large_select 0x7f050018
+int id iv_medium_select 0x7f050019
+int id iv_small_select 0x7f05001a
+int id iv_super_select 0x7f05001b
+int id ll_font_large 0x7f05001c
+int id ll_font_normal 0x7f05001d
+int id ll_font_small 0x7f05001e
+int id ll_font_super 0x7f05001f
+int id menu_alert 0x7f050020
+int id menu_delete 0x7f050021
+int id menu_delete_remind 0x7f050022
+int id menu_export_text 0x7f050023
+int id menu_font_size 0x7f050024
+int id menu_list_mode 0x7f050025
+int id menu_new_folder 0x7f050026
+int id menu_new_note 0x7f050027
+int id menu_search 0x7f050028
+int id menu_send_to_desktop 0x7f050029
+int id menu_setting 0x7f05002a
+int id menu_share 0x7f05002b
+int id menu_sync 0x7f05002c
+int id minute 0x7f05002d
+int id move 0x7f05002e
+int id navigation_bar 0x7f05002f
+int id note_bg_color_selector 0x7f050030
+int id note_edit_list 0x7f050031
+int id note_edit_view 0x7f050032
+int id note_item 0x7f050033
+int id note_title 0x7f050034
+int id notes_list 0x7f050035
+int id prefenerece_sync_status_textview 0x7f050036
+int id preference_sync_button 0x7f050037
+int id selection_menu 0x7f050038
+int id sv_note_edit 0x7f050039
+int id tv_alert_date 0x7f05003a
+int id tv_folder_name 0x7f05003b
+int id tv_modified_date 0x7f05003c
+int id tv_name 0x7f05003d
+int id tv_time 0x7f05003e
+int id tv_title 0x7f05003f
+int id tv_title_bar 0x7f050040
+int id widget_bg_image 0x7f050041
+int id widget_text 0x7f050042
+int layout account_dialog_title 0x7f060000
+int layout add_account_text 0x7f060001
+int layout datetime_picker 0x7f060002
+int layout dialog_edit_text 0x7f060003
+int layout folder_list_item 0x7f060004
+int layout note_edit 0x7f060005
+int layout note_edit_list_item 0x7f060006
+int layout note_item 0x7f060007
+int layout note_list 0x7f060008
+int layout note_list_dropdown_menu 0x7f060009
+int layout note_list_footer 0x7f06000a
+int layout settings_header 0x7f06000b
+int layout widget_2x 0x7f06000c
+int layout widget_4x 0x7f06000d
+int menu call_note_edit 0x7f070000
+int menu call_record_folder 0x7f070001
+int menu note_edit 0x7f070002
+int menu note_list 0x7f070003
+int menu note_list_dropdown 0x7f070004
+int menu note_list_options 0x7f070005
+int menu sub_folder 0x7f070006
+int plurals search_results_title 0x7f080000
+int raw introduction 0x7f090000
+int string alert_message_delete_folder 0x7f0a0000
+int string alert_message_delete_note 0x7f0a0001
+int string alert_message_delete_notes 0x7f0a0002
+int string alert_title_delete 0x7f0a0003
+int string app_name 0x7f0a0004
+int string app_widget2x2 0x7f0a0005
+int string app_widget4x4 0x7f0a0006
+int string button_delete 0x7f0a0007
+int string call_record_folder_name 0x7f0a0008
+int string datetime_dialog_cancel 0x7f0a0009
+int string datetime_dialog_ok 0x7f0a000a
+int string delete_remind_time_message 0x7f0a000b
+int string error_note_empty_for_clock 0x7f0a000c
+int string error_note_empty_for_send_to_desktop 0x7f0a000d
+int string error_note_not_exist 0x7f0a000e
+int string error_sdcard_export 0x7f0a000f
+int string error_sdcard_unmounted 0x7f0a0010
+int string error_sync_cancelled 0x7f0a0011
+int string error_sync_internal 0x7f0a0012
+int string error_sync_network 0x7f0a0013
+int string failed_sdcard_export 0x7f0a0014
+int string file_name_txt_format 0x7f0a0015
+int string file_path 0x7f0a0016
+int string folder_exist 0x7f0a0017
+int string format_date_ymd 0x7f0a0018
+int string format_datetime_mdhm 0x7f0a0019
+int string format_exported_file_location 0x7f0a001a
+int string format_folder_files_count 0x7f0a001b
+int string format_move_notes_to_folder 0x7f0a001c
+int string hint_foler_name 0x7f0a001d
+int string info_note_enter_desktop 0x7f0a001e
+int string menu_alert 0x7f0a001f
+int string menu_create_folder 0x7f0a0020
+int string menu_delete 0x7f0a0021
+int string menu_deselect_all 0x7f0a0022
+int string menu_export_text 0x7f0a0023
+int string menu_folder_change_name 0x7f0a0024
+int string menu_folder_delete 0x7f0a0025
+int string menu_folder_view 0x7f0a0026
+int string menu_font_large 0x7f0a0027
+int string menu_font_normal 0x7f0a0028
+int string menu_font_size 0x7f0a0029
+int string menu_font_small 0x7f0a002a
+int string menu_font_super 0x7f0a002b
+int string menu_list_mode 0x7f0a002c
+int string menu_move 0x7f0a002d
+int string menu_move_parent_folder 0x7f0a002e
+int string menu_normal_mode 0x7f0a002f
+int string menu_remove_remind 0x7f0a0030
+int string menu_search 0x7f0a0031
+int string menu_select_all 0x7f0a0032
+int string menu_select_none 0x7f0a0033
+int string menu_select_title 0x7f0a0034
+int string menu_send_to_desktop 0x7f0a0035
+int string menu_setting 0x7f0a0036
+int string menu_share 0x7f0a0037
+int string menu_sync 0x7f0a0038
+int string menu_sync_cancel 0x7f0a0039
+int string menu_title_select_folder 0x7f0a003a
+int string note_alert_expired 0x7f0a003b
+int string note_link_email 0x7f0a003c
+int string note_link_other 0x7f0a003d
+int string note_link_tel 0x7f0a003e
+int string note_link_web 0x7f0a003f
+int string notealert_enter 0x7f0a0040
+int string notealert_ok 0x7f0a0041
+int string notelist_menu_new 0x7f0a0042
+int string notelist_string_info 0x7f0a0043
+int string preferences_account_summary 0x7f0a0044
+int string preferences_account_title 0x7f0a0045
+int string preferences_add_account 0x7f0a0046
+int string preferences_bg_random_appear_title 0x7f0a0047
+int string preferences_button_sync_cancel 0x7f0a0048
+int string preferences_button_sync_immediately 0x7f0a0049
+int string preferences_dialog_change_account_title 0x7f0a004a
+int string preferences_dialog_change_account_warn_msg 0x7f0a004b
+int string preferences_dialog_select_account_tips 0x7f0a004c
+int string preferences_dialog_select_account_title 0x7f0a004d
+int string preferences_last_sync_time 0x7f0a004e
+int string preferences_last_sync_time_format 0x7f0a004f
+int string preferences_menu_cancel 0x7f0a0050
+int string preferences_menu_change_account 0x7f0a0051
+int string preferences_menu_remove_account 0x7f0a0052
+int string preferences_title 0x7f0a0053
+int string preferences_toast_cannot_change_account 0x7f0a0054
+int string preferences_toast_success_set_accout 0x7f0a0055
+int string search 0x7f0a0056
+int string search_hint 0x7f0a0057
+int string search_label 0x7f0a0058
+int string search_setting_description 0x7f0a0059
+int string set_remind_time_message 0x7f0a005a
+int string success_sdcard_export 0x7f0a005b
+int string success_sync_account 0x7f0a005c
+int string sync_progress_init_list 0x7f0a005d
+int string sync_progress_login 0x7f0a005e
+int string sync_progress_syncing 0x7f0a005f
+int string ticker_cancel 0x7f0a0060
+int string ticker_fail 0x7f0a0061
+int string ticker_success 0x7f0a0062
+int string ticker_syncing 0x7f0a0063
+int string widget_havenot_content 0x7f0a0064
+int string widget_under_visit_mode 0x7f0a0065
+int style HighlightTextAppearancePrimary 0x7f0b0000
+int style HighlightTextAppearanceSecondary 0x7f0b0001
+int style NoteActionBarStyle 0x7f0b0002
+int style NoteTheme 0x7f0b0003
+int style TextAppearanceLarge 0x7f0b0004
+int style TextAppearanceMedium 0x7f0b0005
+int style TextAppearanceNormal 0x7f0b0006
+int style TextAppearancePrimaryItem 0x7f0b0007
+int style TextAppearanceSecondaryItem 0x7f0b0008
+int style TextAppearanceSuper 0x7f0b0009
+int style TextAppearanceUnderMenuIcon 0x7f0b000a
+int xml preferences 0x7f0c0000
+int xml searchable 0x7f0c0001
+int xml widget_2x_info 0x7f0c0002
+int xml widget_4x_info 0x7f0c0003
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/BuildConfig.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/BuildConfig.dex
new file mode 100644
index 0000000..137bc6f
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/BuildConfig.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$array.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$array.dex
new file mode 100644
index 0000000..72cfb2c
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$array.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$color.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$color.dex
new file mode 100644
index 0000000..8b267e0
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$color.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$dimen.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$dimen.dex
new file mode 100644
index 0000000..c2a324d
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$dimen.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$drawable.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$drawable.dex
new file mode 100644
index 0000000..23230d4
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$drawable.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$id.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$id.dex
new file mode 100644
index 0000000..2e0dd35
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$id.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$layout.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$layout.dex
new file mode 100644
index 0000000..d98689a
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$layout.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$menu.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$menu.dex
new file mode 100644
index 0000000..e5e7b04
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$menu.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$plurals.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$plurals.dex
new file mode 100644
index 0000000..538a89c
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$plurals.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$raw.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$raw.dex
new file mode 100644
index 0000000..a6b853b
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$raw.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$string.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$string.dex
new file mode 100644
index 0000000..110ceda
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$string.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$style.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$style.dex
new file mode 100644
index 0000000..3516b56
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$style.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$xml.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$xml.dex
new file mode 100644
index 0000000..4267965
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R$xml.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R.dex
new file mode 100644
index 0000000..10d07b2
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/R.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Contact.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Contact.dex
new file mode 100644
index 0000000..c49f43e
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Contact.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Notes$CallNote.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Notes$CallNote.dex
new file mode 100644
index 0000000..772a9ef
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Notes$CallNote.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Notes$DataColumns.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Notes$DataColumns.dex
new file mode 100644
index 0000000..d187917
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Notes$DataColumns.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Notes$DataConstants.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Notes$DataConstants.dex
new file mode 100644
index 0000000..e718373
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Notes$DataConstants.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Notes$NoteColumns.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Notes$NoteColumns.dex
new file mode 100644
index 0000000..1d64089
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Notes$NoteColumns.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Notes$TextNote.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Notes$TextNote.dex
new file mode 100644
index 0000000..ff55520
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Notes$TextNote.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Notes.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Notes.dex
new file mode 100644
index 0000000..4b393a2
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/Notes.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/NotesDatabaseHelper$TABLE.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/NotesDatabaseHelper$TABLE.dex
new file mode 100644
index 0000000..d321c25
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/NotesDatabaseHelper$TABLE.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/NotesDatabaseHelper.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/NotesDatabaseHelper.dex
new file mode 100644
index 0000000..707db62
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/NotesDatabaseHelper.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/NotesProvider.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/NotesProvider.dex
new file mode 100644
index 0000000..201fb60
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/data/NotesProvider.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/data/MetaData.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/data/MetaData.dex
new file mode 100644
index 0000000..c23e24c
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/data/MetaData.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/data/Node.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/data/Node.dex
new file mode 100644
index 0000000..33feba7
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/data/Node.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/data/SqlData.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/data/SqlData.dex
new file mode 100644
index 0000000..9e34de8
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/data/SqlData.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/data/SqlNote.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/data/SqlNote.dex
new file mode 100644
index 0000000..21f6114
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/data/SqlNote.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/data/Task.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/data/Task.dex
new file mode 100644
index 0000000..03891cf
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/data/Task.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/data/TaskList.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/data/TaskList.dex
new file mode 100644
index 0000000..24307ac
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/data/TaskList.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/exception/ActionFailureException.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/exception/ActionFailureException.dex
new file mode 100644
index 0000000..d2b901b
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/exception/ActionFailureException.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/exception/NetworkFailureException.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/exception/NetworkFailureException.dex
new file mode 100644
index 0000000..ad0eb1e
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/exception/NetworkFailureException.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskASyncTask$1.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskASyncTask$1.dex
new file mode 100644
index 0000000..cb53456
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskASyncTask$1.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.dex
new file mode 100644
index 0000000..5266a05
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskASyncTask$OnCompleteListener.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskASyncTask.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskASyncTask.dex
new file mode 100644
index 0000000..566bd91
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskASyncTask.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskClient.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskClient.dex
new file mode 100644
index 0000000..361cbb7
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskClient.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskManager.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskManager.dex
new file mode 100644
index 0000000..62734e4
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskManager.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskSyncService$1.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskSyncService$1.dex
new file mode 100644
index 0000000..a306a1d
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskSyncService$1.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskSyncService.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskSyncService.dex
new file mode 100644
index 0000000..9bc018d
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/gtask/remote/GTaskSyncService.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/model/Note$NoteData.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/model/Note$NoteData.dex
new file mode 100644
index 0000000..d8c83fd
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/model/Note$NoteData.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/model/Note.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/model/Note.dex
new file mode 100644
index 0000000..9e5b501
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/model/Note.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.dex
new file mode 100644
index 0000000..3d2def9
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/model/WorkingNote$NoteSettingChangedListener.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/model/WorkingNote.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/model/WorkingNote.dex
new file mode 100644
index 0000000..f8683a4
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/model/WorkingNote.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/BackupUtils$TextExport.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/BackupUtils$TextExport.dex
new file mode 100644
index 0000000..f20eb5f
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/BackupUtils$TextExport.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/BackupUtils.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/BackupUtils.dex
new file mode 100644
index 0000000..c79234f
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/BackupUtils.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/DataUtils.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/DataUtils.dex
new file mode 100644
index 0000000..bdfaa34
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/DataUtils.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/GTaskStringUtils.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/GTaskStringUtils.dex
new file mode 100644
index 0000000..b0a39d4
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/GTaskStringUtils.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/ResourceParser$NoteBgResources.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/ResourceParser$NoteBgResources.dex
new file mode 100644
index 0000000..23cdfe3
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/ResourceParser$NoteBgResources.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/ResourceParser$NoteItemBgResources.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/ResourceParser$NoteItemBgResources.dex
new file mode 100644
index 0000000..b9f9779
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/ResourceParser$NoteItemBgResources.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/ResourceParser$TextAppearanceResources.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/ResourceParser$TextAppearanceResources.dex
new file mode 100644
index 0000000..1775d7f
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/ResourceParser$TextAppearanceResources.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/ResourceParser$WidgetBgResources.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/ResourceParser$WidgetBgResources.dex
new file mode 100644
index 0000000..28f20f0
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/ResourceParser$WidgetBgResources.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/ResourceParser.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/ResourceParser.dex
new file mode 100644
index 0000000..67c17cb
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/tool/ResourceParser.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/AlarmAlertActivity.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/AlarmAlertActivity.dex
new file mode 100644
index 0000000..d380f44
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/AlarmAlertActivity.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/AlarmInitReceiver.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/AlarmInitReceiver.dex
new file mode 100644
index 0000000..9c10c7d
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/AlarmInitReceiver.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/AlarmReceiver.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/AlarmReceiver.dex
new file mode 100644
index 0000000..e9e16ab
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/AlarmReceiver.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePicker$1.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePicker$1.dex
new file mode 100644
index 0000000..c3ab146
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePicker$1.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePicker$2.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePicker$2.dex
new file mode 100644
index 0000000..1f4125f
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePicker$2.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePicker$3.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePicker$3.dex
new file mode 100644
index 0000000..c8fc2fb
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePicker$3.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePicker$4.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePicker$4.dex
new file mode 100644
index 0000000..092e0b1
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePicker$4.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.dex
new file mode 100644
index 0000000..7402c2e
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePicker$OnDateTimeChangedListener.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePicker.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePicker.dex
new file mode 100644
index 0000000..249c398
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePicker.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePickerDialog$1.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePickerDialog$1.dex
new file mode 100644
index 0000000..5f5520e
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePickerDialog$1.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.dex
new file mode 100644
index 0000000..72401da
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePickerDialog$OnDateTimeSetListener.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePickerDialog.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePickerDialog.dex
new file mode 100644
index 0000000..7cafa9d
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DateTimePickerDialog.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DropdownMenu$1.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DropdownMenu$1.dex
new file mode 100644
index 0000000..def5d26
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DropdownMenu$1.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DropdownMenu.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DropdownMenu.dex
new file mode 100644
index 0000000..1d31454
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/DropdownMenu.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/FoldersListAdapter$FolderListItem.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/FoldersListAdapter$FolderListItem.dex
new file mode 100644
index 0000000..cb8eeb1
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/FoldersListAdapter$FolderListItem.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/FoldersListAdapter.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/FoldersListAdapter.dex
new file mode 100644
index 0000000..3d2a3a8
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/FoldersListAdapter.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditActivity$1.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditActivity$1.dex
new file mode 100644
index 0000000..29552cc
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditActivity$1.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditActivity$2.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditActivity$2.dex
new file mode 100644
index 0000000..68e30c8
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditActivity$2.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditActivity$3.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditActivity$3.dex
new file mode 100644
index 0000000..e5959c3
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditActivity$3.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.dex
new file mode 100644
index 0000000..2be27a8
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditActivity$HeadViewHolder.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditActivity.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditActivity.dex
new file mode 100644
index 0000000..4022287
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditActivity.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditText$1.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditText$1.dex
new file mode 100644
index 0000000..5b3637a
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditText$1.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.dex
new file mode 100644
index 0000000..f5b7add
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditText$OnTextViewChangeListener.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditText.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditText.dex
new file mode 100644
index 0000000..73e9484
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteEditText.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteItemData.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteItemData.dex
new file mode 100644
index 0000000..dd2e79a
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NoteItemData.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$1.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$1.dex
new file mode 100644
index 0000000..1ca5c95
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$1.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$2.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$2.dex
new file mode 100644
index 0000000..177afcb
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$2.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$3.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$3.dex
new file mode 100644
index 0000000..c0bad0c
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$3.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$4.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$4.dex
new file mode 100644
index 0000000..1172983
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$4.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$5.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$5.dex
new file mode 100644
index 0000000..716d4f4
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$5.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$6.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$6.dex
new file mode 100644
index 0000000..0fe5fd0
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$6.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$7.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$7.dex
new file mode 100644
index 0000000..6e6c7ab
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$7.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$8.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$8.dex
new file mode 100644
index 0000000..28e3ec0
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$8.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$9.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$9.dex
new file mode 100644
index 0000000..dbb01b2
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$9.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.dex
new file mode 100644
index 0000000..4acfa8b
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$BackgroundQueryHandler.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$ListEditState.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$ListEditState.dex
new file mode 100644
index 0000000..d80075b
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$ListEditState.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$ModeCallback$1.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$ModeCallback$1.dex
new file mode 100644
index 0000000..9f450e8
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$ModeCallback$1.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$ModeCallback$2.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$ModeCallback$2.dex
new file mode 100644
index 0000000..d335a0c
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$ModeCallback$2.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$ModeCallback.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$ModeCallback.dex
new file mode 100644
index 0000000..b53c525
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$ModeCallback.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.dex
new file mode 100644
index 0000000..a9a486a
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$NewNoteOnTouchListener.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.dex
new file mode 100644
index 0000000..f093433
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity$OnListItemClickListener.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity.dex
new file mode 100644
index 0000000..612b400
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListActivity.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.dex
new file mode 100644
index 0000000..f5ba12e
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListAdapter$AppWidgetAttribute.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListAdapter.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListAdapter.dex
new file mode 100644
index 0000000..ac6b452
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListAdapter.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListItem.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListItem.dex
new file mode 100644
index 0000000..903b1c3
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesListItem.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$1.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$1.dex
new file mode 100644
index 0000000..c1461fa
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$1.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$2.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$2.dex
new file mode 100644
index 0000000..49a1276
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$2.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$3.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$3.dex
new file mode 100644
index 0000000..55c3c78
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$3.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$4.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$4.dex
new file mode 100644
index 0000000..6c2425d
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$4.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$5.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$5.dex
new file mode 100644
index 0000000..2a8724b
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$5.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$6.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$6.dex
new file mode 100644
index 0000000..1db6419
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$6.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$7.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$7.dex
new file mode 100644
index 0000000..cdcfce3
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$7.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$8.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$8.dex
new file mode 100644
index 0000000..c680a51
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$8.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.dex
new file mode 100644
index 0000000..cdf2e93
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity$GTaskReceiver.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity.dex
new file mode 100644
index 0000000..254114a
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/ui/NotesPreferenceActivity.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/widget/NoteWidgetProvider.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/widget/NoteWidgetProvider.dex
new file mode 100644
index 0000000..d960720
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/widget/NoteWidgetProvider.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/widget/NoteWidgetProvider_2x.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/widget/NoteWidgetProvider_2x.dex
new file mode 100644
index 0000000..ff7afa1
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/widget/NoteWidgetProvider_2x.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/widget/NoteWidgetProvider_4x.dex b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/widget/NoteWidgetProvider_4x.dex
new file mode 100644
index 0000000..d631607
Binary files /dev/null and b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/0/net/micode/notes/widget/NoteWidgetProvider_4x.dex differ
diff --git a/rnotes/app/build/intermediates/transforms/dexBuilder/debug/__content__.json b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/__content__.json
new file mode 100644
index 0000000..f066824
--- /dev/null
+++ b/rnotes/app/build/intermediates/transforms/dexBuilder/debug/__content__.json
@@ -0,0 +1 @@
+[{"name":"C:\\Users\\19440\\AndroidStudioProjects\\Notes\\app\\build\\intermediates\\javac\\debug\\classes","index":0,"scopes":["PROJECT"],"types":["DEX_ARCHIVE"],"format":"DIRECTORY","present":true}]
\ No newline at end of file
diff --git a/rnotes/app/build/outputs/apk/debug/app-debug.apk b/rnotes/app/build/outputs/apk/debug/app-debug.apk
new file mode 100644
index 0000000..927f4e9
Binary files /dev/null and b/rnotes/app/build/outputs/apk/debug/app-debug.apk differ
diff --git a/rnotes/app/build/outputs/apk/debug/output.json b/rnotes/app/build/outputs/apk/debug/output.json
new file mode 100644
index 0000000..07239e5
--- /dev/null
+++ b/rnotes/app/build/outputs/apk/debug/output.json
@@ -0,0 +1 @@
+[{"outputType":{"type":"APK"},"apkData":{"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/rnotes/app/build/outputs/logs/manifest-merger-debug-report.txt b/rnotes/app/build/outputs/logs/manifest-merger-debug-report.txt
new file mode 100644
index 0000000..8b89c57
--- /dev/null
+++ b/rnotes/app/build/outputs/logs/manifest-merger-debug-report.txt
@@ -0,0 +1,235 @@
+-- Merging decision tree log ---
+manifest
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:18:1-148:12
+INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:18:1-148:12
+INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:18:1-148:12
+INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:18:1-148:12
+INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:18:1-148:12
+INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:18:1-148:12
+INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:18:1-148:12
+ package
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:19:5-31
+ INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml
+ INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml
+ android:versionName
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:21:5-30
+ INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml
+ INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml
+ xmlns:android
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:18:11-69
+ android:versionCode
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:20:5-28
+ INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml
+ INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml
+uses-permission#android.permission.WRITE_EXTERNAL_STORAGE
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:23:5-81
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:23:22-78
+uses-permission#com.android.launcher.permission.INSTALL_SHORTCUT
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:24:5-88
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:24:22-85
+uses-permission#android.permission.INTERNET
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:25:5-67
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:25:22-64
+uses-permission#android.permission.READ_CONTACTS
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:26:5-72
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:26:22-69
+uses-permission#android.permission.MANAGE_ACCOUNTS
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:27:5-74
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:27:22-71
+uses-permission#android.permission.AUTHENTICATE_ACCOUNTS
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:28:5-80
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:28:22-77
+uses-permission#android.permission.GET_ACCOUNTS
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:29:5-71
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:29:22-68
+uses-permission#android.permission.USE_CREDENTIALS
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:30:5-74
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:30:22-71
+uses-permission#android.permission.RECEIVE_BOOT_COMPLETED
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:31:5-81
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:31:22-78
+application
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:33:5-147:19
+ android:label
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:35:9-41
+ android:icon
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:34:9-42
+activity#net.micode.notes.ui.NotesListActivity
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:36:9-49:20
+ android:label
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:39:13-45
+ android:launchMode
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:40:13-43
+ android:windowSoftInputMode
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:43:13-52
+ android:uiOptions
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:42:13-57
+ android:configChanges
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:38:13-74
+ android:theme
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:41:13-45
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:37:13-49
+intent-filter#action:name:android.intent.action.MAIN+category:name:android.intent.category.LAUNCHER
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:45:13-48:29
+action#android.intent.action.MAIN
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:46:17-69
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:46:25-66
+category#android.intent.category.LAUNCHER
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:47:17-77
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:47:27-74
+activity#net.micode.notes.ui.NoteEditActivity
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:51:9-79:20
+ android:launchMode
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:54:13-43
+ android:configChanges
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:53:13-74
+ android:theme
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:55:13-45
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:52: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 C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:57:13-62:29
+action#android.intent.action.VIEW
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:58:17-69
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:58:25-66
+category#android.intent.category.DEFAULT
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:59:17-76
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:59:27-73
+data
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:60:17-78
+ android:mimeType
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:60: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 C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:64:13-69:29
+action#android.intent.action.INSERT_OR_EDIT
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:65:17-79
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:65:25-76
+intent-filter#action:name:android.intent.action.SEARCH+category:name:android.intent.category.DEFAULT
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:71:13-74:29
+action#android.intent.action.SEARCH
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:72:17-71
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:72:25-68
+meta-data#android.app.searchable
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:76:13-78:54
+ android:resource
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:78:17-51
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:77:17-54
+provider#net.micode.notes.data.NotesProvider
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:81:9-84:43
+ android:authorities
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:83:13-47
+ android:multiprocess
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:84:13-40
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:82:13-63
+receiver#net.micode.notes.widget.NoteWidgetProvider_2x
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:86:9-98:20
+ android:label
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:88:13-50
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:87: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 C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:89:13-93:29
+action#android.appwidget.action.APPWIDGET_UPDATE
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:90:17-84
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:90:25-81
+action#android.appwidget.action.APPWIDGET_DELETED
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:91:17-85
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:91:25-82
+action#android.intent.action.PRIVACY_MODE_CHANGED
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:92:17-85
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:92:25-82
+meta-data#android.appwidget.provider
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:95:13-97:58
+ android:resource
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:97:17-55
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:96:17-58
+receiver#net.micode.notes.widget.NoteWidgetProvider_4x
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:99:9-112:20
+ android:label
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:101:13-50
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:100:13-57
+receiver#net.micode.notes.ui.AlarmInitReceiver
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:114:9-118:20
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:114:19-55
+intent-filter#action:name:android.intent.action.BOOT_COMPLETED
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:115:13-117:29
+action#android.intent.action.BOOT_COMPLETED
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:116:17-79
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:116:25-76
+receiver#net.micode.notes.ui.AlarmReceiver
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:120:9-123:20
+ android:process
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:122:13-38
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:121:13-61
+activity#net.micode.notes.ui.AlarmAlertActivity
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:125:9-130:20
+ android:label
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:127:13-45
+ android:launchMode
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:128:13-48
+ android:theme
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:129:13-75
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:126:13-50
+activity#net.micode.notes.ui.NotesPreferenceActivity
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:132:9-137:20
+ android:label
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:134:13-54
+ android:launchMode
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:135:13-43
+ android:theme
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:136:13-60
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:133:13-71
+service#net.micode.notes.gtask.remote.GTaskSyncService
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:139:9-142:19
+ android:exported
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:141:13-37
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:140:13-74
+meta-data#android.app.default_searchable
+ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:144:9-146:52
+ android:value
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:146:13-49
+ android:name
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml:145:13-58
+uses-sdk
+INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml reason: use-sdk injection requested
+INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml
+INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml
+INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml
+INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml
+ android:targetSdkVersion
+ INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml
+ INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml
+ android:minSdkVersion
+ INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml
+ ADDED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml
+ INJECTED from C:\Users\19440\AndroidStudioProjects\Notes\app\src\main\AndroidManifest.xml
diff --git a/rnotes/app/src/main/AndroidManifest.xml b/rnotes/app/src/main/AndroidManifest.xml
new file mode 100644
index 0000000..2b77297
--- /dev/null
+++ b/rnotes/app/src/main/AndroidManifest.xml
@@ -0,0 +1,148 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/rnotes/app/src/main/java/net/micode/notes/data/Contact.java b/rnotes/app/src/main/java/net/micode/notes/data/Contact.java
new file mode 100644
index 0000000..d97ac5d
--- /dev/null
+++ b/rnotes/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/rnotes/app/src/main/java/net/micode/notes/data/Notes.java b/rnotes/app/src/main/java/net/micode/notes/data/Notes.java
new file mode 100644
index 0000000..f240604
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/data/Notes.java
@@ -0,0 +1,279 @@
+/*
+ * 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 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/rnotes/app/src/main/java/net/micode/notes/data/NotesDatabaseHelper.java b/rnotes/app/src/main/java/net/micode/notes/data/NotesDatabaseHelper.java
new file mode 100644
index 0000000..ffe5d57
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/data/NotesDatabaseHelper.java
@@ -0,0 +1,362 @@
+/*
+ * 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 = "note.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" +
+ ")";
+
+ 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");
+ }
+}
diff --git a/rnotes/app/src/main/java/net/micode/notes/data/NotesProvider.java b/rnotes/app/src/main/java/net/micode/notes/data/NotesProvider.java
new file mode 100644
index 0000000..edb0a60
--- /dev/null
+++ b/rnotes/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/rnotes/app/src/main/java/net/micode/notes/gtask/data/MetaData.java b/rnotes/app/src/main/java/net/micode/notes/gtask/data/MetaData.java
new file mode 100644
index 0000000..a360db2
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/gtask/data/MetaData.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.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();
+ /*功能描述:调用getSimpleName()函数得到类的简写名称存入字符串TAG中*/
+ private String mRelatedGid = null;
+
+ public void setMeta(String gid, JSONObject metaInfo) {
+ /*设置数据---生成元数据库*/
+ /*调用JSONObject库函数put()以及Task类中的setNotes()和setName()函数*/
+ try {
+ metaInfo.put(GTaskStringUtils.META_HEAD_GTASK_ID, gid);
+ //将值放入metaInfo的jsonobject对象里面
+ } catch (JSONException e) {
+ Log.e(TAG, "failed to put related gid");
+ /*有异常,抛出错误信息*/
+ }
+ setNotes(metaInfo.toString());
+ setName(GTaskStringUtils.META_NOTE_NAME);
+ }
+
+ public String getRelatedGid() {
+ return mRelatedGid;
+ }
+ /*获取相关联的gid*/
+
+ @Override
+ public boolean isWorthSaving() {
+ return getNotes() != null;
+ }
+ /*判断当前数据是否为空,非空返回false*/
+
+ @Override
+ public void setContentByRemoteJSON(JSONObject js) {
+ /*通过远程JSON数据对象设置元数据内容*/
+ super.setContentByRemoteJSON(js);
+ if (getNotes() != null) {
+ try {
+ JSONObject metaInfo = new JSONObject(getNotes().trim());
+ /*新建一个JSONObject对象metaInfo*/
+ mRelatedGid = metaInfo.getString(GTaskStringUtils.META_HEAD_GTASK_ID);
+ /*调用getString()函数设置mRelatedGid*/
+ } catch (JSONException e) {
+ Log.w(TAG, "failed to get related gid");
+ mRelatedGid = null;
+ /*有异常,输出错误信息,mRelatedGid设置为空*/
+ }
+ }
+ }
+
+ @Override
+ public void setContentByLocalJSON(JSONObject js) {
+ // this function should not be called
+ throw new IllegalAccessError("MetaData:setContentByLocalJSON should not be called");
+ }
+ /*使用本地JSON对象设置元数据内容,但这个功能一般不会被使用,如果用到了,则会抛出异常*/
+
+ @Override
+ public JSONObject getLocalJSONFromContent() {
+ throw new IllegalAccessError("MetaData:getLocalJSONFromContent should not be called");
+ }
+ /*从元数据获取本地JSON对象,但这个功能一般不会被使用,如果用到了,则会抛出异常*/
+
+ @Override
+ public int getSyncAction(Cursor c) {
+ throw new IllegalAccessError("MetaData:getSyncAction should not be called");
+ }
+ /*获取同步动作状态但这个功能一般不会被使用,如果用到了,则会抛出异常*/
+}
diff --git a/rnotes/app/src/main/java/net/micode/notes/gtask/data/Node.java b/rnotes/app/src/main/java/net/micode/notes/gtask/data/Node.java
new file mode 100644
index 0000000..0a702c0
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/gtask/data/Node.java
@@ -0,0 +1,104 @@
+/*
+ * 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;//Gid
+
+ 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();
+ /*从目录获取本地JSON对象*/
+ 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/rnotes/app/src/main/java/net/micode/notes/gtask/data/SqlData.java b/rnotes/app/src/main/java/net/micode/notes/gtask/data/SqlData.java
new file mode 100644
index 0000000..cb2bb3b
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/gtask/data/SqlData.java
@@ -0,0 +1,203 @@
+/*
+ * 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();
+ /*得到类的简写名称放入字符串TAG中*/
+ private static final int INVALID_ID = -99999;
+ /*初始化INVALID_ID 为-9999*/
+ public static final String[] PROJECTION_DATA = new String[] {
+ DataColumns.ID, DataColumns.MIME_TYPE, DataColumns.CONTENT, DataColumns.DATA1,
+ DataColumns.DATA3
+ };
+ /*给PROJECTION_DATA 定义了五个变量*/
+
+ public static final int DATA_ID_COLUMN = 0;//ID在sql表中列的编号
+
+ public static final int DATA_MIME_TYPE_COLUMN = 1;//MIME_TYPE在sql表中列的编号
+
+ public static final int DATA_CONTENT_COLUMN = 2;//CONTENT在sql表中列的编号
+
+ public static final int DATA_CONTENT_DATA_1_COLUMN = 3;//DATA1在sql表中列的编号
+
+ public static final int DATA_CONTENT_DATA_3_COLUMN = 4;//DATA3在sql表中列的编号
+
+ private ContentResolver mContentResolver;//用于获取ContentProvider提供的数据
+
+ private boolean mIsCreate;//判断是否直接用content生成,是为true---79行
+
+ private long mDataId;
+
+ private String mDataMimeType;
+
+ private String mDataContent;
+
+ private long mDataContentData1;
+
+ private String mDataContentData3;
+
+ private ContentValues mDiffDataValues;
+ /*定义了几个变量*/
+
+ public SqlData(Context context) {
+ /*构造一个函数SqlData(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) {
+ /*构造一个函数SqlData(Context +变量,Cursor +变量),初始化数据*/
+ 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;
+ }
+ /*通过content直接创建的返回空*/
+
+ /*创建JSONObject对象,放入相关数据并返回*/
+ 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 {
+ /*不是通过content做的修改*/
+ if (mDiffDataValues.size() > 0) {
+ int result = 0;
+ if (!validateVersion) {/*没有日程显示,result为空*/
+ result = mContentResolver.update(ContentUris.withAppendedId(
+ Notes.CONTENT_DATA_URI, mDataId), mDiffDataValues, null, null);
+ } else {/*有日程显示,result来存放更新信息*/
+ 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) {/*result没有更新*/
+ Log.w(TAG, "there is no update. maybe user updates note when syncing");
+ }
+ }
+ }
+
+ mDiffDataValues.clear();//清除value
+ mIsCreate = false;//非content创建
+ }
+ /*获取当前id*/
+ public long getId() {
+ return mDataId;
+ }
+}
diff --git a/rnotes/app/src/main/java/net/micode/notes/gtask/data/SqlNote.java b/rnotes/app/src/main/java/net/micode/notes/gtask/data/SqlNote.java
new file mode 100644
index 0000000..0619d75
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/gtask/data/SqlNote.java
@@ -0,0 +1,527 @@
+/*
+ * 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.
+ */
+/*和SqlData是父子关系,是真正的数据库*/
+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();
+ /*得到类的简写名称存入TAG中*/
+ private static final int INVALID_ID = -99999;
+ /*初始化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
+ };/*给PROJECTION_NOTE 定义变量*/
+
+ /*设置了这17列的编号*/
+ 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;
+
+ /*定义了17个内部变量,12个可以直接content获取,5个需要new或者init(0)*/
+ 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) {
+ /*构造函数SqlNote(Content +变量)初始化所有变量*/
+ 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) {
+ /*构造函数SqlNote(Context +变量,Cursor +变量)初始化变量*/
+ 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) {
+ /*构造函数SqlNote(Context +变量,long +变量)初始化变量*/
+ 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) {
+ /*通过id从光标处加载数据*/
+ Cursor c = null;//光标初始为空
+ try {
+ c = mContentResolver.query(Notes.CONTENT_NOTE_URI, PROJECTION_NOTE, "(_id=?)",
+ new String[] {
+ String.valueOf(id)
+ }, null);
+ /*通过id获得对应的ContentResolver中的cursor*/
+ if (c != null) {/*有光标则移动到光标处,每次指向下一处,再加载光标*/
+ c.moveToNext();
+ loadFromCursor(c);
+ } else {/*没有光标则将NULL存入TAG*/
+ 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;//初始c为空
+ mDataList.clear();//清除数据表
+ try {
+ c = mContentResolver.query(Notes.CONTENT_DATA_URI, SqlData.PROJECTION_DATA,
+ "(note_id=?)", new String[] {
+ String.valueOf(mId)
+ }, null);
+ /*通过note_id获得对应的ContentResolver中的cursor*/
+ if (c != null) {/*有光标*/
+ if (c.getCount() == 0) {/*获取的Count为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 {/*没有光标则将NULL存入TAG*/
+ Log.w(TAG, "loadDataContent: cursor = null");
+ }
+ } finally {/*结束*/
+ if (c != null)
+ c.close();
+ }
+ }
+
+ public boolean setContent(JSONObject js) {
+ /*设置通过content机制下的用于共享的数据信息*/
+ try {
+ JSONObject note = js.getJSONObject(GTaskStringUtils.META_HEAD_NOTE);//定义一个note
+ if (note.getInt(NoteColumns.TYPE) == Notes.TYPE_SYSTEM) {
+ //从系统类型获取note行的类型(int)
+ Log.w(TAG, "cannot set system folder");//log日志信息的警告
+ } else if (note.getInt(NoteColumns.TYPE) == Notes.TYPE_FOLDER) {
+ //从文件夹类型获取note行的类型
+ // 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;/*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);
+ }
+ }/*设置所有的SqlData*/
+ } catch (JSONException e) {
+ /*抛出错误信息*/
+ Log.e(TAG, e.toString());
+ e.printStackTrace();
+ return false;
+ }
+ return true;
+ }
+
+ public JSONObject getContent() {
+ /*获取content机制提供的数据加载到note中*/
+ try {
+ JSONObject js = new JSONObject();
+
+ if (mIsCreate) {
+ /*非content创建时显示错误日志*/
+ 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型的数据*/
+ 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);
+ }/*设置父id*/
+
+ public void setGtaskId(String gid) {
+ mDiffNoteValues.put(NoteColumns.GTASK_ID, gid);
+ }/*设置GtaskId*/
+
+ public void setSyncId(long syncId) {
+ mDiffNoteValues.put(NoteColumns.SYNC_ID, syncId);
+ }/*设置同步Id*/
+
+ 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;
+ }/*判断是否为note类型*/
+
+ public void commit(boolean validateVersion) {
+ /*构造函数commit()将当前修改保存到数据库*/
+ if (mIsCreate) {
+ if (mId == INVALID_ID && mDiffNoteValues.containsKey(NoteColumns.ID)) {
+ mDiffNoteValues.remove(NoteColumns.ID);
+ }/*保存id*/
+
+ Uri uri = mContentResolver.insert(Notes.CONTENT_NOTE_URI, mDiffNoteValues);
+ try {
+ mId = Long.valueOf(uri.getPathSegments().get(1));//定义mid
+ } catch (NumberFormatException e) {
+ /*捕获数据超出异常*/
+ Log.e(TAG, "Get note id error :" + e.toString());
+ throw new ActionFailureException("create note failed");
+ }
+ if (mId == 0) {//mId=0抛出异常
+ throw new IllegalStateException("Create thread id failed");
+ }
+
+ if (mType == Notes.TYPE_NOTE) {
+ /*是note型,用数据库中的数据链表投入显示*/
+ for (SqlData sqlData : mDataList) {
+ sqlData.commit(mId, false, -1);
+ }
+ }
+ } else {/*不是note型*/
+ 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) {/*没有确认的视图,构造id字符串*/
+ result = mContentResolver.update(Notes.CONTENT_NOTE_URI, mDiffNoteValues, "("
+ + NoteColumns.ID + "=?)", new String[] {
+ String.valueOf(mId)
+ });
+ } else {/*有确认的视图,构造id字符串和视图*/
+ 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);
+ }
+ }/*投入note的mid,validateVersion, mVersion数据*/
+ }
+
+ // refresh local info
+ loadFromCursor(mId);//加载光标
+ if (mType == Notes.TYPE_NOTE)
+ loadDataContent();/*加载数据目录*/
+
+ mDiffNoteValues.clear();
+ mIsCreate = false;
+ /*初始化*/
+ }
+}
diff --git a/rnotes/app/src/main/java/net/micode/notes/gtask/data/Task.java b/rnotes/app/src/main/java/net/micode/notes/gtask/data/Task.java
new file mode 100644
index 0000000..d90746d
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/gtask/data/Task.java
@@ -0,0 +1,362 @@
+/*
+ * 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;//优先兄弟的Task指针
+
+ private TaskList mParent;//任务列表指针
+
+ public Task() {
+ /*构造函数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) {
+ /*通过远程JSON设置内容*/
+ 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) {
+ /*通过本地JSON获取内容*/
+ if (js == null || !js.has(GTaskStringUtils.META_HEAD_NOTE)
+ || !js.has(GTaskStringUtils.META_HEAD_DATA)) {
+ Log.w(TAG, "setContentByLocalJSON: nothing is avaiable");
+ }/*没有对象,未创建META_HEAD_NOTE或META_HEAD_DATA异常*/
+
+ 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;
+ }/*非note型错误日志*/
+
+ 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() {
+ /*通过content获取本地JSON*/
+ 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);//放入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;
+ }/*没有id信息,返回本地动作同步更新*/
+
+ // 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;
+ }/*设置note*/
+
+ 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/rnotes/app/src/main/java/net/micode/notes/gtask/data/TaskList.java b/rnotes/app/src/main/java/net/micode/notes/gtask/data/TaskList.java
new file mode 100644
index 0000000..0bd9f7d
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/gtask/data/TaskList.java
@@ -0,0 +1,358 @@
+/*
+ * 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 {
+ /*TaskList类*/
+ 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) {
+ /*远程JSON获取内容*/
+ 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) {
+ /*本地JSON获取内容*/
+ 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() {
+ /*从content获取本地JSON*/
+ 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);//把META_HEAD_NOTE放入floder
+
+ 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();
+ }/*获取mChildren的大小*/
+
+ 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) {
+ /*判断是否在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);/*add*/
+
+ // 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) {
+ /*判断将当前的Task移动到index的位置*/
+ if (index < 0 || index >= mChildren.size()) {
+ Log.e(TAG, "move child task: invalid index");
+ return false;
+ }/*越界错误*/
+
+ int pos = mChildren.indexOf(task);//pos存储地址
+ if (pos == -1) {
+ /*不存在那个地址--显示错误日志信息输出false*/
+ 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) {
+ /*通过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);
+ }/*返回指定的Task的index*/
+
+ public Task getChildTaskByIndex(int index) {
+ /*返回指定index的Task*/
+ if (index < 0 || index >= mChildren.size()) {
+ Log.e(TAG, "getTaskByIndex: invalid index");
+ return null;
+ }
+ return mChildren.get(index);
+ }
+
+ public Task getChilTaskByGid(String gid) {
+ /*返回指定Gid的Task*/
+ 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/rnotes/app/src/main/java/net/micode/notes/gtask/exception/ActionFailureException.java b/rnotes/app/src/main/java/net/micode/notes/gtask/exception/ActionFailureException.java
new file mode 100644
index 0000000..2af8969
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/gtask/exception/ActionFailureException.java
@@ -0,0 +1,36 @@
+/*
+ * 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;
+ //serialVersionUID作用是序列化时保持版本的兼容性,即在版本升级时反序列化仍保持对象的唯一性。
+
+ /*继承父类的实例*/
+ public ActionFailureException() {
+ super();
+ }
+
+ public ActionFailureException(String paramString) {
+ super(paramString);
+ }
+
+ public ActionFailureException(String paramString, Throwable paramThrowable) {
+ super(paramString, paramThrowable);
+ }
+}
\ No newline at end of file
diff --git a/rnotes/app/src/main/java/net/micode/notes/gtask/exception/NetworkFailureException.java b/rnotes/app/src/main/java/net/micode/notes/gtask/exception/NetworkFailureException.java
new file mode 100644
index 0000000..9e157a7
--- /dev/null
+++ b/rnotes/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/rnotes/app/src/main/java/net/micode/notes/gtask/remote/GTaskASyncTask.java b/rnotes/app/src/main/java/net/micode/notes/gtask/remote/GTaskASyncTask.java
new file mode 100644
index 0000000..f9e48d7
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/gtask/remote/GTaskASyncTask.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.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 {
+ /*实现GTask的异步操作*/
+
+ 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) {
+ /*GTask同步任务---设置各个变量的值*/
+ 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);
+ }
+*/
+ private void showNotification(int tickerId, String content) {
+ /*显示通知(当前状态)*/
+ PendingIntent pendingIntent;
+ if (tickerId != R.string.ticker_success) {
+ /*同步不成功,从content调用NotesPreferenceActivity的对象*/
+ pendingIntent = PendingIntent.getActivity(mContext, 0, new Intent(mContext,
+ NotesPreferenceActivity.class), 0);
+
+ } else {
+ /*同步成功,从content里调用NotesListActivity的对象*/
+ pendingIntent = PendingIntent.getActivity(mContext, 0, new Intent(mContext,
+ NotesListActivity.class), 0);
+ }
+
+ /*显示的内容*/
+ Notification.Builder builder = new Notification.Builder(mContext)
+ .setAutoCancel(true)
+ .setContentTitle(mContext.getString(R.string.app_name))
+ .setContentText(content)
+ .setContentIntent(pendingIntent)
+ .setWhen(System.currentTimeMillis())
+ .setOngoing(true);
+ Notification notification=builder.getNotification();
+ 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) {
+ //instanceof用来判断mContext是否是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() {//new一个thresd线程运行
+
+ public void run() {
+ mOnCompleteListener.onComplete();
+ }//完成一次操作
+ }).start();
+ }
+ }
+}
diff --git a/rnotes/app/src/main/java/net/micode/notes/gtask/remote/GTaskClient.java b/rnotes/app/src/main/java/net/micode/notes/gtask/remote/GTaskClient.java
new file mode 100644
index 0000000..5ea0116
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/gtask/remote/GTaskClient.java
@@ -0,0 +1,620 @@
+/*
+ * 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();
+
+ //URL 定位
+ 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;//客户实例为空
+
+ //default默认,系统设定值
+ 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;
+ }/*获取已经实例化的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
+ /*用谷歌官方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");//获取以"com.google"结尾的账户
+
+ if (accounts.length == 0) {
+ Log.e(TAG, "there is no available google account");
+ return null;
+ }/*账户长度为0,说明没有这个账户,空*/
+
+ String accountName = NotesPreferenceActivity.getSyncAccountName(activity);//同步获取账户名字
+ Account account = null;
+ for (Account a : accounts) {
+ /*遍历账户信息,寻找已经有记录,退出查询*/
+ if (a.name.equals(accountName)) {
+ account = a;
+ break;
+ }
+ }
+ if (account != null) {/*有这个账户,传给mAccount */
+ 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) {
+ /*无效数据,需要废除这个无效token,不能登录*/
+ 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) {
+ /*判断尝试登录GTask是否能够成功*/
+ 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) {
+ /*登录GTask*/
+ /*设置参数*/
+ int timeoutConnection = 10000;//超时连接
+ int timeoutSocket = 15000;//超时端口
+ HttpParams httpParameters = new BasicHttpParams();//基本HTTP参数
+ HttpConnectionParams.setConnectionTimeout(httpParameters, timeoutConnection);//设置连接超时时间
+ HttpConnectionParams.setSoTimeout(httpParameters, timeoutSocket);//设置值端口超时时间
+ mHttpClient = new DefaultHttpClient(httpParameters);//new一个HTTP客户端
+ BasicCookieStore localBasicCookieStore = new BasicCookieStore();//new一个本地cookie库
+ mHttpClient.setCookieStore(localBasicCookieStore);//设置本地cookie库
+ HttpProtocolParams.setUseExpectContinue(mHttpClient.getParams(), false);//期望继续使用
+
+ // login gtask
+ try {
+ String loginUrl = mGetUrl + "?auth=" + authToken;//设置登录url
+ 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) {/*遍历cookies,如果包含GTL,则说明存在*/
+ if (cookie.getName().contains("GTL")) {
+ hasAuthCookie = true;
+ }
+ }
+ if (!hasAuthCookie) {//无auth cookie
+ 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++;
+ }/*获取动作id*/
+
+ 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) {
+ /*通过url得到的HttpEntity对象非空,创建*/
+ contentEncoding = entity.getContentEncoding().getValue();
+ Log.d(TAG, "encoding: " + contentEncoding);
+ }
+
+ InputStream input = entity.getContent();//输入
+ if (contentEncoding != null && contentEncoding.equalsIgnoreCase("gzip")) {
+ input = new GZIPInputStream(entity.getContent());//有内容编码并且不是gzip
+ } 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 {
+ /*通过JSON发送请求*/
+ if (!mLoggedin) {//未登录
+ Log.e(TAG, "please login first");
+ throw new ActionFailureException("not logged in");
+ }
+
+ HttpPost httpPost = createHttpPost();//创建HTTP发送数据的对象
+ 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
+ /*执行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) {
+ //cur光标资源文件
+ // 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());
+ }//兄弟优先id
+ 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);//通过GetURI使用getResponseContent从网上获取实体数据
+ 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);
+ }/*给jsString写入数据*/
+ JSONObject js = new JSONObject(jsString);
+ return js.getJSONObject("t").getJSONArray(GTaskStringUtils.GTASK_JSON_LISTS);//获取GTASK_JSON_LISTS的t列
+ } 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 {
+ /*通过Gid获取任务列表*/
+ 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/rnotes/app/src/main/java/net/micode/notes/gtask/remote/GTaskManager.java b/rnotes/app/src/main/java/net/micode/notes/gtask/remote/GTaskManager.java
new file mode 100644
index 0000000..58a6770
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/gtask/remote/GTaskManager.java
@@ -0,0 +1,820 @@
+/*
+ * 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;
+ //<>代表Java的泛型,就是创建一个用类型作为参数的类。
+
+ private GTaskManager() {
+ /*任务管理初始化*/
+ mSyncing = false;//正在同步,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() {//可能运行在多线程环境下,使用语言级同步--synchronized
+ /*类初始化函数*/
+ 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 {
+ /*初始化GTaskList*/
+ 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);//通过远程JSON设置内容
+
+ // 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();//继承自node
+ metaData.setContentByRemoteJSON(object);
+ if (metaData.isWorthSaving()) {/*元数据值得保存,加入子任务*/
+ mMetaList.addChildTask(metaData);
+ if (metaData.getGid() != null) {/*没有gid,把关联gid放入*/
+ 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);
+ //通过getString函数传入本地某个标志数据的名称,获取其在远端的名称
+ 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);//通过远端JSON设置内容
+ mGTaskListHashMap.put(gid, tasklist);//GTaskList放入gid, tasklist
+ mGTaskHashMap.put(gid, tasklist);//GTask放入gid, tasklist
+
+ // load tasks
+ JSONArray jsTasks = client.getTaskList(gid);//客户端获取任务表
+ for (int j = 0; j < jsTasks.length(); j++) {
+ object = (JSONObject) jsTasks.getJSONObject(j);//获取任务表里面的JSONObject
+ gid = object.getString(GTaskStringUtils.GTASK_JSON_ID);//GTASK_JSON_ID
+ Task task = new Task();
+ task.setContentByRemoteJSON(object);//new一个task,通过远端JSON设置内容
+ 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();//调用本地删除id函数
+
+ if (mCancelled) {
+ return;
+ }/*已经取消,直接退出*/
+
+ // for local deleted note(本地删除的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);//系统类型,容错id垃圾桶
+ /*处理内容---*/
+ if (c != null) {//内容非空
+ while (c.moveToNext()) {//转到下一条
+ gid = c.getString(SqlNote.GTASK_ID_COLUMN);
+ node = mGTaskHashMap.get(gid);
+ if (node != null) {//结点非空
+ mGTaskHashMap.remove(gid);//移动gid
+ doContentSync(Node.SYNC_ACTION_DEL_REMOTE, node, c);//内容同步
+ }
+
+ mLocalDeleteIdMap.add(c.getLong(SqlNote.ID_COLUMN));//增加ID_COLUMN到LocalDeleteIdMap
+ }
+ } else {
+ Log.w(TAG, "failed to query trash folder");
+ }
+ } finally {/*非空,关闭初始化为null*/
+ if (c != null) {
+ c.close();
+ c = null;
+ }
+ }
+
+ // sync folder first
+ syncFolder();
+
+ // for note existing in database(存在于基本数据里的note)
+ 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();//遍历map
+ 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();//刷新本地同步id
+ }
+
+ }
+
+ 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) {//能够得到SqlNote的GTASK_ID_COLUMN
+ mGTaskHashMap.remove(gid);//移动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(呼叫note文件夹)
+ 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);//移除得到的key的值
+ 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) {/*同步类型---9种情况*/
+ 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));//获取GTASK_ID_COLUMN)
+ if (meta != null) {
+ GTaskClient.getInstance().deleteNode(meta);//删除
+ }
+ mLocalDeleteIdMap.add(c.getLong(SqlNote.ID_COLUMN));//在本地删除增加ID_COLUMN)
+ break;
+ case Node.SYNC_ACTION_DEL_REMOTE://删除远端同步行为
+ meta = mMetaHashMap.get(node.getGid());//通过gid获取
+ if (meta != null) {
+ GTaskClient.getInstance().deleteNode(meta);//客户端删除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 {
+ /*增加本地Node操作*/
+ if (mCancelled) {/*取消则退出*/
+ return;
+ }
+
+ SqlNote sqlNote;
+ if (node instanceof TaskList) {//node是TaskList的实例
+ if (node.getName().equals(
+ GTaskStringUtils.MIUI_FOLDER_PREFFIX + GTaskStringUtils.FOLDER_DEFAULT)) {
+ sqlNote = new SqlNote(mContext, Notes.ID_ROOT_FOLDER);/*不规范文件夹,新的根文件夹id*/
+ } else if (node.getName().equals(
+ GTaskStringUtils.MIUI_FOLDER_PREFFIX + GTaskStringUtils.FOLDER_CALL_NOTE)) {
+ sqlNote = new SqlNote(mContext, Notes.ID_CALL_RECORD_FOLDER);/*呼叫note文件夹,呼叫远端文件夹id*/
+ } else {
+ sqlNote = new SqlNote(mContext);
+ sqlNote.setContent(node.getLocalJSONFromContent());//从content直接获取本地JSON来设置sqlnote的内容
+ sqlNote.setParentId(Notes.ID_ROOT_FOLDER);//从根文件夹id设置父id
+ }
+ } else {
+ sqlNote = new SqlNote(mContext);
+ JSONObject js = node.getLocalJSONFromContent();//从content直接获取本地JSON
+ try {
+ if (js.has(GTaskStringUtils.META_HEAD_NOTE)) {//js有META_HEAD_NOTE
+ JSONObject note = js.getJSONObject(GTaskStringUtils.META_HEAD_NOTE);
+ if (note.has(NoteColumns.ID)) {//NoteColumns.ID存在
+ long id = note.getLong(NoteColumns.ID);//定义id并且获取
+ if (DataUtils.existInNoteDatabase(mContentResolver, id)) {
+ // the id is not available, have to create a new one
+ note.remove(NoteColumns.ID);/*基础数据里面已经存在,则需要移除NoteColumns.ID*/
+ }
+ }
+ }
+
+ if (js.has(GTaskStringUtils.META_HEAD_DATA)) {//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)) {//DataColumns.ID已经存在
+ long dataId = data.getLong(DataColumns.ID);//定义dataId并给值
+ if (DataUtils.existInDataDatabase(mContentResolver, dataId)) {
+ // the data id is not available, have to create
+ // a new one
+ data.remove(DataColumns.ID);/*基础数据里面已经存在,则需要移除DataColumns.ID*/
+ }
+ }
+ }
+
+ }
+ } catch (JSONException e) {
+ Log.w(TAG, e.toString());
+ e.printStackTrace();
+ }/*json异常*/
+ sqlNote.setContent(js);
+
+ Long parentId = mGidToNid.get(((Task) node).getParent().getGid());//父id
+ if (parentId == null) {//没有---抛出异常
+ Log.e(TAG, "cannot find task's parent id locally");
+ throw new ActionFailureException("cannot add local node");
+ }
+ sqlNote.setParentId(parentId.longValue());//通过parentId.longValue()设置父id
+ }
+
+ // create the local node
+ sqlNote.setGtaskId(node.getGid());//通过gid设置GTask的id
+ sqlNote.commit(false);//在sqlNote保存false(commit到本地数据库)
+
+ // update gid-nid mapping(更新gid和nid之间的映射)
+ 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);//从本地context获取内容
+ sqlNote.setContent(node.getLocalJSONFromContent());//从content之间获取本地JSON,设一个content
+
+ Long parentId = (node instanceof Task) ? mGidToNid.get(((Task) node).getParent().getGid())
+ : new Long(Notes.ID_ROOT_FOLDER);
+ if (parentId == null) {/*没有父id*/
+ Log.e(TAG, "cannot find task's parent id locally");
+ throw new ActionFailureException("cannot update local node");
+ }
+ sqlNote.setParentId(parentId.longValue());//通过parentId.longValue()设置父id
+ sqlNote.commit(true);//在sqlNote保存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);//从本地context获取内容
+ Node n;//结点n
+
+ // update remotely
+ if (sqlNote.isNoteType()) {/*是note型*/
+ Task task = new Task();//new一个task
+ task.setContentByLocalJSON(sqlNote.getContent());//调用sqlNote.getContent()直接通过本地JSON设置content
+
+ String parentGid = mNidToGid.get(sqlNote.getParentId());//在nid到gid的映射获取父gid
+ if (parentGid == null) {//没有父gid
+ Log.e(TAG, "cannot find task's parent tasklist");
+ throw new ActionFailureException("cannot add remote task");
+ }
+ mGTaskListHashMap.get(parentGid).addChildTask(task);//在本地生成的GTask中增加子任务
+
+ GTaskClient.getInstance().createTask(task);//客户端登录远端服务器,创建任务
+ n = (Node) task;//给节点赋予task
+
+ // add meta
+ updateRemoteMeta(task.getGid(), sqlNote);//更新远端meta
+ } else {/*非node型*/
+ 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)) {/*有gid*/
+ mGTaskHashMap.remove(gid);//移除gid
+ }
+ break;
+ }
+ }
+
+ // no match we can add now(匹配不上,不能增加)
+ if (tasklist == null) {//任务表为空
+ tasklist = new TaskList();//new
+ tasklist.setContentByLocalJSON(sqlNote.getContent());//通过本地JSON设置content
+ GTaskClient.getInstance().createTaskList(tasklist);//客户端获取实例
+ mGTaskListHashMap.put(tasklist.getGid(), tasklist);//放入任务表
+ }
+ n = (Node) tasklist;//得到n
+ }
+
+ // update local note(更新本地note)
+ sqlNote.setGtaskId(n.getGid());//设置id
+ sqlNote.commit(false);//在sqlNote保存false
+ sqlNote.resetLocalModified();//重置本地修改
+ sqlNote.commit(true);//在sqlNote保存true
+
+ // gid-id mapping(gid与id的映射)
+ mGidToNid.put(n.getGid(), sqlNote.getId());
+ mNidToGid.put(sqlNote.getId(), n.getGid());
+ }
+
+ private void updateRemoteNode(Node node, Cursor c) throws NetworkFailureException {
+ /*更新远端node*/
+ if (mCancelled) {/*取消则退出*/
+ return;
+ }
+
+ SqlNote sqlNote = new SqlNote(mContext, c);//从本地context获取内容
+
+ // update remotely(远程更新)
+ node.setContentByLocalJSON(sqlNote.getContent());//通过本地JSON设置内容
+ GTaskClient.getInstance().addUpdateNode(node);//客户端增加更新结点
+
+ // update meta
+ updateRemoteMeta(node.getGid(), sqlNote);//更新远端meta
+
+ // move task if necessary(移动任务)
+ if (sqlNote.isNoteType()) {/*是note型*/
+ Task task = (Task) node;//定义一个任务并给定结点
+ TaskList preParentList = task.getParent();//通过node获得父节点列表
+
+ String curParentGid = mNidToGid.get(sqlNote.getParentId());//现在的父gid是从sqlnode里面获取的父id通过nid转为gid得到的
+ if (curParentGid == null) {//没有父gid
+ Log.e(TAG, "cannot find task's parent tasklist");
+ throw new ActionFailureException("cannot update remote task");
+ }
+ TaskList curParentList = mGTaskListHashMap.get(curParentGid);//通过hashmap找到对应gid的任务表
+
+ if (preParentList != curParentList) {//两个父任务表不一样
+ preParentList.removeChildTask(task);//前任务表移除子任务表
+ curParentList.addChildTask(task);//现在的父任务表添加子任务
+ GTaskClient.getInstance().moveTask(task, preParentList, curParentList);
+ }
+ }
+
+ // clear local modified flag(清理本地修改后的标志)
+ sqlNote.resetLocalModified();//重置本地修改
+ sqlNote.commit(true);//在sqlNote保存true
+ }
+
+ private void updateRemoteMeta(String gid, SqlNote sqlNote) throws NetworkFailureException {
+ /*更新远端meta*/
+ if (sqlNote != null && sqlNote.isNoteType()) {/*存在note型的sqlnote*/
+ MetaData metaData = mMetaHashMap.get(gid);//通过MetaHashMap获取gid给metaData
+ if (metaData != null) {//有元数据
+ metaData.setMeta(gid, sqlNote.getContent());//设置meta
+ GTaskClient.getInstance().addUpdateNode(metaData);//客户端增加更新结点
+ } else {//没有元数据
+ metaData = new MetaData();//new一个
+ metaData.setMeta(gid, sqlNote.getContent());//设置Meta
+ mMetaList.addChildTask(metaData);//在元表增加子任务
+ mMetaHashMap.put(gid, metaData);//把gid给metaData
+ GTaskClient.getInstance().createTask(metaData);//客户端创建任务
+ }
+ }
+ }
+
+ private void refreshLocalSyncId() throws NetworkFailureException {
+ /*刷新本地同步id*/
+ if (mCancelled) {/*取消则退出*/
+ return;
+ }
+
+ // get the latest gtask list(获取最新的gtask列表)
+ mGTaskHashMap.clear();//清除GTaskHashMap及里面的内容
+ mGTaskListHashMap.clear();//清除GTaskListHashMap及里面的内容
+ mMetaHashMap.clear();//清除MetaHashMap及里面的内容
+ initGTaskList();//初始化GTask列表
+
+ 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);//从GTASK_ID_COLUMN获取的gid
+ Node node = mGTaskHashMap.get(gid);//从GTaskHashMap获取gid赋予node
+ if (node != null) {/*有结点*/
+ mGTaskHashMap.remove(gid);//在mGTaskHashMap里面移动gid
+ ContentValues values = new ContentValues();//new一个值
+ values.put(NoteColumns.SYNC_ID, node.getLastModified());//将获取的最新修改点放入同步id
+ mContentResolver.update(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI,
+ c.getLong(SqlNote.ID_COLUMN)), values, null, null);//update
+ } else {/*有结点--显示错误信息有所遗漏--抛出异常本地条目在同步后没有gid*/
+ Log.e(TAG, "something is missed");
+ throw new ActionFailureException(
+ "some local items don't have gid after sync");
+ }
+ }
+ } else {/*未查询到本地note以刷新同步id*/
+ 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;
+ }/*取消同步---将mCancelled 置为true*/
+}
diff --git a/rnotes/app/src/main/java/net/micode/notes/gtask/remote/GTaskSyncService.java b/rnotes/app/src/main/java/net/micode/notes/gtask/remote/GTaskSyncService.java
new file mode 100644
index 0000000..2a044b4
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/gtask/remote/GTaskSyncService.java
@@ -0,0 +1,144 @@
+/*
+ * 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 {//* Service是在一段不定的时间运行在后台,不和用户交互的应用组件
+ /*GTask同步服务*/
+ /*定义变量及其信号值*/
+ 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) {
+ /*启动命令(重启service)*/
+ Bundle bundle = intent.getExtras();
+ if (bundle != null && bundle.containsKey(ACTION_STRING_NAME)) {//有bundle并且包含关键名
+ 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;//返回开始信号,等待新的intent使这个service继续运行
+ }
+ return super.onStartCommand(intent, flags, startId);//super调用
+ }
+
+ @Override
+ public void onLowMemory() {
+ /*在没有内存的情况下如果存在service则结束掉这的service*/
+ if (mSyncTask != null) {
+ mSyncTask.cancelSync();
+ }
+ }
+
+ public IBinder onBind(Intent intent) {
+ /*绑定service时被调用*/
+ return null;
+ }
+
+ public void sendBroadcast(String msg) {
+ /*发布同步通知*/
+ mSyncProgress = msg;
+ Intent intent = new Intent(GTASK_SERVICE_BROADCAST_NAME);//new一个组件,通过组件来响应
+ /*放入附加参数值*/
+ 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);//new一个组件,通过组件来响应
+ 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/rnotes/app/src/main/java/net/micode/notes/model/Note.java b/rnotes/app/src/main/java/net/micode/notes/model/Note.java
new file mode 100644
index 0000000..6706cf6
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/model/Note.java
@@ -0,0 +1,253 @@
+/*
+ * 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;
+ 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, 1);
+ values.put(NoteColumns.PARENT_ID, folderId);
+ Uri uri = context.getContentResolver().insert(Notes.CONTENT_NOTE_URI, values);
+
+ long noteId = 0;
+ try {
+ noteId = Long.valueOf(uri.getPathSegments().get(1));
+ } catch (NumberFormatException e) {
+ Log.e(TAG, "Get note id error :" + e.toString());
+ noteId = 0;
+ }
+ if (noteId == -1) {
+ 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/rnotes/app/src/main/java/net/micode/notes/model/WorkingNote.java b/rnotes/app/src/main/java/net/micode/notes/model/WorkingNote.java
new file mode 100644
index 0000000..be081e4
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/model/WorkingNote.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.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 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
+ };
+
+ 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;
+
+ // 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;
+ }
+
+ // Existing note construct
+ private WorkingNote(Context context, long noteId, long folderId) {
+ mContext = context;
+ mNoteId = noteId;
+ mFolderId = folderId;
+ mIsDeleted = false;
+ mNote = new Note();
+ loadNote();
+ }
+
+ 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);
+ }
+ cursor.close();
+ } else {
+ Log.e(TAG, "No note with id:" + mNoteId);
+ throw new IllegalArgumentException("Unable to find note with id " + mNoteId);
+ }
+ loadNoteData();
+ }
+
+ 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;
+ }
+
+ 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 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/rnotes/app/src/main/java/net/micode/notes/tool/BackupUtils.java b/rnotes/app/src/main/java/net/micode/notes/tool/BackupUtils.java
new file mode 100644
index 0000000..39f6ec4
--- /dev/null
+++ b/rnotes/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/rnotes/app/src/main/java/net/micode/notes/tool/DataUtils.java b/rnotes/app/src/main/java/net/micode/notes/tool/DataUtils.java
new file mode 100644
index 0000000..2a14982
--- /dev/null
+++ b/rnotes/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/rnotes/app/src/main/java/net/micode/notes/tool/GTaskStringUtils.java b/rnotes/app/src/main/java/net/micode/notes/tool/GTaskStringUtils.java
new file mode 100644
index 0000000..666b729
--- /dev/null
+++ b/rnotes/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/rnotes/app/src/main/java/net/micode/notes/tool/ResourceParser.java b/rnotes/app/src/main/java/net/micode/notes/tool/ResourceParser.java
new file mode 100644
index 0000000..1ad3ad6
--- /dev/null
+++ b/rnotes/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/rnotes/app/src/main/java/net/micode/notes/ui/AlarmAlertActivity.java b/rnotes/app/src/main/java/net/micode/notes/ui/AlarmAlertActivity.java
new file mode 100644
index 0000000..85723be
--- /dev/null
+++ b/rnotes/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/rnotes/app/src/main/java/net/micode/notes/ui/AlarmInitReceiver.java b/rnotes/app/src/main/java/net/micode/notes/ui/AlarmInitReceiver.java
new file mode 100644
index 0000000..f221202
--- /dev/null
+++ b/rnotes/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/rnotes/app/src/main/java/net/micode/notes/ui/AlarmReceiver.java b/rnotes/app/src/main/java/net/micode/notes/ui/AlarmReceiver.java
new file mode 100644
index 0000000..54e503b
--- /dev/null
+++ b/rnotes/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/rnotes/app/src/main/java/net/micode/notes/ui/DateTimePicker.java b/rnotes/app/src/main/java/net/micode/notes/ui/DateTimePicker.java
new file mode 100644
index 0000000..496b0cd
--- /dev/null
+++ b/rnotes/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/rnotes/app/src/main/java/net/micode/notes/ui/DateTimePickerDialog.java b/rnotes/app/src/main/java/net/micode/notes/ui/DateTimePickerDialog.java
new file mode 100644
index 0000000..2c47ba4
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/ui/DateTimePickerDialog.java
@@ -0,0 +1,90 @@
+/*
+ * 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();
+ private boolean mIs24HourView;
+ private OnDateTimeSetListener mOnDateTimeSetListener;
+ private DateTimePicker mDateTimePicker;
+
+ public interface OnDateTimeSetListener {
+ void OnDateTimeSet(AlertDialog dialog, long 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);
+ 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);
+ set24HourView(DateFormat.is24HourFormat(this.getContext()));
+ updateTitle(mDate.getTimeInMillis());
+ }
+
+ public void set24HourView(boolean is24HourView) {
+ mIs24HourView = is24HourView;
+ }
+
+ public void setOnDateTimeSetListener(OnDateTimeSetListener callBack) {
+ mOnDateTimeSetListener = callBack;
+ }
+
+ 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));
+ }
+
+ public void onClick(DialogInterface arg0, int arg1) {
+ if (mOnDateTimeSetListener != null) {
+ mOnDateTimeSetListener.OnDateTimeSet(this, mDate.getTimeInMillis());
+ }
+ }
+
+}
\ No newline at end of file
diff --git a/rnotes/app/src/main/java/net/micode/notes/ui/DropdownMenu.java b/rnotes/app/src/main/java/net/micode/notes/ui/DropdownMenu.java
new file mode 100644
index 0000000..613dc74
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/ui/DropdownMenu.java
@@ -0,0 +1,61 @@
+/*
+ * 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;
+
+ 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();
+ }
+ });
+ }
+
+ 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/rnotes/app/src/main/java/net/micode/notes/ui/FoldersListAdapter.java b/rnotes/app/src/main/java/net/micode/notes/ui/FoldersListAdapter.java
new file mode 100644
index 0000000..96b77da
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/ui/FoldersListAdapter.java
@@ -0,0 +1,80 @@
+/*
+ * 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;
+
+
+public class FoldersListAdapter extends CursorAdapter {
+ public static final String [] PROJECTION = {
+ NoteColumns.ID,
+ NoteColumns.SNIPPET
+ };
+
+ 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) {
+ 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;
+
+ 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/rnotes/app/src/main/java/net/micode/notes/ui/NoteEditActivity.java b/rnotes/app/src/main/java/net/micode/notes/ui/NoteEditActivity.java
new file mode 100644
index 0000000..96a9ff8
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/ui/NoteEditActivity.java
@@ -0,0 +1,873 @@
+/*
+ * 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.Spannable;
+import android.text.SpannableString;
+import android.text.TextUtils;
+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.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.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.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;
+
+
+public class NoteEditActivity extends Activity implements OnClickListener,
+ NoteSettingChangedListener, OnTextViewChangeListener {
+ private class HeadViewHolder {
+ public TextView tvModified;
+
+ public ImageView ivAlertIcon;
+
+ public TextView tvAlertDate;
+
+ public ImageView ibSetBgColor;
+ }
+
+ 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);
+ }
+
+ 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);
+ }
+
+ 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);
+ }
+
+ 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;
+ 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;
+
+ @Override
+ protected void onCreate(Bundle savedInstanceState) {
+ super.onCreate(savedInstanceState);
+ this.setContentView(R.layout.note_edit);
+
+ 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
+ */
+ @Override
+ protected void onRestoreInstanceState(Bundle savedInstanceState) {
+ super.onRestoreInstanceState(savedInstanceState);
+ 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");
+ }
+ }
+
+ 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;
+ if (TextUtils.equals(Intent.ACTION_VIEW, intent.getAction())) {
+ long noteId = intent.getLongExtra(Intent.EXTRA_UID, 0);
+ mUserQuery = "";
+
+ /**
+ * Starting from the searched result
+ */
+ if (intent.hasExtra(SearchManager.EXTRA_DATA_KEY)) {
+ noteId = Long.parseLong(intent.getStringExtra(SearchManager.EXTRA_DATA_KEY));
+ mUserQuery = intent.getStringExtra(SearchManager.USER_QUERY);
+ }
+
+ if (!DataUtils.visibleInNoteDatabase(getContentResolver(), noteId, Notes.TYPE_NOTE)) {
+ Intent jump = new Intent(this, NotesListActivity.class);
+ startActivity(jump);
+ showToast(R.string.error_note_not_exist);
+ finish();
+ return false;
+ } else {
+ 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;
+ 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 {
+ 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 {
+ Log.e(TAG, "Intent not specified action, should not support");
+ finish();
+ return false;
+ }
+ mWorkingNote.setOnSettingStatusChangedListener(this);
+ return true;
+ }
+
+ @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();
+ }
+
+ 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);
+ };
+ }
+
+ @Override
+ protected void onNewIntent(Intent intent) {
+ super.onNewIntent(intent);
+ initActivityState(intent);
+ }
+
+ @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
+ */
+ if (!mWorkingNote.existInDatabase()) {
+ saveNote();
+ }
+ outState.putLong(Intent.EXTRA_UID, mWorkingNote.getNoteId());
+ Log.d(TAG, "Save working note id: " + mWorkingNote.getNoteId() + " onSaveInstanceState");
+ }
+
+ @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);
+ }
+
+ 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);
+ }
+
+ @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 intent = new Intent(AppWidgetManager.ACTION_APPWIDGET_UPDATE);
+ 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.putExtra(AppWidgetManager.EXTRA_APPWIDGET_IDS, new int[] {
+ mWorkingNote.getWidgetId()
+ });
+
+ sendBroadcast(intent);
+ setResult(RESULT_OK, intent);
+ }
+
+ public void onClick(View v) {
+ int id = v.getId();
+ 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 = 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();
+ }
+
+ 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);
+ }
+ return true;
+ }
+
+ @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;
+ default:
+ break;
+ }
+ return true;
+ }
+
+ 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
+ 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();
+ 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);
+ }
+
+ private boolean isSyncMode() {
+ return NotesPreferenceActivity.getSyncAccountName(this).trim().length() > 0;
+ }
+
+ 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();
+ }
+ if (mWorkingNote.getNoteId() > 0) {
+ Intent intent = new Intent(this, AlarmReceiver.class);
+ intent.setData(ContentUris.withAppendedId(Notes.CONTENT_NOTE_URI, mWorkingNote.getNoteId()));
+ PendingIntent pendingIntent = PendingIntent.getBroadcast(this, 0, intent, 0);
+ AlarmManager alarmManager = ((AlarmManager) getSystemService(ALARM_SERVICE));
+ showAlertHeader();
+ 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();
+ }
+
+ public void onEditTextDelete(int index, String text) {
+ int childCount = mEditTextList.getChildCount();
+ if (childCount == 1) {
+ return;
+ }
+
+ 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;
+ 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);
+ }
+
+ 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);
+ for (int i = index + 1; i < mEditTextList.getChildCount(); i++) {
+ ((NoteEditText) mEditTextList.getChildAt(i).findViewById(R.id.et_edit_text))
+ .setIndex(i);
+ }
+ }
+
+ private void switchToListMode(String text) {
+ mEditTextList.removeAllViews();
+ 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);
+ }
+
+ private Spannable getHighlightQueryResult(String fullText, String userQuery) {
+ 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;
+ }
+
+ 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;
+ }
+
+ 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);
+ }
+ }
+
+ public void onCheckListModeChanged(int oldMode, int newMode) {
+ 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);
+ }
+ }
+
+ private boolean getWorkingText() {
+ boolean hasChecked = false;
+ if (mWorkingNote.getCheckListMode() == TextNote.MODE_CHECK_LIST) {
+ StringBuilder sb = new StringBuilder();
+ for (int i = 0; i < mEditTextList.getChildCount(); i++) {
+ View view = mEditTextList.getChildAt(i);
+ NoteEditText edit = (NoteEditText) view.findViewById(R.id.et_edit_text);
+ if (!TextUtils.isEmpty(edit.getText())) {
+ 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;
+ }
+
+ private boolean saveNote() {
+ getWorkingText();
+ 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();
+ }
+
+ if (mWorkingNote.getNoteId() > 0) {
+ Intent sender = new Intent();
+ Intent shortcutIntent = new Intent(this, NoteEditActivity.class);
+ 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);
+ 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);
+ }
+ }
+
+ 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;
+ }
+
+ private void showToast(int resId) {
+ showToast(resId, Toast.LENGTH_SHORT);
+ }
+
+ private void showToast(int resId, int duration) {
+ Toast.makeText(this, resId, duration).show();
+ }
+}
diff --git a/rnotes/app/src/main/java/net/micode/notes/ui/NoteEditText.java b/rnotes/app/src/main/java/net/micode/notes/ui/NoteEditText.java
new file mode 100644
index 0000000..2afe2a8
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/ui/NoteEditText.java
@@ -0,0 +1,217 @@
+/*
+ * 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;
+
+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
+ */
+ public interface OnTextViewChangeListener {
+ /**
+ * Delete current edit text when {@link KeyEvent#KEYCODE_DEL} happens
+ * and the text is null
+ */
+ void onEditTextDelete(int index, String text);
+
+ /**
+ * Add edit text after current edit text when {@link KeyEvent#KEYCODE_ENTER}
+ * happen
+ */
+ void onEditTextEnter(int index, String text);
+
+ /**
+ * Hide or show item option when text change
+ */
+ void onTextChange(int index, boolean hasText);
+ }
+
+ private OnTextViewChangeListener mOnTextViewChangeListener;
+
+ public NoteEditText(Context context) {
+ super(context, null);
+ mIndex = 0;
+ }
+
+ public void setIndex(int index) {
+ mIndex = index;
+ }
+
+ public void setOnTextViewChangeListener(OnTextViewChangeListener listener) {
+ mOnTextViewChangeListener = listener;
+ }
+
+ public NoteEditText(Context context, AttributeSet attrs) {
+ super(context, attrs, android.R.attr.editTextStyle);
+ }
+
+ 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);
+ }
+
+ @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);
+ }
+
+ @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);
+ }
+
+ @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/rnotes/app/src/main/java/net/micode/notes/ui/NoteItemData.java b/rnotes/app/src/main/java/net/micode/notes/ui/NoteItemData.java
new file mode 100644
index 0000000..0f5a878
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/ui/NoteItemData.java
@@ -0,0 +1,224 @@
+/*
+ * 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,
+ };
+
+ 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 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 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);
+
+ 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 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/rnotes/app/src/main/java/net/micode/notes/ui/NotesListActivity.java b/rnotes/app/src/main/java/net/micode/notes/ui/NotesListActivity.java
new file mode 100644
index 0000000..e843aec
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/ui/NotesListActivity.java
@@ -0,0 +1,954 @@
+/*
+ * 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;
+ }
+ }
+ }
+
+ 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/rnotes/app/src/main/java/net/micode/notes/ui/NotesListAdapter.java b/rnotes/app/src/main/java/net/micode/notes/ui/NotesListAdapter.java
new file mode 100644
index 0000000..51c9cb9
--- /dev/null
+++ b/rnotes/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/rnotes/app/src/main/java/net/micode/notes/ui/NotesListItem.java b/rnotes/app/src/main/java/net/micode/notes/ui/NotesListItem.java
new file mode 100644
index 0000000..1221e80
--- /dev/null
+++ b/rnotes/app/src/main/java/net/micode/notes/ui/NotesListItem.java
@@ -0,0 +1,122 @@
+/*
+ * 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 TextView mTitle;
+ private TextView mTime;
+ private TextView mCallName;
+ private NoteItemData mItemData;
+ private CheckBox mCheckBox;
+
+ public NotesListItem(Context context) {
+ super(context);
+ inflate(context, R.layout.note_item, this);
+ mAlert = (ImageView) findViewById(R.id.iv_alert_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);
+ }
+
+ 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);
+ }
+ }
+ }
+ mTime.setText(DateUtils.getRelativeTimeSpanString(data.getModifiedDate()));
+
+ 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/rnotes/app/src/main/java/net/micode/notes/ui/NotesPreferenceActivity.java b/rnotes/app/src/main/java/net/micode/notes/ui/NotesPreferenceActivity.java
new file mode 100644
index 0000000..07c5f7e
--- /dev/null
+++ b/rnotes/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/rnotes/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider.java b/rnotes/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider.java
new file mode 100644
index 0000000..ec6f819
--- /dev/null
+++ b/rnotes/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/rnotes/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider_2x.java b/rnotes/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider_2x.java
new file mode 100644
index 0000000..adcb2f7
--- /dev/null
+++ b/rnotes/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/rnotes/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider_4x.java b/rnotes/app/src/main/java/net/micode/notes/widget/NoteWidgetProvider_4x.java
new file mode 100644
index 0000000..c12a02e
--- /dev/null
+++ b/rnotes/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/rnotes/app/src/main/res/color/primary_text_dark.xml b/rnotes/app/src/main/res/color/primary_text_dark.xml
new file mode 100644
index 0000000..8ad98e3
--- /dev/null
+++ b/rnotes/app/src/main/res/color/primary_text_dark.xml
@@ -0,0 +1,22 @@
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/rnotes/app/src/main/res/color/secondary_text_dark.xml b/rnotes/app/src/main/res/color/secondary_text_dark.xml
new file mode 100644
index 0000000..9cf8a1a
--- /dev/null
+++ b/rnotes/app/src/main/res/color/secondary_text_dark.xml
@@ -0,0 +1,20 @@
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/rnotes/app/src/main/res/drawable-hdpi/bg_btn_set_color.png b/rnotes/app/src/main/res/drawable-hdpi/bg_btn_set_color.png
new file mode 100644
index 0000000..5eb5d44
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/bg_btn_set_color.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/bg_color_btn_mask.png b/rnotes/app/src/main/res/drawable-hdpi/bg_color_btn_mask.png
new file mode 100644
index 0000000..100db77
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/bg_color_btn_mask.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/call_record.png b/rnotes/app/src/main/res/drawable-hdpi/call_record.png
new file mode 100644
index 0000000..fb88ca4
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/call_record.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/clock.png b/rnotes/app/src/main/res/drawable-hdpi/clock.png
new file mode 100644
index 0000000..5f2ae9a
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/clock.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/delete.png b/rnotes/app/src/main/res/drawable-hdpi/delete.png
new file mode 100644
index 0000000..643de3e
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/delete.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/dropdown_icon.9.png b/rnotes/app/src/main/res/drawable-hdpi/dropdown_icon.9.png
new file mode 100644
index 0000000..5525025
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/dropdown_icon.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/edit_blue.9.png b/rnotes/app/src/main/res/drawable-hdpi/edit_blue.9.png
new file mode 100644
index 0000000..55a1856
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/edit_blue.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/edit_green.9.png b/rnotes/app/src/main/res/drawable-hdpi/edit_green.9.png
new file mode 100644
index 0000000..2cb2d60
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/edit_green.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/edit_red.9.png b/rnotes/app/src/main/res/drawable-hdpi/edit_red.9.png
new file mode 100644
index 0000000..bae944a
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/edit_red.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/edit_title_blue.9.png b/rnotes/app/src/main/res/drawable-hdpi/edit_title_blue.9.png
new file mode 100644
index 0000000..96e6092
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/edit_title_blue.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/edit_title_green.9.png b/rnotes/app/src/main/res/drawable-hdpi/edit_title_green.9.png
new file mode 100644
index 0000000..08d8644
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/edit_title_green.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/edit_title_red.9.png b/rnotes/app/src/main/res/drawable-hdpi/edit_title_red.9.png
new file mode 100644
index 0000000..9c430e5
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/edit_title_red.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/edit_title_white.9.png b/rnotes/app/src/main/res/drawable-hdpi/edit_title_white.9.png
new file mode 100644
index 0000000..19e8d95
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/edit_title_white.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/edit_title_yellow.9.png b/rnotes/app/src/main/res/drawable-hdpi/edit_title_yellow.9.png
new file mode 100644
index 0000000..bf8f580
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/edit_title_yellow.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/edit_white.9.png b/rnotes/app/src/main/res/drawable-hdpi/edit_white.9.png
new file mode 100644
index 0000000..918f7a6
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/edit_white.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/edit_yellow.9.png b/rnotes/app/src/main/res/drawable-hdpi/edit_yellow.9.png
new file mode 100644
index 0000000..10cb642
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/edit_yellow.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/font_large.png b/rnotes/app/src/main/res/drawable-hdpi/font_large.png
new file mode 100644
index 0000000..78cf2e6
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/font_large.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/font_normal.png b/rnotes/app/src/main/res/drawable-hdpi/font_normal.png
new file mode 100644
index 0000000..9de7ced
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/font_normal.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/font_size_selector_bg.9.png b/rnotes/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/rnotes/app/src/main/res/drawable-hdpi/font_size_selector_bg.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/font_small.png b/rnotes/app/src/main/res/drawable-hdpi/font_small.png
new file mode 100644
index 0000000..d3ff104
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/font_small.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/font_super.png b/rnotes/app/src/main/res/drawable-hdpi/font_super.png
new file mode 100644
index 0000000..85b13a1
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/font_super.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/icon_app.png b/rnotes/app/src/main/res/drawable-hdpi/icon_app.png
new file mode 100644
index 0000000..418aadc
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/icon_app.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_background.png b/rnotes/app/src/main/res/drawable-hdpi/list_background.png
new file mode 100644
index 0000000..087e1f9
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_background.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_blue_down.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_blue_down.9.png
new file mode 100644
index 0000000..b88eebf
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_blue_down.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_blue_middle.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_blue_middle.9.png
new file mode 100644
index 0000000..96b1c8b
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_blue_middle.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_blue_single.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_blue_single.9.png
new file mode 100644
index 0000000..d7e7206
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_blue_single.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_blue_up.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_blue_up.9.png
new file mode 100644
index 0000000..632e88c
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_blue_up.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_folder.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_folder.9.png
new file mode 100644
index 0000000..829f61b
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_folder.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_footer_bg.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_footer_bg.9.png
new file mode 100644
index 0000000..5325c25
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_footer_bg.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_green_down.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_green_down.9.png
new file mode 100644
index 0000000..64a39d9
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_green_down.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_green_middle.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_green_middle.9.png
new file mode 100644
index 0000000..897325a
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_green_middle.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_green_single.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_green_single.9.png
new file mode 100644
index 0000000..c83405f
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_green_single.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_green_up.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_green_up.9.png
new file mode 100644
index 0000000..141f9e1
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_green_up.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_red_down.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_red_down.9.png
new file mode 100644
index 0000000..4224309
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_red_down.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_red_middle.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_red_middle.9.png
new file mode 100644
index 0000000..9988f17
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_red_middle.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_red_single.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_red_single.9.png
new file mode 100644
index 0000000..587c348
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_red_single.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_red_up.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_red_up.9.png
new file mode 100644
index 0000000..46b4757
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_red_up.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_white_down.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_white_down.9.png
new file mode 100644
index 0000000..29f9d8c
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_white_down.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_white_middle.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_white_middle.9.png
new file mode 100644
index 0000000..77a4ab4
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_white_middle.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_white_single.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_white_single.9.png
new file mode 100644
index 0000000..3e79189
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_white_single.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_white_up.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_white_up.9.png
new file mode 100644
index 0000000..e23cd5c
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_white_up.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_yellow_down.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_yellow_down.9.png
new file mode 100644
index 0000000..31cfc1e
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_yellow_down.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_yellow_middle.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_yellow_middle.9.png
new file mode 100644
index 0000000..b6549b2
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_yellow_middle.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_yellow_single.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_yellow_single.9.png
new file mode 100644
index 0000000..3faf507
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_yellow_single.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/list_yellow_up.9.png b/rnotes/app/src/main/res/drawable-hdpi/list_yellow_up.9.png
new file mode 100644
index 0000000..4ae791c
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/list_yellow_up.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/menu_delete.png b/rnotes/app/src/main/res/drawable-hdpi/menu_delete.png
new file mode 100644
index 0000000..ccdfc4b
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/menu_delete.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/menu_move.png b/rnotes/app/src/main/res/drawable-hdpi/menu_move.png
new file mode 100644
index 0000000..1140b71
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/menu_move.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/new_note_normal.png b/rnotes/app/src/main/res/drawable-hdpi/new_note_normal.png
new file mode 100644
index 0000000..e24e0d1
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/new_note_normal.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/new_note_pressed.png b/rnotes/app/src/main/res/drawable-hdpi/new_note_pressed.png
new file mode 100644
index 0000000..c748936
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/new_note_pressed.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/note_edit_color_selector_panel.png b/rnotes/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/rnotes/app/src/main/res/drawable-hdpi/note_edit_color_selector_panel.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/notification.png b/rnotes/app/src/main/res/drawable-hdpi/notification.png
new file mode 100644
index 0000000..b13ab4a
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/notification.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/search_result.png b/rnotes/app/src/main/res/drawable-hdpi/search_result.png
new file mode 100644
index 0000000..ff2befd
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/search_result.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/selected.png b/rnotes/app/src/main/res/drawable-hdpi/selected.png
new file mode 100644
index 0000000..b889bef
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/selected.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/title_alert.png b/rnotes/app/src/main/res/drawable-hdpi/title_alert.png
new file mode 100644
index 0000000..544ee9c
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/title_alert.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/title_bar_bg.9.png b/rnotes/app/src/main/res/drawable-hdpi/title_bar_bg.9.png
new file mode 100644
index 0000000..eb6bff0
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/title_bar_bg.9.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/widget_2x_blue.png b/rnotes/app/src/main/res/drawable-hdpi/widget_2x_blue.png
new file mode 100644
index 0000000..a1707f4
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/widget_2x_blue.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/widget_2x_green.png b/rnotes/app/src/main/res/drawable-hdpi/widget_2x_green.png
new file mode 100644
index 0000000..f86886c
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/widget_2x_green.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/widget_2x_red.png b/rnotes/app/src/main/res/drawable-hdpi/widget_2x_red.png
new file mode 100644
index 0000000..0e66c29
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/widget_2x_red.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/widget_2x_white.png b/rnotes/app/src/main/res/drawable-hdpi/widget_2x_white.png
new file mode 100644
index 0000000..5f0619a
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/widget_2x_white.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/widget_2x_yellow.png b/rnotes/app/src/main/res/drawable-hdpi/widget_2x_yellow.png
new file mode 100644
index 0000000..12d1c2b
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/widget_2x_yellow.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/widget_4x_blue.png b/rnotes/app/src/main/res/drawable-hdpi/widget_4x_blue.png
new file mode 100644
index 0000000..9183738
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/widget_4x_blue.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/widget_4x_green.png b/rnotes/app/src/main/res/drawable-hdpi/widget_4x_green.png
new file mode 100644
index 0000000..fa8b452
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/widget_4x_green.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/widget_4x_red.png b/rnotes/app/src/main/res/drawable-hdpi/widget_4x_red.png
new file mode 100644
index 0000000..62de074
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/widget_4x_red.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/widget_4x_white.png b/rnotes/app/src/main/res/drawable-hdpi/widget_4x_white.png
new file mode 100644
index 0000000..a37d67c
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/widget_4x_white.png differ
diff --git a/rnotes/app/src/main/res/drawable-hdpi/widget_4x_yellow.png b/rnotes/app/src/main/res/drawable-hdpi/widget_4x_yellow.png
new file mode 100644
index 0000000..d7c5fa4
Binary files /dev/null and b/rnotes/app/src/main/res/drawable-hdpi/widget_4x_yellow.png differ
diff --git a/rnotes/app/src/main/res/drawable/new_note.xml b/rnotes/app/src/main/res/drawable/new_note.xml
new file mode 100644
index 0000000..2154ebc
--- /dev/null
+++ b/rnotes/app/src/main/res/drawable/new_note.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
+
+
+
diff --git a/rnotes/app/src/main/res/layout/account_dialog_title.xml b/rnotes/app/src/main/res/layout/account_dialog_title.xml
new file mode 100644
index 0000000..7717112
--- /dev/null
+++ b/rnotes/app/src/main/res/layout/account_dialog_title.xml
@@ -0,0 +1,43 @@
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/rnotes/app/src/main/res/layout/add_account_text.xml b/rnotes/app/src/main/res/layout/add_account_text.xml
new file mode 100644
index 0000000..c799178
--- /dev/null
+++ b/rnotes/app/src/main/res/layout/add_account_text.xml
@@ -0,0 +1,32 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/rnotes/app/src/main/res/layout/datetime_picker.xml b/rnotes/app/src/main/res/layout/datetime_picker.xml
new file mode 100644
index 0000000..f10d592
--- /dev/null
+++ b/rnotes/app/src/main/res/layout/datetime_picker.xml
@@ -0,0 +1,56 @@
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/rnotes/app/src/main/res/layout/dialog_edit_text.xml b/rnotes/app/src/main/res/layout/dialog_edit_text.xml
new file mode 100644
index 0000000..361b39a
--- /dev/null
+++ b/rnotes/app/src/main/res/layout/dialog_edit_text.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/rnotes/app/src/main/res/layout/folder_list_item.xml b/rnotes/app/src/main/res/layout/folder_list_item.xml
new file mode 100644
index 0000000..77e8148
--- /dev/null
+++ b/rnotes/app/src/main/res/layout/folder_list_item.xml
@@ -0,0 +1,29 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/rnotes/app/src/main/res/layout/note_edit.xml b/rnotes/app/src/main/res/layout/note_edit.xml
new file mode 100644
index 0000000..10b2aa7
--- /dev/null
+++ b/rnotes/app/src/main/res/layout/note_edit.xml
@@ -0,0 +1,400 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/rnotes/app/src/main/res/layout/note_edit_list_item.xml b/rnotes/app/src/main/res/layout/note_edit_list_item.xml
new file mode 100644
index 0000000..a885f9c
--- /dev/null
+++ b/rnotes/app/src/main/res/layout/note_edit_list_item.xml
@@ -0,0 +1,39 @@
+
+
+
+
+
+
+
+
+
+
diff --git a/rnotes/app/src/main/res/layout/note_item.xml b/rnotes/app/src/main/res/layout/note_item.xml
new file mode 100644
index 0000000..d541f6a
--- /dev/null
+++ b/rnotes/app/src/main/res/layout/note_item.xml
@@ -0,0 +1,78 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/rnotes/app/src/main/res/layout/note_list.xml b/rnotes/app/src/main/res/layout/note_list.xml
new file mode 100644
index 0000000..6b25d38
--- /dev/null
+++ b/rnotes/app/src/main/res/layout/note_list.xml
@@ -0,0 +1,58 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/rnotes/app/src/main/res/layout/note_list_dropdown_menu.xml b/rnotes/app/src/main/res/layout/note_list_dropdown_menu.xml
new file mode 100644
index 0000000..3fa271d
--- /dev/null
+++ b/rnotes/app/src/main/res/layout/note_list_dropdown_menu.xml
@@ -0,0 +1,32 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/rnotes/app/src/main/res/layout/note_list_footer.xml b/rnotes/app/src/main/res/layout/note_list_footer.xml
new file mode 100644
index 0000000..5ca7b22
--- /dev/null
+++ b/rnotes/app/src/main/res/layout/note_list_footer.xml
@@ -0,0 +1,24 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/rnotes/app/src/main/res/layout/settings_header.xml b/rnotes/app/src/main/res/layout/settings_header.xml
new file mode 100644
index 0000000..5eb8c50
--- /dev/null
+++ b/rnotes/app/src/main/res/layout/settings_header.xml
@@ -0,0 +1,41 @@
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/rnotes/app/src/main/res/layout/widget_2x.xml b/rnotes/app/src/main/res/layout/widget_2x.xml
new file mode 100644
index 0000000..55970ce
--- /dev/null
+++ b/rnotes/app/src/main/res/layout/widget_2x.xml
@@ -0,0 +1,37 @@
+
+
+
+
+
+
+
+
diff --git a/rnotes/app/src/main/res/layout/widget_4x.xml b/rnotes/app/src/main/res/layout/widget_4x.xml
new file mode 100644
index 0000000..dc9bb51
--- /dev/null
+++ b/rnotes/app/src/main/res/layout/widget_4x.xml
@@ -0,0 +1,39 @@
+
+
+
+
+
+
+
+
+
+
diff --git a/rnotes/app/src/main/res/menu/call_note_edit.xml b/rnotes/app/src/main/res/menu/call_note_edit.xml
new file mode 100644
index 0000000..02c0528
--- /dev/null
+++ b/rnotes/app/src/main/res/menu/call_note_edit.xml
@@ -0,0 +1,48 @@
+
+
+
+
+
diff --git a/rnotes/app/src/main/res/menu/call_record_folder.xml b/rnotes/app/src/main/res/menu/call_record_folder.xml
new file mode 100644
index 0000000..c664346
--- /dev/null
+++ b/rnotes/app/src/main/res/menu/call_record_folder.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
diff --git a/rnotes/app/src/main/res/menu/note_edit.xml b/rnotes/app/src/main/res/menu/note_edit.xml
new file mode 100644
index 0000000..35cacd1
--- /dev/null
+++ b/rnotes/app/src/main/res/menu/note_edit.xml
@@ -0,0 +1,52 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/rnotes/app/src/main/res/menu/note_list.xml b/rnotes/app/src/main/res/menu/note_list.xml
new file mode 100644
index 0000000..42ea736
--- /dev/null
+++ b/rnotes/app/src/main/res/menu/note_list.xml
@@ -0,0 +1,39 @@
+
+
+
+
+
diff --git a/rnotes/app/src/main/res/menu/note_list_dropdown.xml b/rnotes/app/src/main/res/menu/note_list_dropdown.xml
new file mode 100644
index 0000000..7cbaadc
--- /dev/null
+++ b/rnotes/app/src/main/res/menu/note_list_dropdown.xml
@@ -0,0 +1,20 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/rnotes/app/src/main/res/menu/note_list_options.xml b/rnotes/app/src/main/res/menu/note_list_options.xml
new file mode 100644
index 0000000..daac008
--- /dev/null
+++ b/rnotes/app/src/main/res/menu/note_list_options.xml
@@ -0,0 +1,31 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/rnotes/app/src/main/res/menu/sub_folder.xml b/rnotes/app/src/main/res/menu/sub_folder.xml
new file mode 100644
index 0000000..b00de26
--- /dev/null
+++ b/rnotes/app/src/main/res/menu/sub_folder.xml
@@ -0,0 +1,24 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/rnotes/app/src/main/res/raw-zh-rCN/introduction b/rnotes/app/src/main/res/raw-zh-rCN/introduction
new file mode 100644
index 0000000..7188359
--- /dev/null
+++ b/rnotes/app/src/main/res/raw-zh-rCN/introduction
@@ -0,0 +1,7 @@
+欢迎使用MIUI便签!
+
+ 无论从软件中直接添加,还是从桌面拖出widget,MIUI便签能让你快速建立和保存便签;
+
+ 除了调整文字大小、便签背景、文件夹等基础功能外,你会发现MIUI便签也提供了清单模式、便签提醒、软件加密、导出到SD卡、同步google task的高级功能,让你的生活记录更加美好和安全;
+
+ 来分享你的使用体验吧:http://www.miui.com/index.php
diff --git a/rnotes/app/src/main/res/raw/introduction b/rnotes/app/src/main/res/raw/introduction
new file mode 100644
index 0000000..269cf7b
--- /dev/null
+++ b/rnotes/app/src/main/res/raw/introduction
@@ -0,0 +1 @@
+Welcome to use MIUI notes!
\ No newline at end of file
diff --git a/rnotes/app/src/main/res/values-zh-rCN/arrays.xml b/rnotes/app/src/main/res/values-zh-rCN/arrays.xml
new file mode 100644
index 0000000..a092386
--- /dev/null
+++ b/rnotes/app/src/main/res/values-zh-rCN/arrays.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
+
+ 短信
+ 邮件
+
+
\ No newline at end of file
diff --git a/rnotes/app/src/main/res/values-zh-rCN/strings.xml b/rnotes/app/src/main/res/values-zh-rCN/strings.xml
new file mode 100644
index 0000000..09f75ed
--- /dev/null
+++ b/rnotes/app/src/main/res/values-zh-rCN/strings.xml
@@ -0,0 +1,126 @@
+
+
+
+
+
+ 便签
+ 便签2x2
+ 便签4x4
+ 没有关联内容,点击新建便签。
+ 访客模式下,便签内容不可见
+ ...
+ 新建便签
+ 成功删除提醒
+ 创建提醒
+ 已过期
+ yyyyMMdd
+ MM月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”的搜索结果
+
+
+
diff --git a/rnotes/app/src/main/res/values-zh-rTW/arrays.xml b/rnotes/app/src/main/res/values-zh-rTW/arrays.xml
new file mode 100644
index 0000000..5297209
--- /dev/null
+++ b/rnotes/app/src/main/res/values-zh-rTW/arrays.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
+
+ 短信
+ 郵件
+
+
\ No newline at end of file
diff --git a/rnotes/app/src/main/res/values-zh-rTW/strings.xml b/rnotes/app/src/main/res/values-zh-rTW/strings.xml
new file mode 100644
index 0000000..e29b79b
--- /dev/null
+++ b/rnotes/app/src/main/res/values-zh-rTW/strings.xml
@@ -0,0 +1,127 @@
+
+
+
+
+
+ 便簽
+ 便簽2x2
+ 便簽4x4
+ 沒有關聯內容,點擊新建便簽。
+ 訪客模式下,便籤內容不可見
+ ...
+ 新建便簽
+ 成功刪除提醒
+ 創建提醒
+ 已過期
+ yyyyMMdd
+ MM月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“的搜尋結果
+
+
+
diff --git a/rnotes/app/src/main/res/values/arrays.xml b/rnotes/app/src/main/res/values/arrays.xml
new file mode 100644
index 0000000..e00210b
--- /dev/null
+++ b/rnotes/app/src/main/res/values/arrays.xml
@@ -0,0 +1,31 @@
+
+
+
+
+
+
+
+ -%s
+ --%s
+ --%s
+ --%s
+
+
+
+ Messaging
+ Email
+
+
\ No newline at end of file
diff --git a/rnotes/app/src/main/res/values/colors.xml b/rnotes/app/src/main/res/values/colors.xml
new file mode 100644
index 0000000..123ffbf
--- /dev/null
+++ b/rnotes/app/src/main/res/values/colors.xml
@@ -0,0 +1,20 @@
+
+
+
+
+
+ #335b5b5b
+
diff --git a/rnotes/app/src/main/res/values/dimens.xml b/rnotes/app/src/main/res/values/dimens.xml
new file mode 100644
index 0000000..194e84f
--- /dev/null
+++ b/rnotes/app/src/main/res/values/dimens.xml
@@ -0,0 +1,24 @@
+
+
+
+
+
+ 33sp
+ 26sp
+ 20sp
+ 17sp
+ 14sp
+
\ No newline at end of file
diff --git a/rnotes/app/src/main/res/values/strings.xml b/rnotes/app/src/main/res/values/strings.xml
new file mode 100644
index 0000000..55df868
--- /dev/null
+++ b/rnotes/app/src/main/res/values/strings.xml
@@ -0,0 +1,135 @@
+
+
+
+
+
+ Notes
+ Notes 2x2
+ Notes 4x4
+ No associated note found, click to create associated note.
+ Privacy mode,can not see note content
+ ...
+ Add note
+ Delete reminder successfully
+ Set reminder
+ Expired
+ yyyyMMdd
+ MMMd kk:mm
+ Got it
+ Take a look
+ Call
+ Send email
+ Browse web
+ Open map
+
+ /MIUI/notes/
+ notes_%s.txt
+
+ (%d)
+ New Folder
+ Export text
+ Sync
+ Cancel syncing
+ Settings
+ Search
+ Delete
+ Move to folder
+ %d selected
+ Nothing selected, the operation is invalid
+ Select all
+ Deselect all
+ Font size
+ Small
+ Medium
+ Large
+ Super
+ Enter check list
+ Leave check list
+ View folder
+ Delete folder
+ Change folder name
+ The folder %1$s exist, please rename
+ Share
+ Send to home
+ Remind me
+ Delete reminder
+ Select folder
+ Parent folder
+ Note added to home
+ Confirm to delete folder and its notes?
+ Delete selected notes
+ Confirm to delete the selected %d notes?
+ Confirm to delete this note?
+ Have moved selected %1$d notes to %2$s folder
+
+ SD card busy, not available now
+ Export failed, please check SD card
+ The note is not exist
+ Sorry, can not set clock on empty note
+ Sorry, can not send and empty note to home
+ Export successful
+ Export fail
+ Export text file (%1$s) to SD (%2$s) directory
+
+ Syncing notes...
+ Sync is successful
+ Sync is failed
+ Sync is canceled
+ Sync is successful with account %1$s
+ Sync failed, please check network and account settings
+ Sync failed, internal error occurs
+ Sync is canceled
+ Logging into %1$s...
+ Getting remote note list...
+ Synchronize local notes with Google Task...
+
+ Settings
+ Sync account
+ Sync notes with google task
+ Last sync time %1$s
+ yyyy-MM-dd hh:mm:ss
+ Add account
+ Change sync account
+ Remove sync account
+ Cancel
+ Sync immediately
+ Cancel syncing
+ Current account %1$s
+ All sync related information will be deleted, which may result in duplicated items sometime
+ Sync notes
+ Please 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 account
+ New note background color random
+
+ Delete
+ Call notes
+ Input name
+
+ Searching Notes
+ Search notes
+ Text in your notes
+ Notes
+ set
+ cancel
+
+ %1$s result for \"%2$s\"
+
+ %1$s results for \"%2$s\"
+
+
+
diff --git a/rnotes/app/src/main/res/values/styles.xml b/rnotes/app/src/main/res/values/styles.xml
new file mode 100644
index 0000000..d750e65
--- /dev/null
+++ b/rnotes/app/src/main/res/values/styles.xml
@@ -0,0 +1,69 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/rnotes/app/src/main/res/xml/preferences.xml b/rnotes/app/src/main/res/xml/preferences.xml
new file mode 100644
index 0000000..fe58f8f
--- /dev/null
+++ b/rnotes/app/src/main/res/xml/preferences.xml
@@ -0,0 +1,30 @@
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/rnotes/app/src/main/res/xml/searchable.xml b/rnotes/app/src/main/res/xml/searchable.xml
new file mode 100644
index 0000000..bf74f14
--- /dev/null
+++ b/rnotes/app/src/main/res/xml/searchable.xml
@@ -0,0 +1,27 @@
+
+
+
+
+
diff --git a/rnotes/app/src/main/res/xml/widget_2x_info.xml b/rnotes/app/src/main/res/xml/widget_2x_info.xml
new file mode 100644
index 0000000..ac8b225
--- /dev/null
+++ b/rnotes/app/src/main/res/xml/widget_2x_info.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
+
diff --git a/rnotes/app/src/main/res/xml/widget_4x_info.xml b/rnotes/app/src/main/res/xml/widget_4x_info.xml
new file mode 100644
index 0000000..cf79f9c
--- /dev/null
+++ b/rnotes/app/src/main/res/xml/widget_4x_info.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
+
diff --git a/rnotes/build.gradle b/rnotes/build.gradle
new file mode 100644
index 0000000..c651082
--- /dev/null
+++ b/rnotes/build.gradle
@@ -0,0 +1,17 @@
+// Top-level build file where you can add configuration options common to all sub-projects/modules.
+buildscript {
+ repositories {
+ google()
+ jcenter()
+ }
+ dependencies {
+ classpath 'com.android.tools.build:gradle:3.5.2'
+ }
+}
+
+allprojects {
+ repositories {
+ google()
+ jcenter()
+ }
+}
diff --git a/rnotes/gradle/wrapper/gradle-wrapper.jar b/rnotes/gradle/wrapper/gradle-wrapper.jar
new file mode 100644
index 0000000..f6b961f
Binary files /dev/null and b/rnotes/gradle/wrapper/gradle-wrapper.jar differ
diff --git a/rnotes/gradle/wrapper/gradle-wrapper.properties b/rnotes/gradle/wrapper/gradle-wrapper.properties
new file mode 100644
index 0000000..f4d7b2b
--- /dev/null
+++ b/rnotes/gradle/wrapper/gradle-wrapper.properties
@@ -0,0 +1,5 @@
+distributionBase=GRADLE_USER_HOME
+distributionPath=wrapper/dists
+distributionUrl=https\://services.gradle.org/distributions/gradle-5.4.1-bin.zip
+zipStoreBase=GRADLE_USER_HOME
+zipStorePath=wrapper/dists
diff --git a/rnotes/gradlew b/rnotes/gradlew
new file mode 100644
index 0000000..cccdd3d
--- /dev/null
+++ b/rnotes/gradlew
@@ -0,0 +1,172 @@
+#!/usr/bin/env sh
+
+##############################################################################
+##
+## Gradle start up script for UN*X
+##
+##############################################################################
+
+# Attempt to set APP_HOME
+# Resolve links: $0 may be a link
+PRG="$0"
+# Need this for relative symlinks.
+while [ -h "$PRG" ] ; do
+ ls=`ls -ld "$PRG"`
+ link=`expr "$ls" : '.*-> \(.*\)$'`
+ if expr "$link" : '/.*' > /dev/null; then
+ PRG="$link"
+ else
+ PRG=`dirname "$PRG"`"/$link"
+ fi
+done
+SAVED="`pwd`"
+cd "`dirname \"$PRG\"`/" >/dev/null
+APP_HOME="`pwd -P`"
+cd "$SAVED" >/dev/null
+
+APP_NAME="Gradle"
+APP_BASE_NAME=`basename "$0"`
+
+# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
+DEFAULT_JVM_OPTS=""
+
+# Use the maximum available, or set MAX_FD != -1 to use that value.
+MAX_FD="maximum"
+
+warn () {
+ echo "$*"
+}
+
+die () {
+ echo
+ echo "$*"
+ echo
+ exit 1
+}
+
+# OS specific support (must be 'true' or 'false').
+cygwin=false
+msys=false
+darwin=false
+nonstop=false
+case "`uname`" in
+ CYGWIN* )
+ cygwin=true
+ ;;
+ Darwin* )
+ darwin=true
+ ;;
+ MINGW* )
+ msys=true
+ ;;
+ NONSTOP* )
+ nonstop=true
+ ;;
+esac
+
+CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
+
+# Determine the Java command to use to start the JVM.
+if [ -n "$JAVA_HOME" ] ; then
+ if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
+ # IBM's JDK on AIX uses strange locations for the executables
+ JAVACMD="$JAVA_HOME/jre/sh/java"
+ else
+ JAVACMD="$JAVA_HOME/bin/java"
+ fi
+ if [ ! -x "$JAVACMD" ] ; then
+ die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
+
+Please set the JAVA_HOME variable in your environment to match the
+location of your Java installation."
+ fi
+else
+ JAVACMD="java"
+ which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
+
+Please set the JAVA_HOME variable in your environment to match the
+location of your Java installation."
+fi
+
+# Increase the maximum file descriptors if we can.
+if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then
+ MAX_FD_LIMIT=`ulimit -H -n`
+ if [ $? -eq 0 ] ; then
+ if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
+ MAX_FD="$MAX_FD_LIMIT"
+ fi
+ ulimit -n $MAX_FD
+ if [ $? -ne 0 ] ; then
+ warn "Could not set maximum file descriptor limit: $MAX_FD"
+ fi
+ else
+ warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
+ fi
+fi
+
+# For Darwin, add options to specify how the application appears in the dock
+if $darwin; then
+ GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
+fi
+
+# For Cygwin, switch paths to Windows format before running java
+if $cygwin ; then
+ APP_HOME=`cygpath --path --mixed "$APP_HOME"`
+ CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
+ JAVACMD=`cygpath --unix "$JAVACMD"`
+
+ # We build the pattern for arguments to be converted via cygpath
+ ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
+ SEP=""
+ for dir in $ROOTDIRSRAW ; do
+ ROOTDIRS="$ROOTDIRS$SEP$dir"
+ SEP="|"
+ done
+ OURCYGPATTERN="(^($ROOTDIRS))"
+ # Add a user-defined pattern to the cygpath arguments
+ if [ "$GRADLE_CYGPATTERN" != "" ] ; then
+ OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
+ fi
+ # Now convert the arguments - kludge to limit ourselves to /bin/sh
+ i=0
+ for arg in "$@" ; do
+ CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
+ CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
+
+ if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
+ eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
+ else
+ eval `echo args$i`="\"$arg\""
+ fi
+ i=$((i+1))
+ done
+ case $i in
+ (0) set -- ;;
+ (1) set -- "$args0" ;;
+ (2) set -- "$args0" "$args1" ;;
+ (3) set -- "$args0" "$args1" "$args2" ;;
+ (4) set -- "$args0" "$args1" "$args2" "$args3" ;;
+ (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
+ (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
+ (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
+ (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
+ (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
+ esac
+fi
+
+# Escape application args
+save () {
+ for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
+ echo " "
+}
+APP_ARGS=$(save "$@")
+
+# Collect all arguments for the java command, following the shell quoting and substitution rules
+eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
+
+# by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong
+if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then
+ cd "$(dirname "$0")"
+fi
+
+exec "$JAVACMD" "$@"
diff --git a/rnotes/gradlew.bat b/rnotes/gradlew.bat
new file mode 100644
index 0000000..f955316
--- /dev/null
+++ b/rnotes/gradlew.bat
@@ -0,0 +1,84 @@
+@if "%DEBUG%" == "" @echo off
+@rem ##########################################################################
+@rem
+@rem Gradle startup script for Windows
+@rem
+@rem ##########################################################################
+
+@rem Set local scope for the variables with windows NT shell
+if "%OS%"=="Windows_NT" setlocal
+
+set DIRNAME=%~dp0
+if "%DIRNAME%" == "" set DIRNAME=.
+set APP_BASE_NAME=%~n0
+set APP_HOME=%DIRNAME%
+
+@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
+set DEFAULT_JVM_OPTS=
+
+@rem Find java.exe
+if defined JAVA_HOME goto findJavaFromJavaHome
+
+set JAVA_EXE=java.exe
+%JAVA_EXE% -version >NUL 2>&1
+if "%ERRORLEVEL%" == "0" goto init
+
+echo.
+echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
+echo.
+echo Please set the JAVA_HOME variable in your environment to match the
+echo location of your Java installation.
+
+goto fail
+
+:findJavaFromJavaHome
+set JAVA_HOME=%JAVA_HOME:"=%
+set JAVA_EXE=%JAVA_HOME%/bin/java.exe
+
+if exist "%JAVA_EXE%" goto init
+
+echo.
+echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
+echo.
+echo Please set the JAVA_HOME variable in your environment to match the
+echo location of your Java installation.
+
+goto fail
+
+:init
+@rem Get command-line arguments, handling Windows variants
+
+if not "%OS%" == "Windows_NT" goto win9xME_args
+
+:win9xME_args
+@rem Slurp the command line arguments.
+set CMD_LINE_ARGS=
+set _SKIP=2
+
+:win9xME_args_slurp
+if "x%~1" == "x" goto execute
+
+set CMD_LINE_ARGS=%*
+
+:execute
+@rem Setup the command line
+
+set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
+
+@rem Execute Gradle
+"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
+
+:end
+@rem End local scope for the variables with windows NT shell
+if "%ERRORLEVEL%"=="0" goto mainEnd
+
+:fail
+rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
+rem the _cmd.exe /c_ return code!
+if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
+exit /b 1
+
+:mainEnd
+if "%OS%"=="Windows_NT" endlocal
+
+:omega
diff --git a/rnotes/import-summary.txt b/rnotes/import-summary.txt
new file mode 100644
index 0000000..f2e6428
--- /dev/null
+++ b/rnotes/import-summary.txt
@@ -0,0 +1,36 @@
+ECLIPSE ANDROID PROJECT IMPORT SUMMARY
+======================================
+
+Ignored Files:
+--------------
+The following files were *not* copied into the new Gradle project; you
+should evaluate whether these are still needed in your project and if
+so manually move them:
+
+* .gitignore
+* NOTICE
+* README
+
+Moved Files:
+------------
+Android Gradle projects use a different directory structure than ADT
+Eclipse projects. Here's how the projects were restructured:
+
+* AndroidManifest.xml => app\src\main\AndroidManifest.xml
+* res\ => app\src\main\res\
+* src\ => app\src\main\java\
+
+Next Steps:
+-----------
+You can now build the project. The Gradle project needs network
+connectivity to download dependencies.
+
+Bugs:
+-----
+If for some reason your project does not build, and you determine that
+it is due to a bug or limitation of the Eclipse to Gradle importer,
+please file a bug at http://b.android.com with category
+Component-Tools.
+
+(This import summary is for your information only, and can be deleted
+after import once you are satisfied with the results.)
diff --git a/rnotes/local.properties b/rnotes/local.properties
new file mode 100644
index 0000000..d4ae0de
--- /dev/null
+++ b/rnotes/local.properties
@@ -0,0 +1,7 @@
+## This file must *NOT* be checked into Version Control Systems,
+# as it contains information specific to your local configuration.
+#
+# Location of the SDK. This is only used by Gradle.
+#
+#Fri May 05 21:26:06 CST 2023
+sdk.dir=D\:\\androidSDK
diff --git a/rnotes/settings.gradle b/rnotes/settings.gradle
new file mode 100644
index 0000000..e7b4def
--- /dev/null
+++ b/rnotes/settings.gradle
@@ -0,0 +1 @@
+include ':app'