subscribe dialog: support multiple feed results

This commit is contained in:
Andrew Dolgov 2015-06-08 13:35:54 +03:00
parent c0f1d4a1a9
commit 89baa99ea5
3 changed files with 95 additions and 16 deletions

View File

@ -1,8 +1,8 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android" <manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="org.fox.ttrss" package="org.fox.ttrss"
android:versionCode="343" android:versionCode="344"
android:versionName="1.117" > android:versionName="1.118" >
<uses-sdk <uses-sdk
android:minSdkVersion="15" android:minSdkVersion="15"

View File

@ -5,6 +5,7 @@ import android.content.Intent;
import android.os.Bundle; import android.os.Bundle;
import android.view.View; import android.view.View;
import android.view.Window; import android.view.Window;
import android.widget.AdapterView;
import android.widget.ArrayAdapter; import android.widget.ArrayAdapter;
import android.widget.Button; import android.widget.Button;
import android.widget.EditText; import android.widget.EditText;
@ -14,6 +15,7 @@ import android.widget.Spinner;
import com.google.gson.Gson; import com.google.gson.Gson;
import com.google.gson.JsonArray; import com.google.gson.JsonArray;
import com.google.gson.JsonElement; import com.google.gson.JsonElement;
import com.google.gson.JsonObject;
import com.google.gson.reflect.TypeToken; import com.google.gson.reflect.TypeToken;
import org.fox.ttrss.ApiRequest; import org.fox.ttrss.ApiRequest;
@ -27,14 +29,17 @@ import java.util.Collections;
import java.util.Comparator; import java.util.Comparator;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map;
public class SubscribeActivity extends CommonShareActivity { public class SubscribeActivity extends CommonShareActivity {
private final String TAG = this.getClass().getSimpleName(); private final String TAG = this.getClass().getSimpleName();
private Button m_postButton; private Button m_postButton;
private Button m_catButton; private Button m_catButton;
private CatListAdapter m_adapter; private CatListAdapter m_catAdapter;
private FeedListAdapter m_feedAdapter;
private FeedCategoryList m_cats = new FeedCategoryList(); private FeedCategoryList m_cats = new FeedCategoryList();
private ArrayList<Map.Entry<String, JsonElement>> m_feeds = new ArrayList<Map.Entry<String, JsonElement>>();
private ProgressBar m_progressBar; private ProgressBar m_progressBar;
private static final int REQ_CATS = 1; private static final int REQ_CATS = 1;
@ -57,7 +62,7 @@ public class SubscribeActivity extends CommonShareActivity {
Collections.sort(m_cats, cmp); Collections.sort(m_cats, cmp);
try { try {
m_adapter.notifyDataSetChanged(); m_catAdapter.notifyDataSetChanged();
} catch (NullPointerException e) { } catch (NullPointerException e) {
// adapter missing // adapter missing
} }
@ -79,8 +84,7 @@ public class SubscribeActivity extends CommonShareActivity {
ArrayList<FeedCategory> list = savedInstanceState.getParcelableArrayList("cats"); ArrayList<FeedCategory> list = savedInstanceState.getParcelableArrayList("cats");
for (FeedCategory c : list) m_cats.addAll(list);
m_cats.add(c);
} }
setContentView(R.layout.subscribe); setContentView(R.layout.subscribe);
@ -94,8 +98,30 @@ public class SubscribeActivity extends CommonShareActivity {
if (m_cats.size() == 0) m_cats.add(new FeedCategory(0, "Uncategorized", 0)); if (m_cats.size() == 0) m_cats.add(new FeedCategory(0, "Uncategorized", 0));
m_adapter = new CatListAdapter(this, android.R.layout.simple_spinner_dropdown_item, m_cats); m_catAdapter = new CatListAdapter(this, android.R.layout.simple_spinner_dropdown_item, m_cats);
catList.setAdapter(m_adapter); catList.setAdapter(m_catAdapter);
final Spinner feedList = (Spinner) findViewById(R.id.feed_spinner);
feedList.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
@Override
public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
String feed = m_feedAdapter.getItemURL(position);
EditText feedUrl = (EditText) findViewById(R.id.feed_url);
if (feed != null && feedUrl != null) {
feedUrl.setText(feed);
}
}
@Override
public void onNothingSelected(AdapterView<?> parent) {
}
});
m_feedAdapter = new FeedListAdapter(this, android.R.layout.simple_spinner_dropdown_item, m_feeds);
feedList.setAdapter(m_feedAdapter);
EditText feedUrl = (EditText) findViewById(R.id.feed_url); EditText feedUrl = (EditText) findViewById(R.id.feed_url);
feedUrl.setText(urlValue); feedUrl.setText(urlValue);
@ -174,7 +200,22 @@ public class SubscribeActivity extends CommonShareActivity {
toast(R.string.error_url_is_an_html_page_no_feeds_found); toast(R.string.error_url_is_an_html_page_no_feeds_found);
break; break;
case 4: case 4:
toast(R.string.error_url_contains_multiple_feeds); //toast(R.string.error_url_contains_multiple_feeds);
JsonObject feeds = result.getAsJsonObject().get("status").getAsJsonObject().get("feeds").getAsJsonObject();
if (feeds != null) {
m_feeds.clear();
m_feeds.addAll(feeds.entrySet());
m_feedAdapter.notifyDataSetChanged();
findViewById(R.id.feed_spinner).setVisibility(View.VISIBLE);
} else {
toast(R.string.error_while_subscribing);
}
break; break;
case 5: case 5:
toast(R.string.error_could_not_download_url); toast(R.string.error_could_not_download_url);
@ -193,7 +234,7 @@ public class SubscribeActivity extends CommonShareActivity {
Spinner catSpinner = (Spinner) findViewById(R.id.category_spinner); Spinner catSpinner = (Spinner) findViewById(R.id.category_spinner);
final FeedCategory cat = (FeedCategory) m_adapter.getCategory(catSpinner.getSelectedItemPosition()); final FeedCategory cat = (FeedCategory) m_catAdapter.getCategory(catSpinner.getSelectedItemPosition());
final EditText feedUrl = (EditText) findViewById(R.id.feed_url); final EditText feedUrl = (EditText) findViewById(R.id.feed_url);
if (feedUrl != null ) { if (feedUrl != null ) {
@ -252,7 +293,7 @@ public class SubscribeActivity extends CommonShareActivity {
m_cats.add(0, new FeedCategory(0, "Uncategorized", 0)); m_cats.add(0, new FeedCategory(0, "Uncategorized", 0));
m_adapter.notifyDataSetChanged(); m_catAdapter.notifyDataSetChanged();
toast(R.string.category_list_updated); toast(R.string.category_list_updated);
} }
@ -320,4 +361,32 @@ public class SubscribeActivity extends CommonShareActivity {
} }
} }
private class FeedListAdapter extends ArrayAdapter<String> {
private List<Map.Entry<String, JsonElement>> m_items;
public FeedListAdapter(Context context, int resource, List<Map.Entry<String, JsonElement>> items) {
super(context, resource);
m_items = items;
}
@Override
public String getItem(int item) {
return m_items.get(item).getValue().getAsString();
}
public String getItemURL(int item) {
try {
return m_items.get(item).getKey();
} catch (ArrayIndexOutOfBoundsException e) {
return null;
}
}
@Override
public int getCount() {
return m_items.size();
}
}
} }

