Layout for sort and filter dialog on search results page

This commit is contained in:
Clayton Wilson 2020-10-01 15:34:34 -04:00
parent 550483a708
commit ef2a58d23f
6 changed files with 81 additions and 50 deletions

View File

@ -189,9 +189,9 @@ public class SearchResults extends AppCompatActivity implements SortDialogFragme
resultsProductListSorted.sort(new Comparator<Product>() { resultsProductListSorted.sort(new Comparator<Product>() {
@Override @Override
public int compare(Product a, Product b) { public int compare(Product a, Product b) {
if (a.getPrice() - b.getPrice() > 0) { if (b.getPrice() - a.getPrice() > 0) {
return 1; return 1;
} else if (a.getPrice() - b.getPrice() < 0) { } else if (b.getPrice() - a.getPrice() < 0) {
return -1; return -1;
} else { } else {
return 0; return 0;

View File

@ -36,6 +36,7 @@ public class SortDialogFragment extends DialogFragment {
this.descending = descending; this.descending = descending;
} }
@Override @Override
public Dialog onCreateDialog(final Bundle savedInstanceState) { public Dialog onCreateDialog(final Bundle savedInstanceState) {
AlertDialog.Builder builder = new AlertDialog.Builder(getActivity()); AlertDialog.Builder builder = new AlertDialog.Builder(getActivity());
@ -65,6 +66,8 @@ public class SortDialogFragment extends DialogFragment {
for (int i = 1; i < stores.size() + 1; i++) { for (int i = 1; i < stores.size() + 1; i++) {
storeChoices[i] = stores.get(i - 1); storeChoices[i] = stores.get(i - 1);
} }
// Create the store selection dropdown
ArrayAdapter<String> storeAdapter = new ArrayAdapter<>(root.getContext(), android.R.layout.simple_spinner_dropdown_item, storeChoices); ArrayAdapter<String> storeAdapter = new ArrayAdapter<>(root.getContext(), android.R.layout.simple_spinner_dropdown_item, storeChoices);
storeDropdown.setAdapter(storeAdapter); storeDropdown.setAdapter(storeAdapter);
storeDropdown.setSelection(this.storeSelection); storeDropdown.setSelection(this.storeSelection);
@ -80,6 +83,29 @@ public class SortDialogFragment extends DialogFragment {
} }
}); });
// Change the sort arrow to be pointing up or down based on ascending or descending
final ImageButton sortDirectionButton = root.findViewById(R.id.sort_direction_button);
if (descending) {
sortDirectionButton.setImageResource(R.drawable.ic_baseline_arrow_downward_50);
} else {
sortDirectionButton.setImageResource(R.drawable.ic_baseline_arrow_upward_50);
}
// Change array pointing direction whenever the user clicks the button
sortDirectionButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (descending) {
descending = false;
sortDirectionButton.setImageResource(R.drawable.ic_baseline_arrow_upward_50);
} else {
descending = true;
sortDirectionButton.setImageResource(R.drawable.ic_baseline_arrow_downward_50);
}
}
});
// Create the sort mode selection dropdown
Spinner sortDropdown = (Spinner) root.findViewById(R.id.sort_mode_dropdown); Spinner sortDropdown = (Spinner) root.findViewById(R.id.sort_mode_dropdown);
String[] items = new String[] {"<Default>", "Name", "Price", "Store"}; String[] items = new String[] {"<Default>", "Name", "Price", "Store"};
ArrayAdapter<String> adapter = new ArrayAdapter<>(root.getContext(), android.R.layout.simple_spinner_dropdown_item, items); ArrayAdapter<String> adapter = new ArrayAdapter<>(root.getContext(), android.R.layout.simple_spinner_dropdown_item, items);
@ -89,6 +115,13 @@ public class SortDialogFragment extends DialogFragment {
@Override @Override
public void onItemSelected(AdapterView<?> parent, View view, int position, long id) { public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
sortMode = position; sortMode = position;
// Update the sort direction button
if (position == 0) {
sortDirectionButton.setEnabled(false);
} else {
sortDirectionButton.setEnabled(true);
}
} }
@Override @Override
@ -97,21 +130,16 @@ public class SortDialogFragment extends DialogFragment {
} }
}); });
ImageButton sortDirectionButton = root.findViewById(R.id.sort_direction_button); // Disable the direction button if they have the default sorting mode selected
sortDirectionButton.setOnClickListener(new View.OnClickListener() { // Ascending and Descending are mostly irrelevant in the default sort mode
@Override if (sortDropdown.getSelectedItemPosition() == 0) {
public void onClick(View v) { sortDirectionButton.setEnabled(false);
if (descending) {
descending = false;
} else {
descending = true;
} }
}
});
return builder.create(); return builder.create();
} }
// Required to extend DialogFragment
@Override @Override
public void onAttach(@NonNull Context context) { public void onAttach(@NonNull Context context) {
super.onAttach(context); super.onAttach(context);

View File

@ -0,0 +1,5 @@
<vector android:height="50dp" android:tint="?attr/colorControlNormal"
android:viewportHeight="24" android:viewportWidth="24"
android:width="50dp" xmlns:android="http://schemas.android.com/apk/res/android">
<path android:fillColor="@android:color/white" android:pathData="M20,12l-1.41,-1.41L13,16.17V4h-2v12.17l-5.58,-5.59L4,12l8,8 8,-8z"/>
</vector>

View File

@ -0,0 +1,5 @@
<vector android:height="50dp" android:tint="?attr/colorControlNormal"
android:viewportHeight="24" android:viewportWidth="24"
android:width="50dp" xmlns:android="http://schemas.android.com/apk/res/android">
<path android:fillColor="@android:color/white" android:pathData="M4,12l1.41,1.41L11,7.83V20h2V7.83l5.58,5.59L20,12l-8,-8 -8,8z"/>
</vector>

View File

@ -2,60 +2,52 @@
android:orientation="vertical" android:orientation="vertical"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content"> android:layout_height="wrap_content">
<!-- <ImageView-->
<!-- android:src="@drawable/ic_baseline_filter_list_28"--> <TextView
<!-- android:layout_width="match_parent"--> android:id="@+id/tv_store_selection"
<!-- android:layout_height="64dp"--> android:layout_width="wrap_content"
<!-- android:scaleType="center"--> android:layout_height="0dp"
<!-- android:background="#FFFFBB33"--> android:layout_weight="1"
<!-- android:contentDescription="@string/app_name" />--> android:layout_marginTop="15dp"
<!-- <EditText--> android:layout_marginStart="15dp"
<!-- android:id="@+id/username"--> android:text="@string/store_selection" />
<!-- android:inputType="textEmailAddress"-->
<!-- android:layout_width="match_parent"-->
<!-- android:layout_height="wrap_content"-->
<!-- android:layout_marginTop="16dp"-->
<!-- android:layout_marginLeft="4dp"-->
<!-- android:layout_marginRight="4dp"-->
<!-- android:layout_marginBottom="4dp"-->
<!-- android:hint="Username" />-->
<Spinner <Spinner
android:id="@+id/sort_store_dropdown" android:id="@+id/sort_store_dropdown"
android:layout_width="260dp" android:layout_width="265dp"
android:layout_marginStart="15dp"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:background="@android:drawable/spinner_dropdown_background" android:background="@android:drawable/spinner_dropdown_background"
android:spinnerMode="dropdown"/> android:spinnerMode="dropdown"/>
<TextView
android:id="@+id/tv_sort_by"
android:layout_width="wrap_content"
android:layout_height="0dp"
android:layout_weight="1"
android:layout_marginTop="20dp"
android:layout_marginStart="15dp"
android:text="Sort by" />
<LinearLayout <LinearLayout
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="150dp" android:layout_height="100dp"
android:padding="15dp"> android:paddingStart="15dp">
<Spinner <Spinner
android:id="@+id/sort_mode_dropdown" android:id="@+id/sort_mode_dropdown"
android:layout_width="260dp" android:layout_width="265dp"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:background="@android:drawable/spinner_dropdown_background" android:background="@android:drawable/spinner_dropdown_background"
android:spinnerMode="dropdown"/> android:spinnerMode="dropdown"/>
<ImageButton <ImageButton
android:id="@+id/sort_direction_button" android:id="@+id/sort_direction_button"
android:layout_width="40dp" android:layout_marginTop="-6dp"
android:layout_height="40dp" android:layout_width="57dp"
android:src="@drawable/ic_baseline_sort_28"/> android:layout_height="70dp"
android:background="@null"
android:src="@drawable/ic_baseline_arrow_upward_50"/>
</LinearLayout> </LinearLayout>
<!-- <EditText-->
<!-- android:id="@+id/password"-->
<!-- android:inputType="textPassword"-->
<!-- android:layout_width="match_parent"-->
<!-- android:layout_height="wrap_content"-->
<!-- android:layout_marginTop="4dp"-->
<!-- android:layout_marginLeft="4dp"-->
<!-- android:layout_marginRight="4dp"-->
<!-- android:layout_marginBottom="16dp"-->
<!-- android:fontFamily="sans-serif"-->
<!-- android:hint="Password"/>-->
</LinearLayout> </LinearLayout>

View File

@ -28,4 +28,5 @@
<string name="hello_second_fragment">Hello second fragment. Arg: %1$s</string> <string name="hello_second_fragment">Hello second fragment. Arg: %1$s</string>
<string name="search_button_desc">Search Button</string> <string name="search_button_desc">Search Button</string>
<string name="title_activity_search_results">SearchResults</string> <string name="title_activity_search_results">SearchResults</string>
<string name="store_selection">Store selection</string>
</resources> </resources>