diff --git a/res/values/strings.xml b/res/values/strings.xml
index 6aaea9f89..0fae56971 100644
--- a/res/values/strings.xml
+++ b/res/values/strings.xml
@@ -5,6 +5,7 @@
No applications were found matching \'%s\'
The new version is signed with a different key to the old one. To install the new version, the old one must be uninstalled first. Please do this and try again. (Note that uninstalling will erase any internal data stored by the application)
Android says this package is not compatible with your device. Do you want to try and install it anyway?
+ You are trying to downgrade this application. Doing so might get it to malfunction and even lose your data. Do you want to try and downgrade it anyway?
Version
%d versions available
%d version available
@@ -65,6 +66,9 @@
Available
Updates
Updates available
+ 1 update is available.
+ %d updates are available.
+ F-Droid Updates Available
Please Wait
Updating application list...
Could not connect to the network.
diff --git a/src/org/fdroid/fdroid/AppDetails.java b/src/org/fdroid/fdroid/AppDetails.java
index acf560e24..b5e301171 100644
--- a/src/org/fdroid/fdroid/AppDetails.java
+++ b/src/org/fdroid/fdroid/AppDetails.java
@@ -473,12 +473,29 @@ public class AppDetails extends ListActivity {
@Override
protected void onListItemClick(ListView l, View v, int position, long id) {
curapk = app.apks.get(position - l.getHeaderViewsCount());
- if (app.installedVersion != null
- && app.installedVersion.equals(curapk.version)) {
+ if (app.installedVerCode == curapk.vercode)
removeApk(app.id);
- } else {
+ else if (app.installedVerCode > curapk.vercode) {
+ AlertDialog.Builder ask_alrt = new AlertDialog.Builder(this);
+ ask_alrt.setMessage(getString(R.string.installDowngrade));
+ ask_alrt.setPositiveButton(getString(R.string.yes),
+ new DialogInterface.OnClickListener() {
+ public void onClick(DialogInterface dialog,
+ int whichButton) {
+ install();
+ }
+ });
+ ask_alrt.setNegativeButton(getString(R.string.no),
+ new DialogInterface.OnClickListener() {
+ public void onClick(DialogInterface dialog,
+ int whichButton) {
+ return;
+ }
+ });
+ AlertDialog alert = ask_alrt.create();
+ alert.show();
+ } else
install();
- }
}
@Override
@@ -539,7 +556,7 @@ public class AppDetails extends ListActivity {
startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse(s)));
} catch (android.content.ActivityNotFoundException e) {
Toast toast = Toast.makeText(this,
- getString(R.string.no_handler_app, s), 4);
+ getString(R.string.no_handler_app, s), Toast.LENGTH_LONG);
toast.show();
}
}
diff --git a/src/org/fdroid/fdroid/UpdateService.java b/src/org/fdroid/fdroid/UpdateService.java
index 8b02eb6d0..9228bad0f 100644
--- a/src/org/fdroid/fdroid/UpdateService.java
+++ b/src/org/fdroid/fdroid/UpdateService.java
@@ -254,20 +254,27 @@ public class UpdateService extends IntentService implements ProgressListener {
Log.d("FDroid", "Notifying updates. Apps before:" + prevUpdates
+ ", apps after: " + newUpdates);
if (newUpdates > prevUpdates) {
- NotificationManager n = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
- Notification notification = new Notification(
- R.drawable.icon, "F-Droid Updates Available",
+ NotificationManager n = (NotificationManager) getSystemService(
+ Context.NOTIFICATION_SERVICE);
+ Notification notification = new Notification(R.drawable.icon,
+ getString(R.string.fdroid_updates_available),
System.currentTimeMillis());
Context context = getApplicationContext();
- CharSequence contentTitle = "F-Droid";
- CharSequence contentText = "Updates are available.";
Intent notificationIntent = new Intent(UpdateService.this,
FDroid.class);
notificationIntent.putExtra(FDroid.EXTRA_TAB_UPDATE, true);
PendingIntent contentIntent = PendingIntent.getActivity(
UpdateService.this, 0, notificationIntent, 0);
- notification.setLatestEventInfo(context, contentTitle,
- contentText, contentIntent);
+ CharSequence notification_text;
+ if (newUpdates > 1)
+ notification_text = getString(
+ R.string.many_updates_available, newUpdates);
+ else
+ notification_text = getString(
+ R.string.one_update_available);
+ notification.setLatestEventInfo(context,
+ getString(R.string.app_name),
+ notification_text, contentIntent);
notification.flags |= Notification.FLAG_AUTO_CANCEL;
n.notify(1, notification);
}