View File

@ -2,6 +2,7 @@
android:id="@+id/main" android:id="@+id/main"
android:layout_width="fill_parent" android:layout_width="fill_parent"
android:layout_height="fill_parent" android:layout_height="fill_parent"
android:animateLayoutChanges="true"
android:padding="@dimen/activity_horizontal_margin" > android:padding="@dimen/activity_horizontal_margin" >
<EditText <EditText
@ -13,19 +14,28 @@
android:ems="10" android:ems="10"
android:hint="@string/feed_url" android:hint="@string/feed_url"
android:inputType="textUri" android:inputType="textUri"
android:maxLines="3" > android:maxLines="1" >
<requestFocus /> <requestFocus />
</EditText> </EditText>
<Spinner <Spinner
android:id="@+id/category_spinner" android:id="@+id/feed_spinner"
android:visibility="gone"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_alignLeft="@+id/feed_url" android:layout_alignLeft="@+id/feed_url"
android:layout_alignParentRight="true" android:layout_alignParentRight="true"
android:layout_below="@+id/feed_url" /> android:layout_below="@+id/feed_url" />
<Spinner
android:id="@+id/category_spinner"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/feed_spinner"
android:layout_alignParentRight="true"
android:layout_below="@+id/feed_spinner" />
<ProgressBar <ProgressBar
style="?android:attr/progressBarStyleHorizontal" style="?android:attr/progressBarStyleHorizontal"
android:layout_below="@+id/category_spinner" android:layout_below="@+id/category_spinner"