|
|
|
@ -29,14 +29,21 @@ import org.json.JSONObject;
|
|
|
|
|
|
|
|
|
|
import java.util.ArrayList;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* TaskList 是 Node 的子类,表示一个任务列表(即任务组),用于同步本地和远程的任务列表数据。
|
|
|
|
|
* 它管理一组 Task 子项,并提供了添加、删除、移动任务的方法。
|
|
|
|
|
*/
|
|
|
|
|
public class TaskList extends Node {
|
|
|
|
|
/** 日志标签,标识当前类名 */
|
|
|
|
|
private static final String TAG = TaskList.class.getSimpleName();
|
|
|
|
|
|
|
|
|
|
/** 列表在远程服务器上的索引位置 */
|
|
|
|
|
private int mIndex;
|
|
|
|
|
|
|
|
|
|
/** 当前任务列表中的子任务集合 */
|
|
|
|
|
private ArrayList<Task> mChildren;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 创建一个新的 TaskList 实例,初始化子任务列表和索引。
|
|
|
|
|
*/
|
|
|
|
|
public TaskList() {
|
|
|
|
|
super();
|
|
|
|
|
mChildren = new ArrayList<Task>();
|
|
|
|
@ -73,7 +80,12 @@ public class TaskList extends Node {
|
|
|
|
|
|
|
|
|
|
return js;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 生成更新任务列表的远程同步操作 JSON 对象。
|
|
|
|
|
*
|
|
|
|
|
* @param actionId 操作 ID
|
|
|
|
|
* @return 包含更新操作信息的 JSON 对象
|
|
|
|
|
*/
|
|
|
|
|
public JSONObject getUpdateAction(int actionId) {
|
|
|
|
|
JSONObject js = new JSONObject();
|
|
|
|
|
|
|
|
|
@ -102,7 +114,11 @@ public class TaskList extends Node {
|
|
|
|
|
|
|
|
|
|
return js;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 从远程 JSON 设置任务列表内容(如名称、ID、最后修改时间等)。
|
|
|
|
|
*
|
|
|
|
|
* @param js 远程 JSON 数据
|
|
|
|
|
*/
|
|
|
|
|
public void setContentByRemoteJSON(JSONObject js) {
|
|
|
|
|
if (js != null) {
|
|
|
|
|
try {
|
|
|
|
@ -128,7 +144,11 @@ public class TaskList extends Node {
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 从本地 JSON 设置任务列表内容(通常从数据库加载)。
|
|
|
|
|
*
|
|
|
|
|
* @param js 本地 JSON 数据
|
|
|
|
|
*/
|
|
|
|
|
public void setContentByLocalJSON(JSONObject js) {
|
|
|
|
|
if (js == null || !js.has(GTaskStringUtils.META_HEAD_NOTE)) {
|
|
|
|
|
Log.w(TAG, "setContentByLocalJSON: nothing is avaiable");
|
|
|
|
@ -156,7 +176,11 @@ public class TaskList extends Node {
|
|
|
|
|
e.printStackTrace();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 将当前任务列表内容转换为本地 JSON 格式,用于存储或同步。
|
|
|
|
|
*
|
|
|
|
|
* @return 包含任务列表内容的 JSON 对象
|
|
|
|
|
*/
|
|
|
|
|
public JSONObject getLocalJSONFromContent() {
|
|
|
|
|
try {
|
|
|
|
|
JSONObject js = new JSONObject();
|
|
|
|
@ -182,7 +206,12 @@ public class TaskList extends Node {
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 根据游标判断当前任务列表需要执行的同步动作类型。
|
|
|
|
|
*
|
|
|
|
|
* @param c 数据库游标
|
|
|
|
|
* @return 同步动作类型(SYNC_ACTION_XXX)
|
|
|
|
|
*/
|
|
|
|
|
public int getSyncAction(Cursor c) {
|
|
|
|
|
try {
|
|
|
|
|
if (c.getInt(SqlNote.LOCAL_MODIFIED_COLUMN) == 0) {
|
|
|
|
@ -219,7 +248,12 @@ public class TaskList extends Node {
|
|
|
|
|
public int getChildTaskCount() {
|
|
|
|
|
return mChildren.size();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 添加一个子任务到任务列表末尾,并设置其父级和前一兄弟节点。
|
|
|
|
|
*
|
|
|
|
|
* @param task 要添加的任务
|
|
|
|
|
* @return 是否成功添加
|
|
|
|
|
*/
|
|
|
|
|
public boolean addChildTask(Task task) {
|
|
|
|
|
boolean ret = false;
|
|
|
|
|
if (task != null && !mChildren.contains(task)) {
|
|
|
|
@ -233,7 +267,13 @@ public class TaskList extends Node {
|
|
|
|
|
}
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 在指定位置插入一个子任务,并调整兄弟节点关系。
|
|
|
|
|
*
|
|
|
|
|
* @param task 要添加的任务
|
|
|
|
|
* @param index 插入的位置
|
|
|
|
|
* @return 是否成功插入
|
|
|
|
|
*/
|
|
|
|
|
public boolean addChildTask(Task task, int index) {
|
|
|
|
|
if (index < 0 || index > mChildren.size()) {
|
|
|
|
|
Log.e(TAG, "add child task: invalid index");
|
|
|
|
@ -280,7 +320,13 @@ public class TaskList extends Node {
|
|
|
|
|
}
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 将指定任务移动到新的位置。
|
|
|
|
|
*
|
|
|
|
|
* @param task 要移动的任务
|
|
|
|
|
* @param index 新的位置
|
|
|
|
|
* @return 是否成功移动
|
|
|
|
|
*/
|
|
|
|
|
public boolean moveChildTask(Task task, int index) {
|
|
|
|
|
|
|
|
|
|
if (index < 0 || index >= mChildren.size()) {
|
|
|
|
@ -308,11 +354,21 @@ public class TaskList extends Node {
|
|
|
|
|
}
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 获取指定任务在子任务列表中的索引。
|
|
|
|
|
*
|
|
|
|
|
* @param task 子任务
|
|
|
|
|
* @return 索引位置,若未找到则返回 -1
|
|
|
|
|
*/
|
|
|
|
|
public int getChildTaskIndex(Task task) {
|
|
|
|
|
return mChildren.indexOf(task);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 根据索引获取子任务。
|
|
|
|
|
*
|
|
|
|
|
* @param index 索引位置
|
|
|
|
|
* @return 子任务对象,若索引无效则返回 null
|
|
|
|
|
*/
|
|
|
|
|
public Task getChildTaskByIndex(int index) {
|
|
|
|
|
if (index < 0 || index >= mChildren.size()) {
|
|
|
|
|
Log.e(TAG, "getTaskByIndex: invalid index");
|
|
|
|
@ -321,6 +377,11 @@ public class TaskList extends Node {
|
|
|
|
|
return mChildren.get(index);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 获取所有子任务的列表。
|
|
|
|
|
*
|
|
|
|
|
* @return 子任务集合
|
|
|
|
|
*/
|
|
|
|
|
public Task getChilTaskByGid(String gid) {
|
|
|
|
|
for (Task task : mChildren) {
|
|
|
|
|
if (task.getGid().equals(gid))
|
|
|
|
|