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