diff --git a/src/main/java/net/micode/notes/model/WorkingNote.java b/src/main/java/net/micode/notes/model/WorkingNote.java index d303c30..c495432 100644 --- a/src/main/java/net/micode/notes/model/WorkingNote.java +++ b/src/main/java/net/micode/notes/model/WorkingNote.java @@ -333,7 +333,7 @@ public class WorkingNote { *
* 将当前工作笔记保存到数据库中。如果笔记不存在,则创建新笔记; * 如果笔记已存在,则更新现有笔记。 - * 如果笔记内容为空且已存在于数据库,则删除该笔记。 + * 如果笔记内容为空且已存在于数据库,则将其移动到回收站。 *
* * @return 保存成功返回true,否则返回false @@ -359,12 +359,13 @@ public class WorkingNote { } return true; } else { - // 添加删除逻辑:如果笔记内容为空且已存在于数据库,则删除该笔记 + // 添加删除逻辑:如果笔记内容为空且已存在于数据库,则将其移动到回收站 if (existInDatabase() && TextUtils.isEmpty(mContent)) { HashSet- * 该方法完成以下工作: - * 1. 加载菜单资源 - * 2. 设置删除菜单的点击监听器 - * 3. 根据当前文件夹ID和用户文件夹数量设置移动菜单的可见性 - * 4. 保存动作模式实例 - * 5. 设置列表适配器为选择模式 - * 6. 禁用列表的长按功能 - * 7. 隐藏新建笔记按钮 - * 8. 设置自定义视图 - * 9. 创建下拉菜单 - * 10. 设置下拉菜单的点击监听器 - *
- * @param mode 动作模式 - * @param menu 菜单 - * @return 是否创建成功,返回true表示成功 - */ - 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); - } - // 添加置顶菜单初始化 - MenuItem pinMenu = menu.findItem(R.id.pin); - if (pinMenu != null) { - pinMenu.setOnMenuItemClickListener(this); - } - // 添加锁定菜单初始化 - MenuItem lockMenu = menu.findItem(R.id.lock); - if (lockMenu != null) { - lockMenu.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; + * 创建动作模式 + *+ * 该方法完成以下工作: + * 1. 加载菜单资源 + * 2. 设置删除菜单的点击监听器 + * 3. 根据当前文件夹ID和用户文件夹数量设置移动菜单或恢复菜单的可见性 + * 4. 保存动作模式实例 + * 5. 设置列表适配器为选择模式 + * 6. 禁用列表的长按功能 + * 7. 隐藏新建笔记按钮 + * 8. 设置自定义视图 + * 9. 创建下拉菜单 + * 10. 设置下拉菜单的点击监听器 + *
+ * @param mode 动作模式 + * @param menu 菜单 + * @return 是否创建成功,返回true表示成功 + */ + public boolean onCreateActionMode(ActionMode mode, Menu menu) { + getMenuInflater().inflate(R.menu.note_list_options, menu); + menu.findItem(R.id.delete).setOnMenuItemClickListener(this); + + if (mCurrentFolderId == Notes.ID_TRASH_FOLER) { + // 在回收站内部,显示恢复按钮 + MenuItem restoreMenu = menu.findItem(R.id.restore); + if (restoreMenu != null) { + restoreMenu.setVisible(true); + restoreMenu.setOnMenuItemClickListener(this); + } + // 隐藏移动按钮 + MenuItem moveMenu = menu.findItem(R.id.move); + if (moveMenu != null) { + moveMenu.setVisible(false); + } + } else { + // 在回收站外部,显示移动按钮 + 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); + } + // 隐藏恢复按钮 + MenuItem restoreMenu = menu.findItem(R.id.restore); + if (restoreMenu != null) { + restoreMenu.setVisible(false); + } + } + + // 添加置顶菜单初始化 + MenuItem pinMenu = menu.findItem(R.id.pin); + if (pinMenu != null) { + pinMenu.setOnMenuItemClickListener(this); } + // 添加锁定菜单初始化 + MenuItem lockMenu = menu.findItem(R.id.lock); + if (lockMenu != null) { + lockMenu.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; - } + }); + return true; + } /** * 更新菜单 @@ -672,55 +697,71 @@ public class NotesListActivity extends Activity implements OnClickListener, OnIt } /** - * 处理菜单项点击事件 - *- * 该方法完成以下工作: - * 1. 检查是否有选中的笔记,如果没有则显示提示 - * 2. 根据菜单项ID处理不同的操作: - * - 删除:显示删除确认对话框,点击确定后调用batchDelete方法 - * - 移动:调用startQueryDestinationFolders方法查询目标文件夹 - *
- * @param item 菜单项 - * @return 是否处理成功,返回true表示成功 - */ - 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; - } + * 处理菜单项点击事件 + *+ * 该方法完成以下工作: + * 1. 检查是否有选中的笔记,如果没有则显示提示 + * 2. 根据菜单项ID处理不同的操作: + * - 删除:显示删除确认对话框,点击确定后调用batchDelete方法 + * - 移动:调用startQueryDestinationFolders方法查询目标文件夹 + * - 恢复:调用batchRestore方法恢复选中的项目 + *
+ * @param item 菜单项 + * @return 是否处理成功,返回true表示成功 + */ + 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; - case R.id.pin: - togglePinnedStatus(); - break; - case R.id.lock: - showPasswordDialog(); - break; - default: - return false; + switch (item.getItemId()) { + case R.id.delete: + AlertDialog.Builder builder = new AlertDialog.Builder(NotesListActivity.this); + + if (mCurrentFolderId == Notes.ID_TRASH_FOLER) { + // 在回收站内部,提示永久删除 + 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_permanently, + mNotesListAdapter.getSelectedCount())); + } else { + // 在回收站外部,提示移动到回收站 + 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; + case R.id.restore: + // 恢复选中的项目 + batchRestore(); + break; + case R.id.pin: + togglePinnedStatus(); + break; + case R.id.lock: + showPasswordDialog(); + break; + default: + return false; + } + return true; } - return true; - } } /** @@ -913,8 +954,8 @@ public class NotesListActivity extends Activity implements OnClickListener, OnIt ** 该方法在异步任务中完成以下工作: * 1. 获取选中的部件属性 - * 2. 如果不在同步模式,直接删除选中的笔记 - * 3. 如果在同步模式,将选中的笔记移动到回收站 + * 2. 如果当前在回收站内部,直接永久删除选中的笔记 + * 3. 如果当前不在回收站内部,将选中的笔记移动到回收站 * 4. 更新相关部件 * 5. 结束多选模式 *
@@ -923,16 +964,14 @@ public class NotesListActivity extends Activity implements OnClickListener, OnIt new AsyncTask+ * 该方法在异步任务中完成以下工作: + * 1. 获取选中的项目ID + * 2. 对于每个项目,查询其原始父文件夹ID + * 3. 将项目移动回原始父文件夹(如果原始父文件夹不存在或也在回收站中,则移动到根文件夹) + * 4. 更新相关部件 + * 5. 结束动作模式 + *
+ */ + private void batchRestore() { + new AsyncTask* 该方法用于在选择模式下全选或取消全选所有普通笔记项 + * 在回收站内部时,也会选择文件夹类型的项 *
* @param checked 是否全选 */ @@ -156,7 +157,14 @@ public class NotesListAdapter extends CursorAdapter { Cursor cursor = getCursor(); for (int i = 0; i < getCount(); i++) { if (cursor.moveToPosition(i)) { - if (NoteItemData.getNoteType(cursor) == Notes.TYPE_NOTE) { + // 获取当前项的类型 + int noteType = NoteItemData.getNoteType(cursor); + // 获取当前项的父文件夹ID + cursor.moveToPosition(i); + long parentId = cursor.getLong(8); // PARENT_ID列的索引是8 + + // 在回收站内部时,选择所有类型的项(除了根文件夹) + if (parentId == Notes.ID_TRASH_FOLER || noteType == Notes.TYPE_NOTE) { setCheckedItem(i, checked); } } diff --git a/src/main/java/net/micode/notes/ui/NotesListItem.java b/src/main/java/net/micode/notes/ui/NotesListItem.java index c08425c..069771a 100644 --- a/src/main/java/net/micode/notes/ui/NotesListItem.java +++ b/src/main/java/net/micode/notes/ui/NotesListItem.java @@ -100,6 +100,13 @@ public class NotesListItem extends LinearLayout { 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.getId() == Notes.ID_TRASH_FOLER) { + mCallName.setVisibility(View.GONE); + mAlert.setVisibility(View.VISIBLE); + mTitle.setTextAppearance(context, R.style.TextAppearancePrimaryItem); + mTitle.setText("回收站" + + context.getString(R.string.format_folder_files_count, data.getNotesCount())); + mAlert.setImageResource(R.drawable.delete); } else if (data.getParentId() == Notes.ID_CALL_RECORD_FOLDER) { mCallName.setVisibility(View.VISIBLE); mCallName.setText(data.getCallName()); @@ -117,7 +124,7 @@ public class NotesListItem extends LinearLayout { if (data.getType() == Notes.TYPE_FOLDER) { mTitle.setText(data.getSnippet() - + context.getString(R.string.format_folder_files_count, + + context.getString(R.string.format_folder_files_count, data.getNotesCount())); mAlert.setVisibility(View.GONE); } else { @@ -130,7 +137,15 @@ public class NotesListItem extends LinearLayout { } } } - mTime.setText(DateUtils.getRelativeTimeSpanString(data.getModifiedDate())); + // 根据笔记是否在回收站中显示不同的时间 + if (data.getParentId() == Notes.ID_TRASH_FOLER || data.isDeleted()) { + // 回收站中的项显示删除时间 + mTime.setText(context.getString(R.string.deleted_time_format, + DateUtils.getRelativeTimeSpanString(data.getDeletedDate()))); + } else { + // 普通项显示修改时间 + mTime.setText(DateUtils.getRelativeTimeSpanString(data.getModifiedDate())); + } setBackground(data); }