|
|
|
@ -13,6 +13,9 @@
|
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
|
* limitations under the License.
|
|
|
|
|
*/
|
|
|
|
|
// Description:用于支持小米便签最底层的数据库相关操作,和sqldata的关系上是父集关系,即note是data的子父集。
|
|
|
|
|
// 和SqlData相比,SqlNote算是真正意义上的数据了。
|
|
|
|
|
// 数据库中便签数据类,用于执行最底层的数据库相关操作,包括初始化数据,加载数据,获取共享数据,初始化修改,提交修改到数据库
|
|
|
|
|
|
|
|
|
|
package net.micode.notes.gtask.data;
|
|
|
|
|
|
|
|
|
@ -39,9 +42,12 @@ import java.util.ArrayList;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public class SqlNote {
|
|
|
|
|
// 功能描述:得到类的简写名称存入字符串TAG中
|
|
|
|
|
// 实现过程:调用getSimpleName ()函数
|
|
|
|
|
private static final String TAG = SqlNote.class.getSimpleName();
|
|
|
|
|
|
|
|
|
|
private static final int INVALID_ID = -99999;
|
|
|
|
|
// 集合了interface NoteColumns中所有SF常量(17个)
|
|
|
|
|
|
|
|
|
|
public static final String[] PROJECTION_NOTE = new String[] {
|
|
|
|
|
NoteColumns.ID, NoteColumns.ALERTED_DATE, NoteColumns.BG_COLOR_ID,
|
|
|
|
@ -50,11 +56,15 @@ public class SqlNote {
|
|
|
|
|
NoteColumns.WIDGET_ID, NoteColumns.WIDGET_TYPE, NoteColumns.SYNC_ID,
|
|
|
|
|
NoteColumns.LOCAL_MODIFIED, NoteColumns.ORIGIN_PARENT_ID, NoteColumns.GTASK_ID,
|
|
|
|
|
NoteColumns.VERSION
|
|
|
|
|
// 以下设置17个列的编号
|
|
|
|
|
};
|
|
|
|
|
// 定义一个公共静态常量PROJECTION_NOTE,表示需要查询的列名数组
|
|
|
|
|
|
|
|
|
|
public static final int ID_COLUMN = 0;
|
|
|
|
|
// 定义一个公共静态常量ID_COLUMN,表示查询结果集合中id列的下标
|
|
|
|
|
|
|
|
|
|
public static final int ALERTED_DATE_COLUMN = 1;
|
|
|
|
|
// 定义一个公共静态常量ALERTED_DATE_COLUMN,表示查询结果集合中alerted_date列的下标
|
|
|
|
|
|
|
|
|
|
public static final int BG_COLOR_ID_COLUMN = 2;
|
|
|
|
|
|
|
|
|
@ -86,6 +96,7 @@ public class SqlNote {
|
|
|
|
|
|
|
|
|
|
public static final int VERSION_COLUMN = 16;
|
|
|
|
|
|
|
|
|
|
// 一下定义了17个内部的变量,其中12个可以由content中获得,5个需要初始化为0或者new
|
|
|
|
|
private Context mContext;
|
|
|
|
|
|
|
|
|
|
private ContentResolver mContentResolver;
|
|
|
|
@ -119,65 +130,82 @@ public class SqlNote {
|
|
|
|
|
private long mVersion;
|
|
|
|
|
|
|
|
|
|
private ContentValues mDiffNoteValues;
|
|
|
|
|
// 定义一个私有成员变量mDiffNoteValues,表示当前对象的差异值
|
|
|
|
|
|
|
|
|
|
private ArrayList<SqlData> mDataList;
|
|
|
|
|
// 定义一个私有成员变量mDataList,表示当前对象的数据列表
|
|
|
|
|
|
|
|
|
|
// 功能描述:构造函数
|
|
|
|
|
// 参数注解: mIsCreate用于标示构造方式
|
|
|
|
|
|
|
|
|
|
// 构造函数只有context,对所有的变量进行初始化
|
|
|
|
|
public SqlNote(Context context) {
|
|
|
|
|
mContext = context;
|
|
|
|
|
mContentResolver = context.getContentResolver();
|
|
|
|
|
mIsCreate = true;
|
|
|
|
|
mId = INVALID_ID;
|
|
|
|
|
mAlertDate = 0;
|
|
|
|
|
mBgColorId = ResourceParser.getDefaultBgId(context);
|
|
|
|
|
mCreatedDate = System.currentTimeMillis();
|
|
|
|
|
mHasAttachment = 0;
|
|
|
|
|
mModifiedDate = System.currentTimeMillis();
|
|
|
|
|
mParentId = 0;
|
|
|
|
|
mSnippet = "";
|
|
|
|
|
mType = Notes.TYPE_NOTE;
|
|
|
|
|
mWidgetId = AppWidgetManager.INVALID_APPWIDGET_ID;
|
|
|
|
|
mWidgetType = Notes.TYPE_WIDGET_INVALIDE;
|
|
|
|
|
mOriginParent = 0;
|
|
|
|
|
mVersion = 0;
|
|
|
|
|
mDiffNoteValues = new ContentValues();
|
|
|
|
|
mDataList = new ArrayList<SqlData>();
|
|
|
|
|
mContext = context; // 保存上下文对象
|
|
|
|
|
mContentResolver = context.getContentResolver(); // 获取ContentResolver对象
|
|
|
|
|
mIsCreate = true; // 标记对象是否新建
|
|
|
|
|
mId = INVALID_ID; // 设置对象的id为无效值
|
|
|
|
|
mAlertDate = 0; // 设置提醒日期为0
|
|
|
|
|
mBgColorId = ResourceParser.getDefaultBgId(context); // 设置默认背景颜色
|
|
|
|
|
mCreatedDate = System.currentTimeMillis(); // 获取当前系统时间作为创建日期
|
|
|
|
|
mHasAttachment = 0; // 设置对象是否有附件为0(没有)
|
|
|
|
|
mModifiedDate = System.currentTimeMillis(); // 获取当前系统时间作为修改日期
|
|
|
|
|
mParentId = 0; // 设置对象的父id为0
|
|
|
|
|
mSnippet = ""; // 设置摘要为空字符串
|
|
|
|
|
mType = Notes.TYPE_NOTE; // 设置对象类型为笔记
|
|
|
|
|
mWidgetId = AppWidgetManager.INVALID_APPWIDGET_ID; // 设置小部件id为无效值
|
|
|
|
|
mWidgetType = Notes.TYPE_WIDGET_INVALIDE; // 设置小部件类型为无效值
|
|
|
|
|
mOriginParent = 0; // 设置对象的原始父id为0
|
|
|
|
|
mVersion = 0; // 设置对象版本号为0
|
|
|
|
|
mDiffNoteValues = new ContentValues(); // 初始化对象值差异
|
|
|
|
|
mDataList = new ArrayList<SqlData>(); // 初始化数据列表
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 功能描述:构造函数
|
|
|
|
|
// SqlNote类的构造函数,用于从Cursor对象中加载数据,创建SqlNote对象
|
|
|
|
|
// 参数注解: mIsCreate用于标示构造方式
|
|
|
|
|
|
|
|
|
|
// 构造函数有context和一个数据库的cursor,多数变量通过cursor指向的一条记录直接进行初始化
|
|
|
|
|
public SqlNote(Context context, Cursor c) {
|
|
|
|
|
mContext = context;
|
|
|
|
|
mContentResolver = context.getContentResolver();
|
|
|
|
|
mIsCreate = false;
|
|
|
|
|
loadFromCursor(c);
|
|
|
|
|
mDataList = new ArrayList<SqlData>();
|
|
|
|
|
if (mType == Notes.TYPE_NOTE)
|
|
|
|
|
loadDataContent();
|
|
|
|
|
mDiffNoteValues = new ContentValues();
|
|
|
|
|
mContext = context; // 保存上下文对象
|
|
|
|
|
mContentResolver = context.getContentResolver(); // 获取ContentResolver对象
|
|
|
|
|
mIsCreate = false; // 标记对象不是新建
|
|
|
|
|
loadFromCursor(c); // 从Cursor对象中加载数据
|
|
|
|
|
mDataList = new ArrayList<SqlData>(); // 初始化数据列表
|
|
|
|
|
if (mType == Notes.TYPE_NOTE) // 如果对象是笔记类型
|
|
|
|
|
loadDataContent(); // 加载笔记数据内容
|
|
|
|
|
mDiffNoteValues = new ContentValues(); // 初始化对象值差异
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 功能描述:构造函数
|
|
|
|
|
// SqlNote类的构造函数,用于从id值中加载数据,创建SqlNote对象
|
|
|
|
|
// 参数注解: mIsCreate用于标示构造方式
|
|
|
|
|
public SqlNote(Context context, long id) {
|
|
|
|
|
mContext = context;
|
|
|
|
|
mContentResolver = context.getContentResolver();
|
|
|
|
|
mIsCreate = false;
|
|
|
|
|
loadFromCursor(id);
|
|
|
|
|
mDataList = new ArrayList<SqlData>();
|
|
|
|
|
if (mType == Notes.TYPE_NOTE)
|
|
|
|
|
loadDataContent();
|
|
|
|
|
mDiffNoteValues = new ContentValues();
|
|
|
|
|
|
|
|
|
|
mContext = context; // 保存上下文对象
|
|
|
|
|
mContentResolver = context.getContentResolver(); // 获取ContentResolver对象
|
|
|
|
|
mIsCreate = false; // 标记对象不是新建
|
|
|
|
|
loadFromCursor(id); // 从id值中加载数据
|
|
|
|
|
mDataList = new ArrayList<SqlData>(); // 初始化数据列表
|
|
|
|
|
if (mType == Notes.TYPE_NOTE) // 如果对象是笔记类型
|
|
|
|
|
loadDataContent(); // 加载笔记数据内容
|
|
|
|
|
mDiffNoteValues = new ContentValues(); // 初始化对象值差异
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 功能描述:通过id从光标处加载数据,根据id从数据库中查询便签数据并加载
|
|
|
|
|
private void loadFromCursor(long id) {
|
|
|
|
|
Cursor c = null;
|
|
|
|
|
Cursor c = null; // 声明一个 Cursor 变量并初始化为 null
|
|
|
|
|
try {
|
|
|
|
|
c = mContentResolver.query(Notes.CONTENT_NOTE_URI, PROJECTION_NOTE, "(_id=?)",
|
|
|
|
|
new String[] {
|
|
|
|
|
String.valueOf(id)
|
|
|
|
|
}, null);
|
|
|
|
|
// 通过id获得对应的ContentResolver中的cursor,通过内容提供器获取便签的 Cursor
|
|
|
|
|
if (c != null) {
|
|
|
|
|
c.moveToNext();
|
|
|
|
|
loadFromCursor(c);
|
|
|
|
|
c.moveToNext(); // 将 Cursor 移到下一行,因为默认情况下它指向的是查询结果的第一行之前的位置
|
|
|
|
|
loadFromCursor(c); // 加载数据到 SqlNote 的成员变量中
|
|
|
|
|
// 然后加载数据进行初始化,这与函数SqlNote(Context context, long id)
|
|
|
|
|
// 与SqlNote(Context context, long id)的实现方式基本相同
|
|
|
|
|
} else {
|
|
|
|
|
Log.w(TAG, "loadFromCursor: cursor = null");
|
|
|
|
|
Log.w(TAG, "loadFromCursor: cursor = null"); // 输出警告日志
|
|
|
|
|
}
|
|
|
|
|
} finally {
|
|
|
|
|
if (c != null)
|
|
|
|
@ -185,60 +213,71 @@ public class SqlNote {
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 功能描述:通过游标从光标处加载数据,从 Cursor 中加载便签数据
|
|
|
|
|
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);
|
|
|
|
|
// 直接从一条记录中的获得以下变量的初始值
|
|
|
|
|
mId = c.getLong(ID_COLUMN); // 获取便签的 id
|
|
|
|
|
mAlertDate = c.getLong(ALERTED_DATE_COLUMN); // 获取提醒时间
|
|
|
|
|
mBgColorId = c.getInt(BG_COLOR_ID_COLUMN); // 获取背景颜色 ID
|
|
|
|
|
mCreatedDate = c.getLong(CREATED_DATE_COLUMN); // 获取创建时间
|
|
|
|
|
mHasAttachment = c.getInt(HAS_ATTACHMENT_COLUMN); // 获取是否有附件
|
|
|
|
|
mModifiedDate = c.getLong(MODIFIED_DATE_COLUMN); // 获取修改时间
|
|
|
|
|
mParentId = c.getLong(PARENT_ID_COLUMN); // 获取父级便签的 id
|
|
|
|
|
mSnippet = c.getString(SNIPPET_COLUMN); // 获取便签内容的摘要信息
|
|
|
|
|
mType = c.getInt(TYPE_COLUMN); // 获取便签类型
|
|
|
|
|
mWidgetId = c.getInt(WIDGET_ID_COLUMN); // 获取小部件的 id
|
|
|
|
|
mWidgetType = c.getInt(WIDGET_TYPE_COLUMN); // 获取小部件类型
|
|
|
|
|
mVersion = c.getLong(VERSION_COLUMN); // 获取版本号
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 功能描述:通过content机制获取共享数据并加载到数据库当前游标处
|
|
|
|
|
// 参数注解:
|
|
|
|
|
private void loadDataContent() {
|
|
|
|
|
Cursor c = null;
|
|
|
|
|
mDataList.clear();
|
|
|
|
|
Cursor c = null; //定义游标c
|
|
|
|
|
mDataList.clear(); //清空数据列表mDataList
|
|
|
|
|
try {
|
|
|
|
|
//查询内容提供器,获取数据,条件为note_id=mId,即查询当前笔记的数据内容
|
|
|
|
|
c = mContentResolver.query(Notes.CONTENT_DATA_URI, SqlData.PROJECTION_DATA,
|
|
|
|
|
"(note_id=?)", new String[] {
|
|
|
|
|
String.valueOf(mId)
|
|
|
|
|
String.valueOf(mId)
|
|
|
|
|
}, null);
|
|
|
|
|
if (c != null) {
|
|
|
|
|
if (c.getCount() == 0) {
|
|
|
|
|
Log.w(TAG, "it seems that the note has not data");
|
|
|
|
|
return;
|
|
|
|
|
if (c != null) { //如果游标c不为空
|
|
|
|
|
if (c.getCount() == 0) { //如果游标c的数量为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);
|
|
|
|
|
while (c.moveToNext()) { //如果游标c有下一行记录,则遍历游标c
|
|
|
|
|
SqlData data = new SqlData(mContext, c); //新建SqlData对象data,传入mContext和游标c
|
|
|
|
|
mDataList.add(data); //将data加入到数据列表mDataList中
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
Log.w(TAG, "loadDataContent: cursor = null");
|
|
|
|
|
Log.w(TAG, "loadDataContent: cursor = null"); //输出警告信息
|
|
|
|
|
}
|
|
|
|
|
} finally {
|
|
|
|
|
//无论如何都执行finally块中的代码
|
|
|
|
|
if (c != null)
|
|
|
|
|
c.close();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 功能描述:设置通过content机制用于共享的数据信息
|
|
|
|
|
// 参数注解:
|
|
|
|
|
public boolean setContent(JSONObject js) {
|
|
|
|
|
try {
|
|
|
|
|
// 获取note对象
|
|
|
|
|
JSONObject note = js.getJSONObject(GTaskStringUtils.META_HEAD_NOTE);
|
|
|
|
|
// 如果笔记类型为系统文件夹,则不能设置内容
|
|
|
|
|
if (note.getInt(NoteColumns.TYPE) == Notes.TYPE_SYSTEM) {
|
|
|
|
|
Log.w(TAG, "cannot set system folder");
|
|
|
|
|
} else if (note.getInt(NoteColumns.TYPE) == Notes.TYPE_FOLDER) {
|
|
|
|
|
// for folder we can only update the snnipet and type
|
|
|
|
|
String snippet = note.has(NoteColumns.SNIPPET) ? note
|
|
|
|
|
.getString(NoteColumns.SNIPPET) : "";
|
|
|
|
|
}
|
|
|
|
|
// 如果笔记类型为文件夹
|
|
|
|
|
else if (note.getInt(NoteColumns.TYPE) == Notes.TYPE_FOLDER) {
|
|
|
|
|
// 可以更新snippet和类型
|
|
|
|
|
String snippet = note.has(NoteColumns.SNIPPET) ? note.getString(NoteColumns.SNIPPET) : "";
|
|
|
|
|
// 如果是新建笔记或者snippet改变,则将新值放入mDiffNoteValues中
|
|
|
|
|
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;
|
|
|
|
@ -246,7 +285,9 @@ public class SqlNote {
|
|
|
|
|
mDiffNoteValues.put(NoteColumns.TYPE, type);
|
|
|
|
|
}
|
|
|
|
|
mType = type;
|
|
|
|
|
} else if (note.getInt(NoteColumns.TYPE) == Notes.TYPE_NOTE) {
|
|
|
|
|
}
|
|
|
|
|
// 如果笔记类型为便签
|
|
|
|
|
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) {
|
|
|
|
@ -254,13 +295,16 @@ public class SqlNote {
|
|
|
|
|
}
|
|
|
|
|
mId = id;
|
|
|
|
|
|
|
|
|
|
// 获取提醒时间
|
|
|
|
|
long alertDate = note.has(NoteColumns.ALERTED_DATE) ? note
|
|
|
|
|
.getLong(NoteColumns.ALERTED_DATE) : 0;
|
|
|
|
|
if (mIsCreate || mAlertDate != alertDate) {
|
|
|
|
|
mDiffNoteValues.put(NoteColumns.ALERTED_DATE, alertDate);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
mAlertDate = alertDate;
|
|
|
|
|
|
|
|
|
|
// 获取背景颜色id
|
|
|
|
|
int bgColorId = note.has(NoteColumns.BG_COLOR_ID) ? note
|
|
|
|
|
.getInt(NoteColumns.BG_COLOR_ID) : ResourceParser.getDefaultBgId(mContext);
|
|
|
|
|
if (mIsCreate || mBgColorId != bgColorId) {
|
|
|
|
@ -268,6 +312,7 @@ public class SqlNote {
|
|
|
|
|
}
|
|
|
|
|
mBgColorId = bgColorId;
|
|
|
|
|
|
|
|
|
|
// 获取笔记创建时间
|
|
|
|
|
long createDate = note.has(NoteColumns.CREATED_DATE) ? note
|
|
|
|
|
.getLong(NoteColumns.CREATED_DATE) : System.currentTimeMillis();
|
|
|
|
|
if (mIsCreate || mCreatedDate != createDate) {
|
|
|
|
@ -275,6 +320,7 @@ public class SqlNote {
|
|
|
|
|
}
|
|
|
|
|
mCreatedDate = createDate;
|
|
|
|
|
|
|
|
|
|
// 获取笔记是否有附件
|
|
|
|
|
int hasAttachment = note.has(NoteColumns.HAS_ATTACHMENT) ? note
|
|
|
|
|
.getInt(NoteColumns.HAS_ATTACHMENT) : 0;
|
|
|
|
|
if (mIsCreate || mHasAttachment != hasAttachment) {
|
|
|
|
@ -296,6 +342,7 @@ public class SqlNote {
|
|
|
|
|
}
|
|
|
|
|
mParentId = parentId;
|
|
|
|
|
|
|
|
|
|
// 获取笔记的摘要
|
|
|
|
|
String snippet = note.has(NoteColumns.SNIPPET) ? note
|
|
|
|
|
.getString(NoteColumns.SNIPPET) : "";
|
|
|
|
|
if (mIsCreate || !mSnippet.equals(snippet)) {
|
|
|
|
@ -303,6 +350,7 @@ public class SqlNote {
|
|
|
|
|
}
|
|
|
|
|
mSnippet = snippet;
|
|
|
|
|
|
|
|
|
|
// 获取笔记的类型
|
|
|
|
|
int type = note.has(NoteColumns.TYPE) ? note.getInt(NoteColumns.TYPE)
|
|
|
|
|
: Notes.TYPE_NOTE;
|
|
|
|
|
if (mIsCreate || mType != type) {
|
|
|
|
@ -310,6 +358,7 @@ public class SqlNote {
|
|
|
|
|
}
|
|
|
|
|
mType = type;
|
|
|
|
|
|
|
|
|
|
// 获取笔记的小部件 ID
|
|
|
|
|
int widgetId = note.has(NoteColumns.WIDGET_ID) ? note.getInt(NoteColumns.WIDGET_ID)
|
|
|
|
|
: AppWidgetManager.INVALID_APPWIDGET_ID;
|
|
|
|
|
if (mIsCreate || mWidgetId != widgetId) {
|
|
|
|
@ -317,6 +366,7 @@ public class SqlNote {
|
|
|
|
|
}
|
|
|
|
|
mWidgetId = widgetId;
|
|
|
|
|
|
|
|
|
|
// 获取笔记的小部件类型
|
|
|
|
|
int widgetType = note.has(NoteColumns.WIDGET_TYPE) ? note
|
|
|
|
|
.getInt(NoteColumns.WIDGET_TYPE) : Notes.TYPE_WIDGET_INVALIDE;
|
|
|
|
|
if (mIsCreate || mWidgetType != widgetType) {
|
|
|
|
@ -331,6 +381,7 @@ public class SqlNote {
|
|
|
|
|
}
|
|
|
|
|
mOriginParent = originParent;
|
|
|
|
|
|
|
|
|
|
// 获取笔记的附加数据
|
|
|
|
|
for (int i = 0; i < dataArray.length(); i++) {
|
|
|
|
|
JSONObject data = dataArray.getJSONObject(i);
|
|
|
|
|
SqlData sqlData = null;
|
|
|
|
@ -359,15 +410,20 @@ public class SqlNote {
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 功能描述:获取content机制提供的数据并加载到note中, 获取笔记内容的JSONObject对象
|
|
|
|
|
// return 笔记内容的JSONObject对象,若该笔记未在数据库中创建,则返回null
|
|
|
|
|
// 参数注解:
|
|
|
|
|
public JSONObject getContent() {
|
|
|
|
|
try {
|
|
|
|
|
JSONObject js = new JSONObject();
|
|
|
|
|
|
|
|
|
|
// 如果该笔记未在数据库中创建,则返回null
|
|
|
|
|
if (mIsCreate) {
|
|
|
|
|
Log.e(TAG, "it seems that we haven't created this in database yet");
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 构造笔记的JSONObject对象
|
|
|
|
|
JSONObject note = new JSONObject();
|
|
|
|
|
if (mType == Notes.TYPE_NOTE) {
|
|
|
|
|
note.put(NoteColumns.ID, mId);
|
|
|
|
@ -384,6 +440,7 @@ public class SqlNote {
|
|
|
|
|
note.put(NoteColumns.ORIGIN_PARENT_ID, mOriginParent);
|
|
|
|
|
js.put(GTaskStringUtils.META_HEAD_NOTE, note);
|
|
|
|
|
|
|
|
|
|
// 构造数据的JSONArray对象
|
|
|
|
|
JSONArray dataArray = new JSONArray();
|
|
|
|
|
for (SqlData sqlData : mDataList) {
|
|
|
|
|
JSONObject data = sqlData.getContent();
|
|
|
|
@ -393,6 +450,7 @@ public class SqlNote {
|
|
|
|
|
}
|
|
|
|
|
js.put(GTaskStringUtils.META_HEAD_DATA, dataArray);
|
|
|
|
|
} else if (mType == Notes.TYPE_FOLDER || mType == Notes.TYPE_SYSTEM) {
|
|
|
|
|
// 如果该笔记为文件夹或系统笔记,则构造简单的笔记JSONObject对象
|
|
|
|
|
note.put(NoteColumns.ID, mId);
|
|
|
|
|
note.put(NoteColumns.TYPE, mType);
|
|
|
|
|
note.put(NoteColumns.SNIPPET, mSnippet);
|
|
|
|
@ -407,45 +465,66 @@ public class SqlNote {
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 功能描述:给当前id设置父id
|
|
|
|
|
// 参数注解:
|
|
|
|
|
public void setParentId(long id) {
|
|
|
|
|
mParentId = id;
|
|
|
|
|
mDiffNoteValues.put(NoteColumns.PARENT_ID, id);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 功能描述:给当前id设置Gtaskid
|
|
|
|
|
// 参数注解:
|
|
|
|
|
public void setGtaskId(String gid) {
|
|
|
|
|
mDiffNoteValues.put(NoteColumns.GTASK_ID, gid);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 功能描述:给当前id设置同步id
|
|
|
|
|
// 参数注解:
|
|
|
|
|
public void setSyncId(long syncId) {
|
|
|
|
|
mDiffNoteValues.put(NoteColumns.SYNC_ID, syncId);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 功能描述:初始化本地修改,即撤销所有当前修改
|
|
|
|
|
// 参数注解:
|
|
|
|
|
public void resetLocalModified() {
|
|
|
|
|
mDiffNoteValues.put(NoteColumns.LOCAL_MODIFIED, 0);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 功能描述:获得当前id
|
|
|
|
|
// 参数注解:
|
|
|
|
|
public long getId() {
|
|
|
|
|
return mId;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 功能描述:获得当前id的父id
|
|
|
|
|
// 参数注解:
|
|
|
|
|
public long getParentId() {
|
|
|
|
|
return mParentId;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 功能描述:获取小片段即用于显示的部分便签内容
|
|
|
|
|
// 参数注解:
|
|
|
|
|
public String getSnippet() {
|
|
|
|
|
return mSnippet;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 功能描述:判断是否为便签类型
|
|
|
|
|
// 参数注解:
|
|
|
|
|
public boolean isNoteType() {
|
|
|
|
|
return mType == Notes.TYPE_NOTE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 功能描述:commit函数用于把当前造作所做的修改保存到数据库
|
|
|
|
|
// 参数注解:
|
|
|
|
|
public void commit(boolean validateVersion) {
|
|
|
|
|
if (mIsCreate) {
|
|
|
|
|
// 如果当前的 Note 是新建的
|
|
|
|
|
// 如果当前 Note 的 ID 是无效的,并且存在 ID 字段,则将其从 DiffNoteValues 中移除
|
|
|
|
|
if (mId == INVALID_ID && mDiffNoteValues.containsKey(NoteColumns.ID)) {
|
|
|
|
|
mDiffNoteValues.remove(NoteColumns.ID);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 将当前 Note 插入到数据库中,并从返回的 URI 中获取 Note 的 ID
|
|
|
|
|
Uri uri = mContentResolver.insert(Notes.CONTENT_NOTE_URI, mDiffNoteValues);
|
|
|
|
|
try {
|
|
|
|
|
mId = Long.valueOf(uri.getPathSegments().get(1));
|
|
|
|
@ -453,31 +532,37 @@ public class SqlNote {
|
|
|
|
|
Log.e(TAG, "Get note id error :" + e.toString());
|
|
|
|
|
throw new ActionFailureException("create note failed");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 如果获取到的 Note 的 ID 为 0,则抛出异常
|
|
|
|
|
if (mId == 0) {
|
|
|
|
|
throw new IllegalStateException("Create thread id failed");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 如果当前 Note 是普通笔记,则将其关联的 SqlData 数据写入到数据库中
|
|
|
|
|
if (mType == Notes.TYPE_NOTE) {
|
|
|
|
|
for (SqlData sqlData : mDataList) {
|
|
|
|
|
sqlData.commit(mId, false, -1);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
} else { // 如果当前的 Note 不是新建的
|
|
|
|
|
// 如果当前 Note 的 ID 无效,则抛出异常
|
|
|
|
|
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");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 如果当前 Note 的 DiffNoteValues 中存在修改过的值,则将其更新到数据库中
|
|
|
|
|
if (mDiffNoteValues.size() > 0) {
|
|
|
|
|
mVersion ++;
|
|
|
|
|
mVersion ++; // 更新 Note 的版本号
|
|
|
|
|
int result = 0;
|
|
|
|
|
if (!validateVersion) {
|
|
|
|
|
if (!validateVersion) { // 如果不需要验证版本号,则直接更新数据库
|
|
|
|
|
result = mContentResolver.update(Notes.CONTENT_NOTE_URI, mDiffNoteValues, "("
|
|
|
|
|
+ NoteColumns.ID + "=?)", new String[] {
|
|
|
|
|
String.valueOf(mId)
|
|
|
|
|
String.valueOf(mId)
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
} else { // 如果需要验证版本号,则在更新数据库时指定版本号
|
|
|
|
|
result = mContentResolver.update(Notes.CONTENT_NOTE_URI, mDiffNoteValues, "("
|
|
|
|
|
+ NoteColumns.ID + "=?) AND (" + NoteColumns.VERSION + "<=?)",
|
|
|
|
|
+ NoteColumns.ID + "=?) AND (" + NoteColumns.VERSION + "<=?)",
|
|
|
|
|
new String[] {
|
|
|
|
|
String.valueOf(mId), String.valueOf(mVersion)
|
|
|
|
|
});
|
|
|
|
@ -487,6 +572,7 @@ public class SqlNote {
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 如果当前 Note 是普通笔记,则将其关联的 SqlData 数据写入到数据库中
|
|
|
|
|
if (mType == Notes.TYPE_NOTE) {
|
|
|
|
|
for (SqlData sqlData : mDataList) {
|
|
|
|
|
sqlData.commit(mId, validateVersion, mVersion);
|
|
|
|
@ -494,12 +580,11 @@ public class SqlNote {
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// refresh local info
|
|
|
|
|
// 刷新当前 Note 对象的本地数据,并将其 DiffNoteValues 清空
|
|
|
|
|
loadFromCursor(mId);
|
|
|
|
|
if (mType == Notes.TYPE_NOTE)
|
|
|
|
|
loadDataContent();
|
|
|
|
|
|
|
|
|
|
mDiffNoteValues.clear();
|
|
|
|
|
mIsCreate = false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|