Add functionality to select/deselect all button
This commit is contained in:
parent
d8a226ff92
commit
b813ba4df4
2 changed files with 30 additions and 3 deletions
|
@ -551,12 +551,18 @@ public class MapMarkersHelper {
|
|||
return mapMarkersHistory;
|
||||
}
|
||||
|
||||
public void clearSelections() {
|
||||
public void deselectAllActiveMarkers() {
|
||||
for (MapMarker m : mapMarkers) {
|
||||
m.selected = false;
|
||||
}
|
||||
}
|
||||
|
||||
public void selectAllActiveMarkers() {
|
||||
for (MapMarker m : mapMarkers) {
|
||||
m.selected = true;
|
||||
}
|
||||
}
|
||||
|
||||
public List<MapMarker> getSelectedMarkers() {
|
||||
List<MapMarker> list = new ArrayList<>();
|
||||
for (MapMarker m : this.mapMarkers) {
|
||||
|
|
|
@ -50,6 +50,7 @@ public class PlanRouteFragment extends Fragment {
|
|||
private PlanRouteToolbarController toolbarController;
|
||||
private ApplicationMode appMode;
|
||||
private int previousMapPosition;
|
||||
private int selectedCount = 0;
|
||||
|
||||
private boolean nightMode;
|
||||
private boolean portrait;
|
||||
|
@ -120,7 +121,16 @@ public class PlanRouteFragment extends Fragment {
|
|||
mainView.findViewById(R.id.select_all_button).setOnClickListener(new View.OnClickListener() {
|
||||
@Override
|
||||
public void onClick(View view) {
|
||||
Toast.makeText(mapActivity, "Select all", Toast.LENGTH_SHORT).show();
|
||||
int activeMarkersCount = markersHelper.getMapMarkers().size();
|
||||
if (selectedCount == activeMarkersCount) {
|
||||
markersHelper.deselectAllActiveMarkers();
|
||||
selectedCount = 0;
|
||||
} else {
|
||||
markersHelper.selectAllActiveMarkers();
|
||||
selectedCount = activeMarkersCount;
|
||||
}
|
||||
adapter.notifyDataSetChanged();
|
||||
updateSelectButton();
|
||||
}
|
||||
});
|
||||
|
||||
|
@ -167,8 +177,10 @@ public class PlanRouteFragment extends Fragment {
|
|||
public void onItemClick(View view) {
|
||||
int pos = markersRv.getChildAdapterPosition(view);
|
||||
MapMarker marker = adapter.getItem(pos);
|
||||
selectedCount = marker.selected ? selectedCount - 1 : selectedCount + 1;
|
||||
marker.selected = !marker.selected;
|
||||
adapter.notifyItemChanged(pos);
|
||||
updateSelectButton();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -270,6 +282,7 @@ public class PlanRouteFragment extends Fragment {
|
|||
|
||||
mapActivity.refreshMap();
|
||||
updateText();
|
||||
updateSelectButton();
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -329,6 +342,14 @@ public class PlanRouteFragment extends Fragment {
|
|||
timeTv.setText("~ 45 min.");
|
||||
}
|
||||
|
||||
private void updateSelectButton() {
|
||||
if (selectedCount == markersHelper.getMapMarkers().size()) {
|
||||
((TextView) mainView.findViewById(R.id.select_all_button)).setText(getString(R.string.shared_string_deselect_all));
|
||||
} else {
|
||||
((TextView) mainView.findViewById(R.id.select_all_button)).setText(getString(R.string.shared_string_select_all));
|
||||
}
|
||||
}
|
||||
|
||||
private void mark(int status, int... widgets) {
|
||||
MapActivity mapActivity = getMapActivity();
|
||||
if (mapActivity != null) {
|
||||
|
@ -427,7 +448,7 @@ public class PlanRouteFragment extends Fragment {
|
|||
if (markersListOpened) {
|
||||
hideMarkersList();
|
||||
}
|
||||
markersHelper.clearSelections();
|
||||
markersHelper.deselectAllActiveMarkers();
|
||||
activity.getSupportFragmentManager().beginTransaction().remove(this).commitAllowingStateLoss();
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue