From 8f15a8c8f2765278272fbf2b5d4bb06ac4eb15f9 Mon Sep 17 00:00:00 2001 From: Jesse Young Date: Sun, 11 Sep 2011 21:21:42 -0700 Subject: [PATCH] add menu with options to test server connection, or edit settings --- res/menu/mainmenu.xml | 9 ++++++ res/values/strings.xml | 2 ++ src/org/envaya/kalsms/App.java | 1 + src/org/envaya/kalsms/Main.java | 56 +++++++++++++++++++++++++-------- 4 files changed, 55 insertions(+), 13 deletions(-) create mode 100755 res/menu/mainmenu.xml diff --git a/res/menu/mainmenu.xml b/res/menu/mainmenu.xml new file mode 100755 index 0000000..4c3ea24 --- /dev/null +++ b/res/menu/mainmenu.xml @@ -0,0 +1,9 @@ + + + + + \ No newline at end of file diff --git a/res/values/strings.xml b/res/values/strings.xml index b48bf11..12257ae 100755 --- a/res/values/strings.xml +++ b/res/values/strings.xml @@ -1,4 +1,6 @@ KalSMS Envaya + Settings + Test diff --git a/src/org/envaya/kalsms/App.java b/src/org/envaya/kalsms/App.java index de1a4b9..d5bd02f 100755 --- a/src/org/envaya/kalsms/App.java +++ b/src/org/envaya/kalsms/App.java @@ -29,6 +29,7 @@ public class App { public static final String ACTION_OUTGOING = "outgoing"; public static final String ACTION_INCOMING = "incoming"; public static final String ACTION_SEND_STATUS = "send_status"; + public static final String ACTION_TEST = "test"; public static final int STATUS_QUEUED = 1; public static final int STATUS_FAILED = 2; diff --git a/src/org/envaya/kalsms/Main.java b/src/org/envaya/kalsms/Main.java index 2ac991c..b312299 100755 --- a/src/org/envaya/kalsms/Main.java +++ b/src/org/envaya/kalsms/Main.java @@ -10,14 +10,20 @@ import android.preference.PreferenceManager; import android.text.Html; import android.text.method.ScrollingMovementMethod; import android.view.Menu; +import android.view.MenuInflater; +import android.view.MenuItem; import android.view.View; import android.widget.ScrollView; import android.widget.TextView; import java.text.DateFormat; import java.util.Date; +import org.apache.http.HttpResponse; +import org.apache.http.message.BasicNameValuePair; public class Main extends Activity { + private App app; + private BroadcastReceiver logReceiver = new BroadcastReceiver() { @Override public void onReceive(Context context, Intent intent) { @@ -25,6 +31,19 @@ public class Main extends Activity { } }; + private class TestTask extends HttpTask + { + public TestTask() { + super(app); + } + + @Override + protected void handleResponse(HttpResponse response) throws Exception + { + app.log("Server connection OK!"); + } + } + private long lastLogTime = 0; public void showLogMessage(String message) @@ -85,7 +104,7 @@ public class Main extends Activity { App.debug("STARTED"); - App app = App.getInstance(this.getApplication()); + this.app = App.getInstance(this.getApplication()); setContentView(R.layout.main); PreferenceManager.setDefaultValues(this, R.xml.prefs, false); @@ -104,25 +123,36 @@ public class Main extends Activity { logReceiverFilter.addAction(App.LOG_INTENT); registerReceiver(logReceiver, logReceiverFilter); - app.setOutgoingMessageAlarm(); - - for (int i = 0; i < 30; i++) - { - showLogMessage(" " + i); - } + app.setOutgoingMessageAlarm(); } + @Override + public boolean onOptionsItemSelected(MenuItem item) { + // Handle item selection + switch (item.getItemId()) { + case R.id.settings: + startActivity(new Intent(this, Prefs.class)); + return true; + case R.id.test: + app.log("Testing server connection..."); + new TestTask().execute( + new BasicNameValuePair("action", App.ACTION_TEST) + ); + return true; + default: + return super.onOptionsItemSelected(item); + } + } + // first time the Menu key is pressed + @Override public boolean onCreateOptionsMenu(Menu menu) { - startActivity(new Intent(this, Prefs.class)); + MenuInflater inflater = getMenuInflater(); + inflater.inflate(R.menu.mainmenu, menu); + return(true); } - // any other time the Menu key is pressed - public boolean onPrepareOptionsMenu(Menu menu) { - startActivity(new Intent(this, Prefs.class)); - return(true); - } @Override protected void onStop(){