summaryrefslogtreecommitdiff
path: root/src/org
diff options
context:
space:
mode:
authorAndrew Dolgov <[email protected]>2012-01-10 15:13:58 +0400
committerAndrew Dolgov <[email protected]>2012-01-10 15:13:58 +0400
commit7f34760c3cbc00c6068639775fdf59d17df37ec0 (patch)
tree9d1cae192e7ed78d98cf8d4d50e962300d4e9529 /src/org
parent055707ce678058179bda1656860211e7a6e8c5e3 (diff)
parent27161555137065b114a97e8ce5c0b31e45e8c76b (diff)
Merge branch 'master' of github.com:gothfox/Tiny-Tiny-RSS-for-Honeycomb
Diffstat (limited to 'src/org')
-rw-r--r--src/org/fox/ttrss/Label.java9
-rw-r--r--src/org/fox/ttrss/MainActivity.java92
-rw-r--r--src/org/fox/ttrss/OfflineActivity.java8
3 files changed, 99 insertions, 10 deletions
diff --git a/src/org/fox/ttrss/Label.java b/src/org/fox/ttrss/Label.java
new file mode 100644
index 00000000..eccc1e66
--- /dev/null
+++ b/src/org/fox/ttrss/Label.java
@@ -0,0 +1,9 @@
+package org.fox.ttrss;
+
+public class Label {
+ int id;
+ String caption;
+ String fg_color;
+ String bg_color;
+ boolean checked;
+}
diff --git a/src/org/fox/ttrss/MainActivity.java b/src/org/fox/ttrss/MainActivity.java
index c4df46a4..3a439733 100644
--- a/src/org/fox/ttrss/MainActivity.java
+++ b/src/org/fox/ttrss/MainActivity.java
@@ -1,5 +1,7 @@
package org.fox.ttrss;
+import java.lang.reflect.Type;
+import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Timer;
@@ -13,6 +15,8 @@ import android.app.Dialog;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.DialogInterface;
+import android.content.DialogInterface.OnClickListener;
+import android.content.DialogInterface.OnMultiChoiceClickListener;
import android.content.Intent;
import android.content.IntentFilter;
import android.content.SharedPreferences;
@@ -40,8 +44,10 @@ import android.widget.LinearLayout;
import android.widget.TextView;
import android.widget.Toast;
+import com.google.gson.Gson;
import com.google.gson.JsonElement;
import com.google.gson.JsonObject;
+import com.google.gson.reflect.TypeToken;
public class MainActivity extends FragmentActivity implements OnlineServices {
private final String TAG = this.getClass().getSimpleName();
@@ -469,12 +475,12 @@ public class MainActivity extends FragmentActivity implements OnlineServices {
int height = display.getHeight();
if (height > width) {
- int tmp = height;
- width = tmp;
- height = width;
+ int tmp = width;
+ width = height;
+ height = tmp;
}
-
- m_smallScreenMode = width < 960 || height < 720;
+
+ m_smallScreenMode = m_compatMode || (width < 960 || height < 720);
setContentView(R.layout.main);
@@ -1030,6 +1036,78 @@ public class MainActivity extends FragmentActivity implements OnlineServices {
*
* return true;
*/
+ case R.id.set_labels:
+ if (m_selectedArticle != null) {
+
+ ApiRequest req = new ApiRequest(getApplicationContext()) {
+ @Override
+ protected void onPostExecute(JsonElement result) {
+ if (result != null) {
+ Type listType = new TypeToken<List<Label>>() {}.getType();
+ final List<Label> labels = new Gson().fromJson(result, listType);
+
+ CharSequence[] items = new CharSequence[labels.size()];
+ final int[] itemIds = new int[labels.size()];
+ boolean[] checkedItems = new boolean[labels.size()];
+
+ for (int i = 0; i < labels.size(); i++) {
+ items[i] = labels.get(i).caption;
+ itemIds[i] = labels.get(i).id;
+ checkedItems[i] = labels.get(i).checked;
+ }
+
+ Dialog dialog = new Dialog(MainActivity.this);
+ AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this)
+ .setTitle("Set labels")
+ .setMultiChoiceItems(items, checkedItems, new OnMultiChoiceClickListener() {
+
+ @Override
+ public void onClick(DialogInterface dialog, int which, final boolean isChecked) {
+ final int labelId = itemIds[which];
+
+ @SuppressWarnings("serial")
+ HashMap<String, String> map = new HashMap<String, String>() {
+ {
+ put("sid", m_sessionId);
+ put("op", "setArticleLabel");
+ put("label_id", String.valueOf(labelId));
+ put("article_ids", String.valueOf(m_selectedArticle.id));
+ if (isChecked) put("assign", "true");
+ }
+ };
+
+ ApiRequest req = new ApiRequest(m_context);
+ req.execute(map);
+
+ }
+ }).setPositiveButton("Close", new OnClickListener() {
+
+ @Override
+ public void onClick(DialogInterface dialog, int which) {
+ dialog.cancel();
+ }
+ });
+
+ dialog = builder.create();
+ dialog.show();
+
+ }
+ }
+ };
+
+ @SuppressWarnings("serial")
+ HashMap<String, String> map = new HashMap<String, String>() {
+ {
+ put("sid", m_sessionId);
+ put("op", "getLabels");
+ put("article_id", String.valueOf(m_selectedArticle.id));
+ }
+ };
+
+ req.execute(map);
+
+ }
+ return true;
default:
Log.d(TAG,
"onOptionsItemSelected, unhandled id=" + item.getItemId());
@@ -1046,7 +1124,7 @@ public class MainActivity extends FragmentActivity implements OnlineServices {
intent.putExtra(Intent.EXTRA_TEXT, article.link);
startActivity(Intent.createChooser(intent,
- getString(R.id.share_article)));
+ getString(R.string.share_article)));
}
}
@@ -1133,6 +1211,8 @@ public class MainActivity extends FragmentActivity implements OnlineServices {
getActionBar().setDisplayHomeAsUpEnabled(m_selectedArticle != null);
}
+ m_menu.findItem(R.id.set_labels).setEnabled(m_apiLevel >= 1);
+
} else {
m_menu.setGroupVisible(R.id.menu_group_logged_in, false);
m_menu.setGroupVisible(R.id.menu_group_logged_out, true);
diff --git a/src/org/fox/ttrss/OfflineActivity.java b/src/org/fox/ttrss/OfflineActivity.java
index a03dbbf9..fb7a9ad5 100644
--- a/src/org/fox/ttrss/OfflineActivity.java
+++ b/src/org/fox/ttrss/OfflineActivity.java
@@ -125,12 +125,12 @@ public class OfflineActivity extends FragmentActivity implements
int height = display.getHeight();
if (height > width) {
- int tmp = height;
- width = tmp;
- height = width;
+ int tmp = width;
+ width = height;
+ height = tmp;
}
- m_smallScreenMode = width < 960 || height < 720;
+ m_smallScreenMode = m_compatMode || (width < 960 || height < 720);
setContentView(R.layout.main);