Эх сурвалжийг харах

Update selection in FileListListAdapter using ID received from list instead of position, so that changes removals or additions in the list result in correct update of the drawn selection

David A. Velasco 8 жил өмнө
parent
commit
0a4ac6e91c

+ 3 - 8
src/com/owncloud/android/ui/adapter/FileListListAdapter.java

@@ -476,17 +476,12 @@ public class FileListListAdapter extends BaseAdapter implements ListAdapter {
         return mSelection.contains(getItemId(position));
         return mSelection.contains(getItemId(position));
     }
     }
 
 
-    public void updateSelection(int position, boolean checked) {
+    public void updateSelection(long itemId, boolean checked) {
         if (checked) {
         if (checked) {
-            mSelection.add(getItemId(position));
-            notifyDataSetChanged();
+            mSelection.add(itemId);
         } else {
         } else {
-            removeSelection(position);
+            mSelection.remove(itemId);
         }
         }
-    }
-
-    public void removeSelection(int position) {
-        mSelection.remove(getItemId(position));
         notifyDataSetChanged();
         notifyDataSetChanged();
     }
     }
 
 

+ 4 - 5
src/com/owncloud/android/ui/fragment/OCFileListFragment.java

@@ -349,7 +349,7 @@ public class OCFileListFragment extends ExtendedListFragment {
 
 
             @Override
             @Override
             public void onItemCheckedStateChanged(ActionMode mode, int position, long id, boolean checked) {
             public void onItemCheckedStateChanged(ActionMode mode, int position, long id, boolean checked) {
-                mAdapter.updateSelection(position, checked);
+                mAdapter.updateSelection(id, checked);
                 mode.invalidate();
                 mode.invalidate();
             }
             }
 
 
@@ -376,18 +376,17 @@ public class OCFileListFragment extends ExtendedListFragment {
 
 
             @Override
             @Override
             public boolean onPrepareActionMode(ActionMode mode, Menu menu) {
             public boolean onPrepareActionMode(ActionMode mode, Menu menu) {
-                final int checkedCount = getListView().getCheckedItemCount();
+                List<OCFile> checkedFiles = mAdapter.getCheckedItems();
+                final int checkedCount = checkedFiles.size();
                 String title = getResources().getQuantityString(
                 String title = getResources().getQuantityString(
                     R.plurals.items_selected_count,
                     R.plurals.items_selected_count,
                     checkedCount,
                     checkedCount,
                     checkedCount
                     checkedCount
                 );
                 );
                 mode.setTitle(title);
                 mode.setTitle(title);
-
                 if (checkedCount > 0) {
                 if (checkedCount > 0) {
-                    List<OCFile> targetFiles = mAdapter.getCheckedItems();
                     FileMenuFilter mf = new FileMenuFilter(
                     FileMenuFilter mf = new FileMenuFilter(
-                        targetFiles,
+                        checkedFiles,
                         ((FileActivity) getActivity()).getAccount(),
                         ((FileActivity) getActivity()).getAccount(),
                         mContainerActivity,
                         mContainerActivity,
                         getActivity()
                         getActivity()