diff --git a/app/src/main/java/org/fdroid/fdroid/views/apps/AppListActivity.java b/app/src/main/java/org/fdroid/fdroid/views/apps/AppListActivity.java index 2d8b75353..de8ea509a 100644 --- a/app/src/main/java/org/fdroid/fdroid/views/apps/AppListActivity.java +++ b/app/src/main/java/org/fdroid/fdroid/views/apps/AppListActivity.java @@ -16,7 +16,9 @@ import android.view.View; import android.view.inputmethod.EditorInfo; import android.view.inputmethod.InputMethodManager; import android.widget.EditText; +import android.widget.ImageView; import android.widget.TextView; + import org.fdroid.fdroid.FDroidApp; import org.fdroid.fdroid.R; import org.fdroid.fdroid.data.AppProvider; @@ -34,8 +36,15 @@ public class AppListActivity extends AppCompatActivity implements LoaderManager. private AppListAdapter appAdapter; private String category; private String searchTerms; + private String sortClauseSelected = SortClause.LAST_UPDATED; private TextView emptyState; private EditText searchInput; + private ImageView sortImage; + + private interface SortClause { + String NAME = Schema.AppMetadataTable.NAME + "." + Schema.AppMetadataTable.Cols.NAME + " asc"; + String LAST_UPDATED = Schema.AppMetadataTable.NAME + "." + Schema.AppMetadataTable.Cols.LAST_UPDATED + " desc"; + } @Override protected void onCreate(@Nullable Bundle savedInstanceState) { @@ -62,6 +71,22 @@ public class AppListActivity extends AppCompatActivity implements LoaderManager. } }); + sortImage = (ImageView) findViewById(R.id.sort); + sortImage.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View view) { + if (sortClauseSelected.equalsIgnoreCase(SortClause.LAST_UPDATED)) { + sortClauseSelected = SortClause.NAME; + sortImage.setImageResource(R.drawable.ic_az_black); + } else { + sortClauseSelected = SortClause.LAST_UPDATED; + sortImage.setImageResource(R.drawable.ic_last_updated_black); + } + getSupportLoaderManager().restartLoader(0, null, AppListActivity.this ); + appView.scrollToPosition(0); + } + }); + emptyState = (TextView) findViewById(R.id.empty_state); View backButton = findViewById(R.id.back); @@ -128,7 +153,7 @@ public class AppListActivity extends AppCompatActivity implements LoaderManager. Schema.AppMetadataTable.Cols.ALL, null, null, - Schema.AppMetadataTable.Cols.NAME + sortClauseSelected ); } diff --git a/app/src/main/res/layout/activity_app_list.xml b/app/src/main/res/layout/activity_app_list.xml index fa12d3ac8..98e6def4b 100644 --- a/app/src/main/res/layout/activity_app_list.xml +++ b/app/src/main/res/layout/activity_app_list.xml @@ -18,20 +18,21 @@ + android:paddingStart="8dp" + android:paddingLeft="8dp" + android:paddingEnd="8dp" + android:paddingRight="8dp"> + app:layout_constraintTop_toTopOf="parent"/> + + + app:layout_constraintStart_toEndOf="@+id/clear" + app:layout_constraintTop_toTopOf="parent"/> diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index f4377daa8..4dbbbedc8 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -128,6 +128,7 @@ This often occurs with apps installed via Google Play or other sources, if they Add Key Overwrite Clear search + Sort search No Bluetooth send method found, choose one! Choose Bluetooth send method