mirror of
https://github.com/moparisthebest/android-app
synced 2024-11-15 13:25:07 -05:00
Merge pull request #47 from kevmeyer/rss-feed
Updating ActionBarTheme, added error messages
This commit is contained in:
commit
ba95bea59a
1
.gitignore
vendored
1
.gitignore
vendored
@ -10,5 +10,4 @@ gen/
|
|||||||
.idea/
|
.idea/
|
||||||
.gradle/
|
.gradle/
|
||||||
build/
|
build/
|
||||||
gradle/
|
|
||||||
local.properties
|
local.properties
|
||||||
|
26
.travis.yml
Normal file
26
.travis.yml
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
language: android
|
||||||
|
android:
|
||||||
|
components:
|
||||||
|
# Uncomment the lines below if you want to
|
||||||
|
# use the latest revision of Android SDK Tools
|
||||||
|
- platform-tools
|
||||||
|
- tools
|
||||||
|
|
||||||
|
# The BuildTools version used by your project
|
||||||
|
- build-tools-21.0.0
|
||||||
|
|
||||||
|
# The SDK version used to compile your project
|
||||||
|
- android-21
|
||||||
|
|
||||||
|
# Additional components
|
||||||
|
# - extra-google-google_play_services
|
||||||
|
# - extra-google-m2repository
|
||||||
|
# - extra-android-m2repository
|
||||||
|
# - addon-google_apis-google-19
|
||||||
|
|
||||||
|
# Specify at least one system image,
|
||||||
|
# if you need to run emulator(s) during your tests
|
||||||
|
# - sys-img-armeabi-v7a-android-19
|
||||||
|
# - sys-img-x86-android-17
|
||||||
|
|
||||||
|
script: ./gradlew build check
|
@ -1,3 +1,5 @@
|
|||||||
|
# wallabag - Android App [![Build Status](https://travis-ci.org/wallabag/android-app.svg?branch=rss-feed)](https://travis-ci.org/wallabag/android-app)
|
||||||
|
|
||||||
wallabag app for Android, originally written by Jonathan GAULUPEAU <jo.gaulupeau-at-gmail.com>
|
wallabag app for Android, originally written by Jonathan GAULUPEAU <jo.gaulupeau-at-gmail.com>
|
||||||
|
|
||||||
Android application to add post to wallabag <https://www.wallabag.org>
|
Android application to add post to wallabag <https://www.wallabag.org>
|
15
app/app.iml
15
app/app.iml
@ -13,6 +13,7 @@
|
|||||||
<option name="COMPILE_JAVA_TASK_NAME" value="compileDebugJava" />
|
<option name="COMPILE_JAVA_TASK_NAME" value="compileDebugJava" />
|
||||||
<option name="ASSEMBLE_TEST_TASK_NAME" value="assembleDebugTest" />
|
<option name="ASSEMBLE_TEST_TASK_NAME" value="assembleDebugTest" />
|
||||||
<option name="SOURCE_GEN_TASK_NAME" value="generateDebugSources" />
|
<option name="SOURCE_GEN_TASK_NAME" value="generateDebugSources" />
|
||||||
|
<option name="TEST_SOURCE_GEN_TASK_NAME" value="generateDebugTestSources" />
|
||||||
<option name="ALLOW_USER_CONFIGURATION" value="false" />
|
<option name="ALLOW_USER_CONFIGURATION" value="false" />
|
||||||
<option name="MANIFEST_FILE_RELATIVE_PATH" value="/src/main/AndroidManifest.xml" />
|
<option name="MANIFEST_FILE_RELATIVE_PATH" value="/src/main/AndroidManifest.xml" />
|
||||||
<option name="RES_FOLDER_RELATIVE_PATH" value="/src/main/res" />
|
<option name="RES_FOLDER_RELATIVE_PATH" value="/src/main/res" />
|
||||||
@ -37,22 +38,22 @@
|
|||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/res/rs/test/debug" type="java-test-resource" />
|
<sourceFolder url="file://$MODULE_DIR$/build/generated/res/rs/test/debug" type="java-test-resource" />
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/res" type="java-resource" />
|
<sourceFolder url="file://$MODULE_DIR$/src/debug/res" type="java-resource" />
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/resources" type="java-resource" />
|
<sourceFolder url="file://$MODULE_DIR$/src/debug/resources" type="java-resource" />
|
||||||
|
<sourceFolder url="file://$MODULE_DIR$/src/debug/assets" type="java-resource" />
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/aidl" isTestSource="false" />
|
<sourceFolder url="file://$MODULE_DIR$/src/debug/aidl" isTestSource="false" />
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/assets" isTestSource="false" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/java" isTestSource="false" />
|
<sourceFolder url="file://$MODULE_DIR$/src/debug/java" isTestSource="false" />
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/jni" isTestSource="false" />
|
<sourceFolder url="file://$MODULE_DIR$/src/debug/jni" isTestSource="false" />
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/rs" isTestSource="false" />
|
<sourceFolder url="file://$MODULE_DIR$/src/debug/rs" isTestSource="false" />
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/res" type="java-resource" />
|
<sourceFolder url="file://$MODULE_DIR$/src/main/res" type="java-resource" />
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/resources" type="java-resource" />
|
<sourceFolder url="file://$MODULE_DIR$/src/main/resources" type="java-resource" />
|
||||||
|
<sourceFolder url="file://$MODULE_DIR$/src/main/assets" type="java-resource" />
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/aidl" isTestSource="false" />
|
<sourceFolder url="file://$MODULE_DIR$/src/main/aidl" isTestSource="false" />
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/assets" isTestSource="false" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/java" isTestSource="false" />
|
<sourceFolder url="file://$MODULE_DIR$/src/main/java" isTestSource="false" />
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/jni" isTestSource="false" />
|
<sourceFolder url="file://$MODULE_DIR$/src/main/jni" isTestSource="false" />
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/rs" isTestSource="false" />
|
<sourceFolder url="file://$MODULE_DIR$/src/main/rs" isTestSource="false" />
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/res" type="java-test-resource" />
|
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/res" type="java-test-resource" />
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/resources" type="java-test-resource" />
|
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/resources" type="java-test-resource" />
|
||||||
|
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/assets" type="java-test-resource" />
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/aidl" isTestSource="true" />
|
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/aidl" isTestSource="true" />
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/assets" isTestSource="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/java" isTestSource="true" />
|
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/java" isTestSource="true" />
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/jni" isTestSource="true" />
|
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/jni" isTestSource="true" />
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/rs" isTestSource="true" />
|
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/rs" isTestSource="true" />
|
||||||
@ -77,11 +78,11 @@
|
|||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/symbols" />
|
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/symbols" />
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/outputs" />
|
<excludeFolder url="file://$MODULE_DIR$/build/outputs" />
|
||||||
</content>
|
</content>
|
||||||
<orderEntry type="jdk" jdkName="Android API 20 Platform" jdkType="Android SDK" />
|
<orderEntry type="jdk" jdkName="Android API 21 Platform" jdkType="Android SDK" />
|
||||||
<orderEntry type="sourceFolder" forTests="false" />
|
<orderEntry type="sourceFolder" forTests="false" />
|
||||||
<orderEntry type="library" exported="" name="appcompat-v7-20.0.0" level="project" />
|
<orderEntry type="library" exported="" name="support-annotations-21.0.0" level="project" />
|
||||||
<orderEntry type="library" exported="" name="support-annotations-20.0.0" level="project" />
|
<orderEntry type="library" exported="" name="support-v4-21.0.0" level="project" />
|
||||||
<orderEntry type="library" exported="" name="support-v4-20.0.0" level="project" />
|
<orderEntry type="library" exported="" name="appcompat-v7-21.0.0" level="project" />
|
||||||
</component>
|
</component>
|
||||||
</module>
|
</module>
|
||||||
|
|
||||||
|
@ -1,13 +1,13 @@
|
|||||||
apply plugin: 'com.android.application'
|
apply plugin: 'com.android.application'
|
||||||
|
|
||||||
android {
|
android {
|
||||||
compileSdkVersion 20
|
compileSdkVersion 21
|
||||||
buildToolsVersion '20'
|
buildToolsVersion '21'
|
||||||
|
|
||||||
defaultConfig {
|
defaultConfig {
|
||||||
applicationId "fr.gaulupeau.apps.InThePoche"
|
applicationId "fr.gaulupeau.apps.InThePoche"
|
||||||
minSdkVersion 8
|
minSdkVersion 8
|
||||||
targetSdkVersion 20
|
targetSdkVersion 21
|
||||||
versionCode 9
|
versionCode 9
|
||||||
versionName "1.6"
|
versionName "1.6"
|
||||||
}
|
}
|
||||||
@ -20,5 +20,5 @@ android {
|
|||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
compile 'com.android.support:appcompat-v7:20.0.0'
|
compile 'com.android.support:appcompat-v7:21.0.0'
|
||||||
}
|
}
|
||||||
|
@ -1,18 +1,35 @@
|
|||||||
package fr.gaulupeau.apps.Poche;
|
package fr.gaulupeau.apps.Poche;
|
||||||
|
|
||||||
public class Article {
|
import java.net.URL;
|
||||||
public String url;
|
|
||||||
public String id;
|
|
||||||
public String title;
|
|
||||||
public String content;
|
|
||||||
public String archive;
|
|
||||||
|
|
||||||
public Article(String url, String id, String title, String content, String archive) {
|
public class Article {
|
||||||
super();
|
public String url;
|
||||||
this.url = url;
|
public String id;
|
||||||
this.id = id;
|
public String title;
|
||||||
this.title = title;
|
public String content;
|
||||||
this.content = content;
|
public String archive;
|
||||||
this.archive = archive;
|
|
||||||
}
|
private URL m_url = null;
|
||||||
|
|
||||||
|
public Article(String url, String id, String title, String content, String archive) {
|
||||||
|
super();
|
||||||
|
this.url = url;
|
||||||
|
this.id = id;
|
||||||
|
this.title = title;
|
||||||
|
this.content = content;
|
||||||
|
this.archive = archive;
|
||||||
|
|
||||||
|
try {
|
||||||
|
this.m_url = new URL(url);
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getHostOfUrl() {
|
||||||
|
if (this.m_url != null) {
|
||||||
|
return m_url.getHost();
|
||||||
|
}
|
||||||
|
return "";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -4,6 +4,7 @@ import android.content.Context;
|
|||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
import android.database.sqlite.SQLiteDatabase;
|
import android.database.sqlite.SQLiteDatabase;
|
||||||
import android.database.sqlite.SQLiteOpenHelper;
|
import android.database.sqlite.SQLiteOpenHelper;
|
||||||
|
|
||||||
import static fr.gaulupeau.apps.Poche.Helpers.PREFS_NAME;
|
import static fr.gaulupeau.apps.Poche.Helpers.PREFS_NAME;
|
||||||
import static fr.gaulupeau.apps.Poche.Helpers.zeroUpdate;
|
import static fr.gaulupeau.apps.Poche.Helpers.zeroUpdate;
|
||||||
|
|
||||||
@ -11,68 +12,68 @@ import static fr.gaulupeau.apps.Poche.Helpers.zeroUpdate;
|
|||||||
public class ArticlesSQLiteOpenHelper extends SQLiteOpenHelper {
|
public class ArticlesSQLiteOpenHelper extends SQLiteOpenHelper {
|
||||||
|
|
||||||
|
|
||||||
public static final int VERSION = 1;
|
public static final int VERSION = 1;
|
||||||
public static final String DB_NAME = "article_db.sqlite";
|
public static final String DB_NAME = "article_db.sqlite";
|
||||||
public static String MY_ID = "my_id";
|
public static String MY_ID = "my_id";
|
||||||
public static String ARTICLE_TABLE = "article";
|
public static String ARTICLE_TABLE = "article";
|
||||||
public static String ARTICLE_DATE = "update_date";
|
public static String ARTICLE_DATE = "update_date";
|
||||||
public static String ARTICLE_ID = "article_id";
|
public static String ARTICLE_ID = "article_id";
|
||||||
public static String ARTICLE_AUTHOR = "author";
|
public static String ARTICLE_AUTHOR = "author";
|
||||||
public static String ARTICLE_CONTENT = "content";
|
public static String ARTICLE_CONTENT = "content";
|
||||||
public static String ARTICLE_TITLE = "title";
|
public static String ARTICLE_TITLE = "title";
|
||||||
public static String ARTICLE_URL = "url";
|
public static String ARTICLE_URL = "url";
|
||||||
public static String ARCHIVE = "archive";
|
public static String ARCHIVE = "archive";
|
||||||
public static String ARTICLE_SYNC = "sync";
|
public static String ARTICLE_SYNC = "sync";
|
||||||
public static String ARTICLE_READAT = "read_at";
|
public static String ARTICLE_READAT = "read_at";
|
||||||
Context c;
|
Context c;
|
||||||
|
|
||||||
public ArticlesSQLiteOpenHelper(Context context) {
|
public ArticlesSQLiteOpenHelper(Context context) {
|
||||||
super(context, DB_NAME, null, VERSION);
|
super(context, DB_NAME, null, VERSION);
|
||||||
c = context;
|
c = context;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCreate(SQLiteDatabase db) {
|
public void onCreate(SQLiteDatabase db) {
|
||||||
createTables(db);
|
createTables(db);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onOpen(SQLiteDatabase db) {
|
public void onOpen(SQLiteDatabase db) {
|
||||||
// TODO Auto-generated method stub
|
// TODO Auto-generated method stub
|
||||||
super.onOpen(db);
|
super.onOpen(db);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
|
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
|
||||||
db.delete(ARTICLE_TABLE, null, null);
|
db.delete(ARTICLE_TABLE, null, null);
|
||||||
SharedPreferences preferences = c.getSharedPreferences(PREFS_NAME, 0);
|
SharedPreferences preferences = c.getSharedPreferences(PREFS_NAME, 0);
|
||||||
SharedPreferences.Editor editor = preferences.edit();
|
SharedPreferences.Editor editor = preferences.edit();
|
||||||
editor.putString("previous_update", zeroUpdate);
|
editor.putString("previous_update", zeroUpdate);
|
||||||
editor.commit();
|
editor.commit();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void createTables(SQLiteDatabase db) {
|
protected void createTables(SQLiteDatabase db) {
|
||||||
db.execSQL(
|
db.execSQL(
|
||||||
"create table " + ARTICLE_TABLE + " (" +
|
"create table " + ARTICLE_TABLE + " (" +
|
||||||
MY_ID + " integer primary key autoincrement not null, " +
|
MY_ID + " integer primary key autoincrement not null, " +
|
||||||
ARTICLE_AUTHOR + " text, " +
|
ARTICLE_AUTHOR + " text, " +
|
||||||
ARTICLE_DATE + " datetime, " +
|
ARTICLE_DATE + " datetime, " +
|
||||||
ARTICLE_CONTENT + " text, " +
|
ARTICLE_CONTENT + " text, " +
|
||||||
ARTICLE_TITLE + " text, " +
|
ARTICLE_TITLE + " text, " +
|
||||||
ARTICLE_URL + " text, " +
|
ARTICLE_URL + " text, " +
|
||||||
ARTICLE_ID + " integer, " +
|
ARTICLE_ID + " integer, " +
|
||||||
ARCHIVE + " integer," +
|
ARCHIVE + " integer," +
|
||||||
ARTICLE_SYNC + " integer," +
|
ARTICLE_SYNC + " integer," +
|
||||||
ARTICLE_READAT + " integer," +
|
ARTICLE_READAT + " integer," +
|
||||||
"UNIQUE (" + ARTICLE_URL + ")" +
|
"UNIQUE (" + ARTICLE_URL + ")" +
|
||||||
");"
|
");"
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void truncateTables(SQLiteDatabase db) {
|
public void truncateTables(SQLiteDatabase db) {
|
||||||
db.execSQL("DELETE FROM " + ARTICLE_TABLE + ";");
|
db.execSQL("DELETE FROM " + ARTICLE_TABLE + ";");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,37 @@
|
|||||||
|
package fr.gaulupeau.apps.Poche;
|
||||||
|
|
||||||
|
|
||||||
|
import android.annotation.TargetApi;
|
||||||
|
import android.os.Build;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.support.v7.app.ActionBarActivity;
|
||||||
|
import android.view.MenuItem;
|
||||||
|
|
||||||
|
public class BaseActionBarActivity extends ActionBarActivity {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
addBackButtonToActionBar();
|
||||||
|
}
|
||||||
|
|
||||||
|
@TargetApi(11)
|
||||||
|
protected void addBackButtonToActionBar() {
|
||||||
|
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
|
||||||
|
try {
|
||||||
|
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
|
||||||
|
} catch (Exception e) {
|
||||||
|
//
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onOptionsItemSelected(MenuItem item) {
|
||||||
|
if (item.getItemId() == android.R.id.home) {
|
||||||
|
this.finish();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return super.onOptionsItemSelected(item);
|
||||||
|
}
|
||||||
|
}
|
@ -1,36 +1,32 @@
|
|||||||
package fr.gaulupeau.apps.Poche;
|
package fr.gaulupeau.apps.Poche;
|
||||||
|
|
||||||
import java.io.BufferedReader;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.InputStream;
|
|
||||||
import java.io.InputStreamReader;
|
|
||||||
|
|
||||||
import org.apache.http.HttpResponse;
|
import org.apache.http.HttpResponse;
|
||||||
import org.apache.http.client.HttpClient;
|
import org.apache.http.client.HttpClient;
|
||||||
import org.apache.http.client.methods.HttpGet;
|
import org.apache.http.client.methods.HttpGet;
|
||||||
import org.apache.http.impl.client.DefaultHttpClient;
|
import org.apache.http.impl.client.DefaultHttpClient;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.io.InputStreamReader;
|
||||||
|
|
||||||
public class Helpers {
|
public class Helpers {
|
||||||
|
|
||||||
public static final String PREFS_NAME = "InThePoche";
|
public static final String PREFS_NAME = "InThePoche";
|
||||||
public final static String zeroUpdate = "2011-01-01 00:00:00";
|
public final static String zeroUpdate = "2011-01-01 00:00:00";
|
||||||
|
|
||||||
public static String InputStreamtoString(InputStream is)
|
public static String InputStreamtoString(InputStream is) {
|
||||||
{
|
String s = "", line = "";
|
||||||
String s = "",line="";
|
|
||||||
BufferedReader rd = new BufferedReader(new InputStreamReader(is));
|
BufferedReader rd = new BufferedReader(new InputStreamReader(is));
|
||||||
try{
|
try {
|
||||||
for(; ; rd.readLine())
|
for (; ; rd.readLine()) {
|
||||||
{
|
if ((line = rd.readLine()) != null) {
|
||||||
if((line = rd.readLine())!=null)
|
s += line;
|
||||||
{
|
} else {
|
||||||
s +=line;
|
|
||||||
}else
|
|
||||||
{
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}catch (IOException e) {
|
} catch (IOException e) {
|
||||||
// TODO: handle exception
|
// TODO: handle exception
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
@ -38,7 +34,7 @@ public class Helpers {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static String getInputStreamFromUrl(String url) {
|
public static String getInputStreamFromUrl(String url) {
|
||||||
InputStream content = null;
|
InputStream content;
|
||||||
String res = "";
|
String res = "";
|
||||||
try {
|
try {
|
||||||
HttpGet httpGet = new HttpGet(url);
|
HttpGet httpGet = new HttpGet(url);
|
||||||
|
@ -1,13 +1,8 @@
|
|||||||
package fr.gaulupeau.apps.Poche;
|
package fr.gaulupeau.apps.Poche;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.*;
|
|
||||||
import fr.gaulupeau.apps.InThePoche.R;
|
|
||||||
import android.app.Activity;
|
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.database.Cursor;
|
import android.database.Cursor;
|
||||||
import android.database.sqlite.SQLiteDatabase;
|
import android.database.sqlite.SQLiteDatabase;
|
||||||
import android.os.Build;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.view.Menu;
|
import android.view.Menu;
|
||||||
import android.view.MenuInflater;
|
import android.view.MenuInflater;
|
||||||
@ -16,63 +11,57 @@ import android.view.View;
|
|||||||
import android.widget.AdapterView;
|
import android.widget.AdapterView;
|
||||||
import android.widget.ListView;
|
import android.widget.ListView;
|
||||||
|
|
||||||
public class ListArticles extends Activity {
|
import java.util.ArrayList;
|
||||||
|
|
||||||
private ArrayList<Article> readArticlesInfo;
|
import fr.gaulupeau.apps.InThePoche.R;
|
||||||
private ListView readList;
|
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARCHIVE;
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_CONTENT;
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_DATE;
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_TABLE;
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_TITLE;
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_URL;
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.MY_ID;
|
||||||
|
|
||||||
|
public class ListArticles extends BaseActionBarActivity {
|
||||||
|
|
||||||
|
private ArrayList<Article> readArticlesInfo;
|
||||||
private SQLiteDatabase database;
|
private SQLiteDatabase database;
|
||||||
|
|
||||||
public void onCreate(Bundle savedInstanceState) {
|
public void onCreate(Bundle savedInstanceState) {
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
setContentView(R.layout.list);
|
setContentView(R.layout.list);
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
|
|
||||||
try {
|
|
||||||
getActionBar().setDisplayHomeAsUpEnabled(true);
|
|
||||||
} catch (Exception e) {
|
|
||||||
//
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
setupDB();
|
setupDB();
|
||||||
setupList(false);
|
setupList(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void onResume() {
|
public void onDestroy() {
|
||||||
super.onResume();
|
super.onDestroy();
|
||||||
setupList(false);
|
database.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void onDestroy() {
|
@Override
|
||||||
super.onDestroy();
|
public boolean onCreateOptionsMenu(Menu menu) {
|
||||||
database.close();
|
MenuInflater inflater = getMenuInflater();
|
||||||
}
|
inflater.inflate(R.menu.option_list, menu);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onCreateOptionsMenu(Menu menu) {
|
public boolean onOptionsItemSelected(MenuItem item) {
|
||||||
MenuInflater inflater = getMenuInflater();
|
switch (item.getItemId()) {
|
||||||
inflater.inflate(R.menu.option_list, menu);
|
case R.id.menuShowAll:
|
||||||
return true;
|
setupList(true);
|
||||||
}
|
return true;
|
||||||
|
case R.id.menuWipeDb:
|
||||||
@Override
|
ArticlesSQLiteOpenHelper helper = new ArticlesSQLiteOpenHelper(this);
|
||||||
public boolean onOptionsItemSelected(MenuItem item) {
|
helper.truncateTables(database);
|
||||||
switch (item.getItemId()) {
|
setupList(false);
|
||||||
case R.id.menuShowAll:
|
return true;
|
||||||
setupList(true);
|
default:
|
||||||
return super.onOptionsItemSelected(item);
|
|
||||||
case R.id.menuWipeDb:
|
|
||||||
ArticlesSQLiteOpenHelper helper = new ArticlesSQLiteOpenHelper(this);
|
|
||||||
helper.truncateTables(database);
|
|
||||||
setupList(false);
|
|
||||||
return super.onOptionsItemSelected(item);
|
|
||||||
case android.R.id.home:
|
|
||||||
this.finish();
|
|
||||||
return super.onOptionsItemSelected(item);
|
return super.onOptionsItemSelected(item);
|
||||||
default:
|
}
|
||||||
return super.onOptionsItemSelected(item);
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setupDB() {
|
public void setupDB() {
|
||||||
ArticlesSQLiteOpenHelper helper = new ArticlesSQLiteOpenHelper(this);
|
ArticlesSQLiteOpenHelper helper = new ArticlesSQLiteOpenHelper(this);
|
||||||
@ -80,38 +69,38 @@ public class ListArticles extends Activity {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void setupList(Boolean showAll) {
|
public void setupList(Boolean showAll) {
|
||||||
readList = (ListView) findViewById(R.id.liste_articles);
|
ListView readList = (ListView) findViewById(R.id.liste_articles);
|
||||||
readArticlesInfo = new ArrayList<Article>();
|
readArticlesInfo = new ArrayList<Article>();
|
||||||
String filter = null;
|
String filter = null;
|
||||||
if (showAll == false) {
|
if (!showAll) {
|
||||||
filter = ARCHIVE + "=0";
|
filter = ARCHIVE + "=0";
|
||||||
}
|
}
|
||||||
ReadingListAdapter ad = getAdapterQuery(filter, readArticlesInfo);
|
ReadingListAdapter ad = getAdapterQuery(filter, readArticlesInfo);
|
||||||
readList.setAdapter(ad);
|
readList.setAdapter(ad);
|
||||||
|
|
||||||
readList.setOnItemClickListener(new AdapterView.OnItemClickListener() {
|
readList.setOnItemClickListener(new AdapterView.OnItemClickListener() {
|
||||||
|
|
||||||
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
|
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
|
||||||
Intent i = new Intent(getBaseContext(), ReadArticle.class);
|
Intent i = new Intent(getBaseContext(), ReadArticle.class);
|
||||||
i.putExtra("id", (String) readArticlesInfo.get(position).id);
|
i.putExtra("id", readArticlesInfo.get(position).id);
|
||||||
startActivity(i);
|
startActivity(i);
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public ReadingListAdapter getAdapterQuery(String filter, ArrayList<Article> articleInfo) {
|
public ReadingListAdapter getAdapterQuery(String filter, ArrayList<Article> articleInfo) {
|
||||||
//Log.e("getAdapterQuery", "running query");
|
//Log.e("getAdapterQuery", "running query");
|
||||||
//String url, String domain, String id, String title, String content
|
//String url, String domain, String id, String title, String content
|
||||||
String[] getStrColumns = new String[] {ARTICLE_URL, MY_ID, ARTICLE_TITLE, ARTICLE_CONTENT, ARCHIVE};
|
String[] getStrColumns = new String[]{ARTICLE_URL, MY_ID, ARTICLE_TITLE, ARTICLE_CONTENT, ARCHIVE};
|
||||||
Cursor ac = database.query(
|
Cursor ac = database.query(
|
||||||
ARTICLE_TABLE,
|
ARTICLE_TABLE,
|
||||||
getStrColumns,
|
getStrColumns,
|
||||||
filter, null, null, null, ARTICLE_DATE + " DESC");
|
filter, null, null, null, ARTICLE_DATE + " DESC");
|
||||||
ac.moveToFirst();
|
ac.moveToFirst();
|
||||||
if(!ac.isAfterLast()) {
|
if (!ac.isAfterLast()) {
|
||||||
do {
|
do {
|
||||||
Article tempArticle = new Article(ac.getString(0),ac.getString(1),ac.getString(2),ac.getString(3),ac.getString(4));
|
Article tempArticle = new Article(ac.getString(0), ac.getString(1), ac.getString(2), ac.getString(3), ac.getString(4));
|
||||||
articleInfo.add(tempArticle);
|
articleInfo.add(tempArticle);
|
||||||
} while (ac.moveToNext());
|
} while (ac.moveToNext());
|
||||||
}
|
}
|
||||||
|
@ -8,39 +8,9 @@
|
|||||||
|
|
||||||
package fr.gaulupeau.apps.Poche;
|
package fr.gaulupeau.apps.Poche;
|
||||||
|
|
||||||
import fr.gaulupeau.apps.InThePoche.R;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.InputStreamReader;
|
|
||||||
import java.io.UnsupportedEncodingException;
|
|
||||||
import java.net.HttpURLConnection;
|
|
||||||
import java.net.MalformedURLException;
|
|
||||||
import java.net.URL;
|
|
||||||
import java.security.SecureRandom;
|
|
||||||
import java.security.cert.CertificateException;
|
|
||||||
import java.security.cert.X509Certificate;
|
|
||||||
import java.text.DateFormat;
|
|
||||||
import java.util.Date;
|
|
||||||
|
|
||||||
import javax.net.ssl.HostnameVerifier;
|
|
||||||
import javax.net.ssl.HttpsURLConnection;
|
|
||||||
import javax.net.ssl.SSLContext;
|
|
||||||
import javax.net.ssl.SSLSession;
|
|
||||||
import javax.net.ssl.X509TrustManager;
|
|
||||||
import javax.xml.parsers.DocumentBuilder;
|
|
||||||
import javax.xml.parsers.DocumentBuilderFactory;
|
|
||||||
import javax.xml.parsers.ParserConfigurationException;
|
|
||||||
|
|
||||||
import org.w3c.dom.DOMException;
|
|
||||||
import org.w3c.dom.Document;
|
|
||||||
import org.w3c.dom.Element;
|
|
||||||
import org.w3c.dom.Node;
|
|
||||||
import org.w3c.dom.NodeList;
|
|
||||||
import org.xml.sax.InputSource;
|
|
||||||
import org.xml.sax.SAXException;
|
|
||||||
|
|
||||||
import android.annotation.TargetApi;
|
import android.annotation.TargetApi;
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
|
import android.app.AlertDialog;
|
||||||
import android.content.ContentValues;
|
import android.content.ContentValues;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
@ -53,39 +23,61 @@ import android.net.NetworkInfo;
|
|||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.os.Build;
|
import android.os.Build;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.preference.PreferenceManager;
|
|
||||||
import android.provider.Browser;
|
import android.provider.Browser;
|
||||||
import android.text.Html;
|
|
||||||
import android.util.Base64;
|
import android.util.Base64;
|
||||||
import android.view.Menu;
|
import android.util.Patterns;
|
||||||
import android.view.MenuInflater;
|
|
||||||
import android.view.MenuItem;
|
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.View.OnClickListener;
|
import android.view.View.OnClickListener;
|
||||||
import android.widget.Button;
|
import android.widget.Button;
|
||||||
import android.widget.EditText;
|
|
||||||
import android.widget.Toast;
|
import android.widget.Toast;
|
||||||
import static fr.gaulupeau.apps.Poche.Helpers.PREFS_NAME;
|
|
||||||
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_TABLE;
|
|
||||||
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_URL;
|
|
||||||
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_TITLE;
|
|
||||||
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_CONTENT;
|
|
||||||
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARCHIVE;
|
|
||||||
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_SYNC;
|
|
||||||
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_DATE;
|
|
||||||
|
|
||||||
|
import org.w3c.dom.Document;
|
||||||
|
import org.w3c.dom.Element;
|
||||||
|
import org.w3c.dom.Node;
|
||||||
|
import org.w3c.dom.NodeList;
|
||||||
|
import org.xml.sax.InputSource;
|
||||||
|
import org.xml.sax.SAXException;
|
||||||
|
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.io.InputStreamReader;
|
||||||
|
import java.io.UnsupportedEncodingException;
|
||||||
|
import java.net.HttpURLConnection;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.security.SecureRandom;
|
||||||
|
import java.security.cert.CertificateException;
|
||||||
|
import java.security.cert.X509Certificate;
|
||||||
|
import java.util.regex.Matcher;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
|
import javax.net.ssl.HostnameVerifier;
|
||||||
|
import javax.net.ssl.HttpsURLConnection;
|
||||||
|
import javax.net.ssl.SSLContext;
|
||||||
|
import javax.net.ssl.SSLSession;
|
||||||
|
import javax.net.ssl.X509TrustManager;
|
||||||
|
import javax.xml.parsers.DocumentBuilder;
|
||||||
|
import javax.xml.parsers.DocumentBuilderFactory;
|
||||||
|
|
||||||
|
import fr.gaulupeau.apps.InThePoche.R;
|
||||||
|
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARCHIVE;
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_CONTENT;
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_DATE;
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_SYNC;
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_TABLE;
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_TITLE;
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_URL;
|
||||||
|
import static fr.gaulupeau.apps.Poche.Helpers.PREFS_NAME;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Main activity class
|
* Main activity class
|
||||||
*/
|
*/
|
||||||
@TargetApi(Build.VERSION_CODES.FROYO) public class Poche extends Activity {
|
@TargetApi(Build.VERSION_CODES.FROYO)
|
||||||
|
public class Poche extends Activity {
|
||||||
private static SQLiteDatabase database;
|
private static SQLiteDatabase database;
|
||||||
Button btnDone;
|
|
||||||
Button btnGetPost;
|
Button btnGetPost;
|
||||||
Button btnSync;
|
Button btnSync;
|
||||||
Button btnSettings;
|
Button btnSettings;
|
||||||
EditText editPocheUrl;
|
|
||||||
SharedPreferences settings;
|
SharedPreferences settings;
|
||||||
static String apiUsername;
|
static String apiUsername;
|
||||||
static String apiToken;
|
static String apiToken;
|
||||||
@ -93,101 +85,114 @@ import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_DATE;
|
|||||||
String action;
|
String action;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called when the activity is first created.
|
||||||
|
* Will act differently depending on whether sharing or
|
||||||
|
* displaying information page.
|
||||||
|
*/
|
||||||
|
public void onCreate(Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
|
||||||
|
Intent intent = getIntent();
|
||||||
|
Bundle extras = intent.getExtras();
|
||||||
|
action = intent.getAction();
|
||||||
|
|
||||||
|
getSettings();
|
||||||
|
// Find out if Sharing or if app has been launched from icon
|
||||||
|
if (action.equals(Intent.ACTION_SEND) && !pocheUrl.equals("http://")) {
|
||||||
|
setContentView(R.layout.main);
|
||||||
|
findViewById(R.id.btnSync).setVisibility(View.GONE);
|
||||||
|
findViewById(R.id.btnGetPost).setVisibility(View.GONE);
|
||||||
|
findViewById(R.id.progressBar1).setVisibility(View.VISIBLE);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/** Called when the activity is first created.
|
final String extraText = extras.getString("android.intent.extra.TEXT");
|
||||||
* Will act differently depending on whether sharing or
|
final String pageUrl;
|
||||||
* displaying information page. */
|
|
||||||
public void onCreate(Bundle savedInstanceState) {
|
|
||||||
super.onCreate(savedInstanceState);
|
|
||||||
|
|
||||||
Intent intent = getIntent();
|
// Parsing string for urls.
|
||||||
Bundle extras = intent.getExtras();
|
Matcher matcher = Patterns.WEB_URL.matcher(extraText);
|
||||||
action = intent.getAction();
|
if (matcher.find()) {
|
||||||
|
pageUrl = matcher.group();
|
||||||
|
} else {
|
||||||
|
showErrorMessage("Couldn't find a URL in share string:\n"+extraText);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
getSettings();
|
|
||||||
// Find out if Sharing or if app has been launched from icon
|
|
||||||
if (action.equals(Intent.ACTION_SEND) && pocheUrl != "http://") {
|
|
||||||
setContentView(R.layout.main);
|
|
||||||
findViewById(R.id.btnSync).setVisibility(View.GONE);
|
|
||||||
findViewById(R.id.btnGetPost).setVisibility(View.GONE);
|
|
||||||
findViewById(R.id.progressBar1).setVisibility(View.VISIBLE);
|
|
||||||
final String pageUrl = extras.getString("android.intent.extra.TEXT");
|
|
||||||
// Vérification de la connectivité Internet
|
|
||||||
final ConnectivityManager conMgr = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
|
|
||||||
final NetworkInfo activeNetwork = conMgr.getActiveNetworkInfo();
|
|
||||||
if (activeNetwork != null && activeNetwork.isConnected()) {
|
|
||||||
// Start to build the poche URL
|
|
||||||
Uri.Builder pocheSaveUrl = Uri.parse(pocheUrl).buildUpon();
|
|
||||||
// Add the parameters from the call
|
|
||||||
pocheSaveUrl.appendQueryParameter("action", "add");
|
|
||||||
byte[] data = null;
|
|
||||||
try {
|
|
||||||
data = pageUrl.getBytes("UTF-8");
|
|
||||||
} catch (UnsupportedEncodingException e) {
|
|
||||||
// TODO Auto-generated catch block
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
String base64 = Base64.encodeToString(data, Base64.DEFAULT);
|
|
||||||
pocheSaveUrl.appendQueryParameter("url", base64);
|
|
||||||
System.out.println("base64 : " + base64);
|
|
||||||
System.out.println("pageurl : " + pageUrl);
|
|
||||||
|
|
||||||
// Load the constructed URL in the browser
|
// Vérification de la connectivité Internet
|
||||||
Intent i = new Intent(Intent.ACTION_VIEW);
|
final ConnectivityManager conMgr = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
|
||||||
i.setData(pocheSaveUrl.build());
|
final NetworkInfo activeNetwork = conMgr.getActiveNetworkInfo();
|
||||||
i.putExtra(Browser.EXTRA_APPLICATION_ID, getPackageName());
|
if (activeNetwork != null && activeNetwork.isConnected()) {
|
||||||
// If user has more then one browser installed give them a chance to
|
// Start to build the poche URL
|
||||||
// select which one they want to use
|
Uri.Builder pocheSaveUrl = Uri.parse(pocheUrl).buildUpon();
|
||||||
|
// Add the parameters from the call
|
||||||
|
pocheSaveUrl.appendQueryParameter("action", "add");
|
||||||
|
byte[] data = null;
|
||||||
|
try {
|
||||||
|
data = pageUrl.getBytes("UTF-8");
|
||||||
|
} catch (UnsupportedEncodingException e) {
|
||||||
|
// TODO Auto-generated catch block
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
String base64 = Base64.encodeToString(data, Base64.DEFAULT);
|
||||||
|
pocheSaveUrl.appendQueryParameter("url", base64);
|
||||||
|
System.out.println("base64 : " + base64);
|
||||||
|
System.out.println("pageurl : " + pageUrl);
|
||||||
|
|
||||||
startActivity(i);
|
// Load the constructed URL in the browser
|
||||||
// That is all this app needs to do, so call finish()
|
Intent i = new Intent(Intent.ACTION_VIEW);
|
||||||
this.finish();
|
i.setData(pocheSaveUrl.build());
|
||||||
} else {
|
i.putExtra(Browser.EXTRA_APPLICATION_ID, getPackageName());
|
||||||
// Afficher alerte connectivité
|
// If user has more then one browser installed give them a chance to
|
||||||
showToast(getString(R.string.txtNetOffline));
|
// select which one they want to use
|
||||||
}
|
|
||||||
}
|
startActivity(i);
|
||||||
else {
|
// That is all this app needs to do, so call finish()
|
||||||
setContentView(R.layout.main);
|
this.finish();
|
||||||
|
} else {
|
||||||
|
// Afficher alerte connectivité
|
||||||
|
showToast(getString(R.string.txtNetOffline));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
setContentView(R.layout.main);
|
||||||
checkAndHandleAfterUpdate();
|
checkAndHandleAfterUpdate();
|
||||||
|
|
||||||
btnSync = (Button)findViewById(R.id.btnSync);
|
btnSync = (Button) findViewById(R.id.btnSync);
|
||||||
btnSync.setOnClickListener(new OnClickListener() {
|
btnSync.setOnClickListener(new OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(View v) {
|
public void onClick(View v) {
|
||||||
// Vérification de la connectivité Internet
|
// Vérification de la connectivité Internet
|
||||||
final ConnectivityManager conMgr = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
|
final ConnectivityManager conMgr = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
|
||||||
final NetworkInfo activeNetwork = conMgr.getActiveNetworkInfo();
|
final NetworkInfo activeNetwork = conMgr.getActiveNetworkInfo();
|
||||||
if (pocheUrl == "http://") {
|
if (pocheUrl.equals("http://")) {
|
||||||
showToast(getString(R.string.txtConfigNotSet));
|
showToast(getString(R.string.txtConfigNotSet));
|
||||||
} else if (activeNetwork != null && activeNetwork.isConnected()) {
|
} else if (activeNetwork != null && activeNetwork.isConnected()) {
|
||||||
// Exécution de la synchro en arrière-plan
|
// Exécution de la synchro en arrière-plan
|
||||||
findViewById(R.id.progressBar1).setVisibility(View.VISIBLE);
|
findViewById(R.id.progressBar1).setVisibility(View.VISIBLE);
|
||||||
new Thread(new Runnable() {
|
new Thread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
//pushRead();
|
//pushRead();
|
||||||
parseRSS();
|
parseRSS();
|
||||||
runOnUiThread(new Runnable() {
|
runOnUiThread(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
findViewById(R.id.progressBar1).setVisibility(View.GONE);
|
findViewById(R.id.progressBar1).setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}).start();
|
}).start();
|
||||||
} else {
|
} else {
|
||||||
// Afficher alerte connectivité
|
// Afficher alerte connectivité
|
||||||
showToast(getString(R.string.txtNetOffline));
|
showToast(getString(R.string.txtNetOffline));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
btnGetPost = (Button)findViewById(R.id.btnGetPost);
|
btnGetPost = (Button) findViewById(R.id.btnGetPost);
|
||||||
//updateUnread();
|
//updateUnread();
|
||||||
|
|
||||||
btnGetPost.setOnClickListener(new OnClickListener() {
|
btnGetPost.setOnClickListener(new OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
@ -196,20 +201,20 @@ import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_DATE;
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
btnSettings = (Button)findViewById(R.id.btnSettings);
|
btnSettings = (Button) findViewById(R.id.btnSettings);
|
||||||
btnSettings.setOnClickListener(new OnClickListener() {
|
btnSettings.setOnClickListener(new OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(View view) {
|
public void onClick(View view) {
|
||||||
startActivity(new Intent(getBaseContext(), Settings.class));
|
startActivity(new Intent(getBaseContext(), Settings.class));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void checkAndHandleAfterUpdate() {
|
private void checkAndHandleAfterUpdate() {
|
||||||
SharedPreferences pref = getSharedPreferences(PREFS_NAME, 0);
|
SharedPreferences pref = getSharedPreferences(PREFS_NAME, 0);
|
||||||
|
|
||||||
if (pref.getInt("update_checker",0) < 9) {
|
if (pref.getInt("update_checker", 0) < 9) {
|
||||||
// Wipe Database, because we now save HTML content instead of plain text
|
// Wipe Database, because we now save HTML content instead of plain text
|
||||||
ArticlesSQLiteOpenHelper helper = new ArticlesSQLiteOpenHelper(this);
|
ArticlesSQLiteOpenHelper helper = new ArticlesSQLiteOpenHelper(this);
|
||||||
database = helper.getReadableDatabase();
|
database = helper.getReadableDatabase();
|
||||||
@ -227,52 +232,63 @@ import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_DATE;
|
|||||||
pref.edit().putInt("update_checker", versionCode).commit();
|
pref.edit().putInt("update_checker", versionCode).commit();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void getSettings(){
|
private void getSettings() {
|
||||||
settings = getSharedPreferences(PREFS_NAME, 0);
|
settings = getSharedPreferences(PREFS_NAME, 0);
|
||||||
pocheUrl = settings.getString("pocheUrl", "http://");
|
pocheUrl = settings.getString("pocheUrl", "http://");
|
||||||
apiUsername = settings.getString("APIUsername", "");
|
apiUsername = settings.getString("APIUsername", "");
|
||||||
apiToken = settings.getString("APIToken", "");
|
apiToken = settings.getString("APIToken", "");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onResume() {
|
protected void onResume() {
|
||||||
super.onResume();
|
super.onResume();
|
||||||
getSettings();
|
getSettings();
|
||||||
if (! action.equals(Intent.ACTION_SEND)){
|
if (!action.equals(Intent.ACTION_SEND)) {
|
||||||
updateUnread();
|
updateUnread();
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void onDestroy() {
|
|
||||||
super.onDestroy();
|
|
||||||
if (database != null) {
|
|
||||||
database.close();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateUnread(){
|
@Override
|
||||||
runOnUiThread(new Runnable() {
|
protected void onDestroy() {
|
||||||
public void run()
|
super.onDestroy();
|
||||||
{
|
if (database != null) {
|
||||||
ArticlesSQLiteOpenHelper helper = new ArticlesSQLiteOpenHelper(getApplicationContext());
|
database.close();
|
||||||
database = helper.getReadableDatabase();
|
}
|
||||||
int news = database.query(ARTICLE_TABLE, null, ARCHIVE + "=0", null, null, null, null).getCount();
|
}
|
||||||
btnGetPost.setText(String.format(getString(R.string.btnGetPost), news));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public void showToast(final String toast)
|
private void updateUnread() {
|
||||||
{
|
runOnUiThread(new Runnable() {
|
||||||
runOnUiThread(new Runnable() {
|
public void run() {
|
||||||
public void run()
|
ArticlesSQLiteOpenHelper helper = new ArticlesSQLiteOpenHelper(getApplicationContext());
|
||||||
{
|
database = helper.getReadableDatabase();
|
||||||
Toast.makeText(Poche.this, toast, Toast.LENGTH_SHORT).show();
|
int news = database.query(ARTICLE_TABLE, null, ARCHIVE + "=0", null, null, null, null).getCount();
|
||||||
}
|
btnGetPost.setText(String.format(getString(R.string.btnGetPost), news));
|
||||||
});
|
}
|
||||||
}
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public void showToast(final String toast) {
|
||||||
|
runOnUiThread(new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
Toast.makeText(Poche.this, toast, Toast.LENGTH_SHORT).show();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void showErrorMessage(final String message) {
|
||||||
|
runOnUiThread(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
AlertDialog.Builder messageBox = new AlertDialog.Builder(Poche.this);
|
||||||
|
messageBox.setMessage(message);
|
||||||
|
messageBox.setTitle(getString(R.string.error));
|
||||||
|
// messageBox.setIconAttribute(android.R.attr.alertDialogIcon);
|
||||||
|
messageBox.setPositiveButton("OK", null);
|
||||||
|
messageBox.setCancelable(false);
|
||||||
|
messageBox.create().show();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
// public void pocheIt(String url){
|
// public void pocheIt(String url){
|
||||||
// String id ="req-001";
|
// String id ="req-001";
|
||||||
@ -324,206 +340,202 @@ import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_DATE;
|
|||||||
// }
|
// }
|
||||||
|
|
||||||
|
|
||||||
public String cleanString(String s){
|
public String cleanString(String s) {
|
||||||
|
|
||||||
s = s.replace("é", "é");
|
s = s.replace("é", "é");
|
||||||
s = s.replace("è", "è");
|
s = s.replace("è", "è");
|
||||||
s = s.replace("ê", "ê");
|
s = s.replace("ê", "ê");
|
||||||
s = s.replace("ë", "ë");
|
s = s.replace("ë", "ë");
|
||||||
s = s.replace("Ã ", "à");
|
s = s.replace("Ã ", "à");
|
||||||
s = s.replace("ä", "ä");
|
s = s.replace("ä", "ä");
|
||||||
s = s.replace("â", "â");
|
s = s.replace("â", "â");
|
||||||
s = s.replace("ù", "ù");
|
s = s.replace("ù", "ù");
|
||||||
s = s.replace("û", "û");
|
s = s.replace("û", "û");
|
||||||
s = s.replace("ü", "ü");
|
s = s.replace("ü", "ü");
|
||||||
s = s.replace("ô", "ô");
|
s = s.replace("ô", "ô");
|
||||||
s = s.replace("ö", "ö");
|
s = s.replace("ö", "ö");
|
||||||
s = s.replace("î", "î");
|
s = s.replace("î", "î");
|
||||||
s = s.replace("ï", "ï");
|
s = s.replace("ï", "ï");
|
||||||
s = s.replace("ç", "ç");
|
s = s.replace("ç", "ç");
|
||||||
s = s.replace("&", "&");
|
s = s.replace("&", "&");
|
||||||
return s;
|
|
||||||
}
|
// Replace multiple whitespaces with single space
|
||||||
|
s = s.replaceAll("\\s+", " ");
|
||||||
|
s = s.trim();
|
||||||
|
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
private void trustEveryone() {
|
private void trustEveryone() {
|
||||||
try {
|
try {
|
||||||
HttpsURLConnection.setDefaultHostnameVerifier(new HostnameVerifier(){
|
HttpsURLConnection.setDefaultHostnameVerifier(new HostnameVerifier() {
|
||||||
public boolean verify(String hostname, SSLSession session) {
|
public boolean verify(String hostname, SSLSession session) {
|
||||||
return true;
|
return true;
|
||||||
}});
|
}
|
||||||
SSLContext context = SSLContext.getInstance("TLS");
|
});
|
||||||
context.init(null, new X509TrustManager[]{new X509TrustManager(){
|
SSLContext context = SSLContext.getInstance("TLS");
|
||||||
public void checkClientTrusted(X509Certificate[] chain,
|
context.init(null, new X509TrustManager[]{new X509TrustManager() {
|
||||||
String authType) throws CertificateException {}
|
public void checkClientTrusted(X509Certificate[] chain,
|
||||||
public void checkServerTrusted(X509Certificate[] chain,
|
String authType) throws CertificateException {
|
||||||
String authType) throws CertificateException {}
|
}
|
||||||
public X509Certificate[] getAcceptedIssuers() {
|
|
||||||
return new X509Certificate[0];
|
public void checkServerTrusted(X509Certificate[] chain,
|
||||||
}}}, new SecureRandom());
|
String authType) throws CertificateException {
|
||||||
HttpsURLConnection.setDefaultSSLSocketFactory(
|
}
|
||||||
context.getSocketFactory());
|
|
||||||
} catch (Exception e) { // should never happen
|
public X509Certificate[] getAcceptedIssuers() {
|
||||||
e.printStackTrace();
|
return new X509Certificate[0];
|
||||||
}
|
}
|
||||||
}
|
}}, new SecureRandom());
|
||||||
|
HttpsURLConnection.setDefaultSSLSocketFactory(
|
||||||
|
context.getSocketFactory());
|
||||||
|
} catch (Exception e) { // should never happen
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
public void parseRSS(){
|
public void parseRSS() {
|
||||||
|
|
||||||
URL url;
|
URL url;
|
||||||
try
|
try {
|
||||||
{
|
// Set the url (you will need to change this to your RSS URL
|
||||||
// Set the url (you will need to change this to your RSS URL
|
url = new URL(pocheUrl + "/?feed&type=home&user_id=" + apiUsername + "&token=" + apiToken);
|
||||||
url = new URL(pocheUrl + "/?feed&type=home&user_id=" + apiUsername + "&token=" + apiToken );
|
if (pocheUrl.startsWith("https")) {
|
||||||
// Setup the connection
|
trustEveryone();
|
||||||
HttpsURLConnection conn_s = null;
|
}
|
||||||
HttpURLConnection conn = null;
|
|
||||||
if (pocheUrl.startsWith("https") ) {
|
|
||||||
trustEveryone();
|
|
||||||
conn_s = (HttpsURLConnection) url.openConnection();
|
|
||||||
}else{
|
|
||||||
conn = (HttpURLConnection) url.openConnection();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (
|
// Setup the connection
|
||||||
((conn != null) && (conn.getResponseCode() == HttpURLConnection.HTTP_OK))
|
HttpURLConnection urlConnection;
|
||||||
|| ((conn_s != null) && (conn_s.getResponseCode() == HttpURLConnection.HTTP_OK))
|
urlConnection = (HttpURLConnection) url.openConnection();
|
||||||
)
|
|
||||||
{
|
|
||||||
|
|
||||||
// Retreive the XML from the URL
|
if ((urlConnection != null) && (urlConnection.getResponseCode() == HttpURLConnection.HTTP_OK)) {
|
||||||
DocumentBuilderFactory dbf = DocumentBuilderFactory
|
|
||||||
.newInstance();
|
|
||||||
DocumentBuilder db = dbf.newDocumentBuilder();
|
|
||||||
Document doc;
|
|
||||||
// doc = db.parse(url.openStream());
|
|
||||||
InputSource is = new InputSource(
|
|
||||||
new InputStreamReader(
|
|
||||||
url.openStream()));
|
|
||||||
doc = db.parse(is);
|
|
||||||
// doc = db.parse(
|
|
||||||
// new InputSource(
|
|
||||||
// new InputStreamReader(
|
|
||||||
// url.openStream(),
|
|
||||||
// "latin-1")));
|
|
||||||
doc.getDocumentElement().normalize();
|
|
||||||
|
|
||||||
// This is the root node of each section you want to parse
|
// Retreive the XML from the URL
|
||||||
NodeList itemLst = doc.getElementsByTagName("item");
|
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
|
||||||
|
DocumentBuilder db = dbf.newDocumentBuilder();
|
||||||
|
Document doc = null;
|
||||||
|
|
||||||
// This sets up some arrays to hold the data parsed
|
InputSource is;
|
||||||
arrays.PodcastTitle = new String[itemLst.getLength()];
|
|
||||||
arrays.PodcastURL = new String[itemLst.getLength()];
|
|
||||||
arrays.PodcastContent = new String[itemLst.getLength()];
|
|
||||||
arrays.PodcastMedia = new String[itemLst.getLength()];
|
|
||||||
arrays.PodcastDate = new String[itemLst.getLength()];
|
|
||||||
|
|
||||||
// Loop through the XML passing the data to the arrays
|
try {
|
||||||
for (int i = 0; i < itemLst.getLength(); i++)
|
is = new InputSource(
|
||||||
{
|
new InputStreamReader(
|
||||||
|
urlConnection.getInputStream()));
|
||||||
|
doc = db.parse(is);
|
||||||
|
doc.getDocumentElement().normalize();
|
||||||
|
} catch (SAXException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
|
||||||
Node item = itemLst.item(i);
|
InputStream inputStream = url.openStream();
|
||||||
if (item.getNodeType() == Node.ELEMENT_NODE)
|
int ch;
|
||||||
{
|
StringBuffer stringBuffer = new StringBuffer();
|
||||||
Element ielem = (Element) item;
|
while ((ch = inputStream.read()) != -1) {
|
||||||
|
stringBuffer.append((char) ch);
|
||||||
|
}
|
||||||
|
showErrorMessage("Got invalid response:\n\"" + stringBuffer.toString() + "\"");
|
||||||
|
}
|
||||||
|
|
||||||
// This section gets the elements from the XML
|
// This is the root node of each section you want to parse
|
||||||
// that we want to use you will need to add
|
NodeList itemLst = doc.getElementsByTagName("item");
|
||||||
// and remove elements that you want / don't want
|
|
||||||
NodeList title = ielem.getElementsByTagName("title");
|
|
||||||
NodeList link = ielem.getElementsByTagName("link");
|
|
||||||
NodeList date = ielem.getElementsByTagName("pubDate");
|
|
||||||
NodeList content = ielem
|
|
||||||
.getElementsByTagName("description");
|
|
||||||
//NodeList media = ielem
|
|
||||||
// .getElementsByTagName("media:content");
|
|
||||||
|
|
||||||
// This is an attribute of an element so I create
|
// This sets up some arrays to hold the data parsed
|
||||||
// a string to make it easier to use
|
arrays.PodcastTitle = new String[itemLst.getLength()];
|
||||||
//String mediaurl = media.item(0).getAttributes()
|
arrays.PodcastURL = new String[itemLst.getLength()];
|
||||||
// .getNamedItem("url").getNodeValue();
|
arrays.PodcastContent = new String[itemLst.getLength()];
|
||||||
|
arrays.PodcastMedia = new String[itemLst.getLength()];
|
||||||
|
arrays.PodcastDate = new String[itemLst.getLength()];
|
||||||
|
|
||||||
// This section adds an entry to the arrays with the
|
// Loop through the XML passing the data to the arrays
|
||||||
// data retrieved from above. I have surrounded each
|
for (int i = 0; i < itemLst.getLength(); i++) {
|
||||||
// with try/catch just incase the element does not
|
|
||||||
// exist
|
Node item = itemLst.item(i);
|
||||||
try
|
if (item.getNodeType() == Node.ELEMENT_NODE) {
|
||||||
{
|
Element ielem = (Element) item;
|
||||||
arrays.PodcastTitle[i] = cleanString(title.item(0).getChildNodes().item(0).getNodeValue());
|
|
||||||
} catch (NullPointerException e)
|
// This section gets the elements from the XML
|
||||||
{
|
// that we want to use you will need to add
|
||||||
e.printStackTrace();
|
// and remove elements that you want / don't want
|
||||||
arrays.PodcastTitle[i] = "Echec";
|
NodeList title = ielem.getElementsByTagName("title");
|
||||||
}
|
NodeList link = ielem.getElementsByTagName("link");
|
||||||
try {
|
NodeList date = ielem.getElementsByTagName("pubDate");
|
||||||
|
NodeList content = ielem
|
||||||
|
.getElementsByTagName("description");
|
||||||
|
//NodeList media = ielem
|
||||||
|
// .getElementsByTagName("media:content");
|
||||||
|
|
||||||
|
// This is an attribute of an element so I create
|
||||||
|
// a string to make it easier to use
|
||||||
|
//String mediaurl = media.item(0).getAttributes()
|
||||||
|
// .getNamedItem("url").getNodeValue();
|
||||||
|
|
||||||
|
// This section adds an entry to the arrays with the
|
||||||
|
// data retrieved from above. I have surrounded each
|
||||||
|
// with try/catch just incase the element does not
|
||||||
|
// exist
|
||||||
|
try {
|
||||||
|
arrays.PodcastTitle[i] = cleanString(title.item(0).getChildNodes().item(0).getNodeValue());
|
||||||
|
} catch (NullPointerException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
arrays.PodcastTitle[i] = "Echec";
|
||||||
|
}
|
||||||
|
try {
|
||||||
arrays.PodcastDate[i] = date.item(0).getChildNodes().item(0).getNodeValue();
|
arrays.PodcastDate[i] = date.item(0).getChildNodes().item(0).getNodeValue();
|
||||||
} catch (NullPointerException e) {
|
} catch (NullPointerException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
arrays.PodcastDate[i] = null;
|
arrays.PodcastDate[i] = null;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
arrays.PodcastURL[i] = link.item(0).getChildNodes()
|
||||||
|
.item(0).getNodeValue();
|
||||||
|
} catch (NullPointerException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
arrays.PodcastURL[i] = "Echec";
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
arrays.PodcastContent[i] = content.item(0)
|
||||||
|
.getChildNodes().item(0).getNodeValue();
|
||||||
|
} catch (NullPointerException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
arrays.PodcastContent[i] = "Echec";
|
||||||
}
|
}
|
||||||
try
|
|
||||||
{
|
|
||||||
arrays.PodcastURL[i] = link.item(0).getChildNodes()
|
|
||||||
.item(0).getNodeValue();
|
|
||||||
} catch (NullPointerException e)
|
|
||||||
{
|
|
||||||
e.printStackTrace();
|
|
||||||
arrays.PodcastURL[i] = "Echec";
|
|
||||||
}
|
|
||||||
try
|
|
||||||
{
|
|
||||||
arrays.PodcastContent[i] = content.item(0)
|
|
||||||
.getChildNodes().item(0).getNodeValue();
|
|
||||||
} catch (NullPointerException e)
|
|
||||||
{
|
|
||||||
e.printStackTrace();
|
|
||||||
arrays.PodcastContent[i] = "Echec";
|
|
||||||
}
|
|
||||||
|
|
||||||
ContentValues values = new ContentValues();
|
ContentValues values = new ContentValues();
|
||||||
values.put(ARTICLE_TITLE, arrays.PodcastTitle[i]);
|
values.put(ARTICLE_TITLE, arrays.PodcastTitle[i]);
|
||||||
values.put(ARTICLE_CONTENT, arrays.PodcastContent[i]);
|
values.put(ARTICLE_CONTENT, arrays.PodcastContent[i]);
|
||||||
//values.put(ARTICLE_ID, Html.fromHtml(article.getString("id")).toString());
|
//values.put(ARTICLE_ID, Html.fromHtml(article.getString("id")).toString());
|
||||||
values.put(ARTICLE_URL, arrays.PodcastURL[i]);
|
values.put(ARTICLE_URL, arrays.PodcastURL[i]);
|
||||||
values.put(ARTICLE_DATE, arrays.PodcastDate[i]);
|
values.put(ARTICLE_DATE, arrays.PodcastDate[i]);
|
||||||
values.put(ARCHIVE, 0);
|
values.put(ARCHIVE, 0);
|
||||||
values.put(ARTICLE_SYNC, 0);
|
values.put(ARTICLE_SYNC, 0);
|
||||||
try {
|
try {
|
||||||
database.insertOrThrow(ARTICLE_TABLE, null, values);
|
database.insertOrThrow(ARTICLE_TABLE, null, values);
|
||||||
} catch (SQLiteConstraintException e) {
|
} catch (SQLiteConstraintException e) {
|
||||||
continue;
|
continue;
|
||||||
} catch (SQLiteException e) {
|
} catch (SQLiteException e) {
|
||||||
database.execSQL("ALTER TABLE " + ARTICLE_TABLE + " ADD COLUMN " + ARTICLE_DATE + " datetime;");
|
database.execSQL("ALTER TABLE " + ARTICLE_TABLE + " ADD COLUMN " + ARTICLE_DATE + " datetime;");
|
||||||
database.insertOrThrow(ARTICLE_TABLE, null, values);
|
database.insertOrThrow(ARTICLE_TABLE, null, values);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
showToast(getString(R.string.txtSyncDone));
|
||||||
showToast(getString(R.string.txtSyncDone));
|
} else {
|
||||||
updateUnread();
|
// HTTP Connection not successful
|
||||||
} catch (MalformedURLException e)
|
if (urlConnection == null) {
|
||||||
{
|
showErrorMessage(getString(R.string.error_feed));
|
||||||
e.printStackTrace();
|
} else {
|
||||||
} catch (DOMException e)
|
showErrorMessage(getString(R.string.error_feed) + ":\n" + urlConnection.getResponseCode() + " " + urlConnection.getResponseMessage());
|
||||||
{
|
}
|
||||||
e.printStackTrace();
|
}
|
||||||
} catch (IOException e)
|
updateUnread();
|
||||||
{
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
|
||||||
} catch (ParserConfigurationException e)
|
|
||||||
{
|
|
||||||
e.printStackTrace();
|
|
||||||
} catch (SAXException e)
|
|
||||||
{
|
|
||||||
e.printStackTrace();
|
|
||||||
} catch (Exception e) {
|
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// public void fetchUnread(){
|
// public void fetchUnread(){
|
||||||
// String id = "req-001";
|
// String id = "req-001";
|
||||||
|
@ -1,65 +1,45 @@
|
|||||||
package fr.gaulupeau.apps.Poche;
|
package fr.gaulupeau.apps.Poche;
|
||||||
|
|
||||||
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARCHIVE;
|
|
||||||
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_CONTENT;
|
|
||||||
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_ID;
|
|
||||||
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_TITLE;
|
|
||||||
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_URL;
|
|
||||||
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_TABLE;
|
|
||||||
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_AUTHOR;
|
|
||||||
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.MY_ID;
|
|
||||||
|
|
||||||
import android.app.Activity;
|
|
||||||
import android.content.ContentValues;
|
import android.content.ContentValues;
|
||||||
import android.content.Context;
|
|
||||||
import android.database.Cursor;
|
import android.database.Cursor;
|
||||||
import android.database.sqlite.SQLiteDatabase;
|
import android.database.sqlite.SQLiteDatabase;
|
||||||
import android.os.Build;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.view.MenuItem;
|
|
||||||
import android.view.MotionEvent;
|
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.View.OnClickListener;
|
import android.view.View.OnClickListener;
|
||||||
import android.view.View.OnTouchListener;
|
|
||||||
import android.view.Window;
|
|
||||||
import android.webkit.WebChromeClient;
|
|
||||||
import android.webkit.WebView;
|
import android.webkit.WebView;
|
||||||
import android.webkit.WebViewClient;
|
|
||||||
import android.widget.Button;
|
import android.widget.Button;
|
||||||
import android.widget.ScrollView;
|
import android.widget.ScrollView;
|
||||||
import android.widget.TextView;
|
|
||||||
|
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
|
|
||||||
import fr.gaulupeau.apps.InThePoche.R;
|
import fr.gaulupeau.apps.InThePoche.R;
|
||||||
|
|
||||||
public class ReadArticle extends Activity {
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARCHIVE;
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_AUTHOR;
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_CONTENT;
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_ID;
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_TABLE;
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_TITLE;
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.ARTICLE_URL;
|
||||||
|
import static fr.gaulupeau.apps.Poche.ArticlesSQLiteOpenHelper.MY_ID;
|
||||||
|
|
||||||
|
public class ReadArticle extends BaseActionBarActivity {
|
||||||
WebView webViewContent;
|
WebView webViewContent;
|
||||||
Button btnMarkRead;
|
Button btnMarkRead;
|
||||||
SQLiteDatabase database;
|
SQLiteDatabase database;
|
||||||
String id = "";
|
String id = "";
|
||||||
ScrollView view;
|
ScrollView view;
|
||||||
|
|
||||||
public void onCreate(Bundle savedInstanceState) {
|
public void onCreate(Bundle savedInstanceState) {
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
requestWindowFeature(Window.FEATURE_INDETERMINATE_PROGRESS);
|
|
||||||
requestWindowFeature(Window.FEATURE_PROGRESS);
|
|
||||||
setContentView(R.layout.article);
|
setContentView(R.layout.article);
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
|
|
||||||
try {
|
|
||||||
getActionBar().setDisplayHomeAsUpEnabled(true);
|
|
||||||
} catch (Exception e) {
|
|
||||||
//
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
view = (ScrollView) findViewById(R.id.scroll);
|
view = (ScrollView) findViewById(R.id.scroll);
|
||||||
ArticlesSQLiteOpenHelper helper = new ArticlesSQLiteOpenHelper(getApplicationContext());
|
ArticlesSQLiteOpenHelper helper = new ArticlesSQLiteOpenHelper(getApplicationContext());
|
||||||
database = helper.getWritableDatabase();
|
database = helper.getWritableDatabase();
|
||||||
String[] getStrColumns = new String[] {ARTICLE_URL, MY_ID, ARTICLE_TITLE, ARTICLE_CONTENT, ARCHIVE, ARTICLE_AUTHOR};
|
String[] getStrColumns = new String[]{ARTICLE_URL, MY_ID, ARTICLE_TITLE, ARTICLE_CONTENT, ARCHIVE, ARTICLE_AUTHOR};
|
||||||
Bundle data = getIntent().getExtras();
|
Bundle data = getIntent().getExtras();
|
||||||
if(data != null) {
|
if (data != null) {
|
||||||
id = data.getString("id");
|
id = data.getString("id");
|
||||||
}
|
}
|
||||||
Cursor ac = database.query(ARTICLE_TABLE, getStrColumns, MY_ID + "=" + id, null, null, null, null);
|
Cursor ac = database.query(ARTICLE_TABLE, getStrColumns, MY_ID + "=" + id, null, null, null, null);
|
||||||
@ -73,8 +53,7 @@ public class ReadArticle extends Activity {
|
|||||||
try {
|
try {
|
||||||
URL originalUrl = new URL(originalUrlText);
|
URL originalUrl = new URL(originalUrlText);
|
||||||
originalUrlDesc = originalUrl.getHost();
|
originalUrlDesc = originalUrl.getHost();
|
||||||
}
|
} catch (Exception e) {
|
||||||
catch (Exception e) {
|
|
||||||
//
|
//
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -90,8 +69,8 @@ public class ReadArticle extends Activity {
|
|||||||
"\t\t\t\t<div id=\"content\" class=\"w600p center\">\n" +
|
"\t\t\t\t<div id=\"content\" class=\"w600p center\">\n" +
|
||||||
"\t\t\t\t\t<div id=\"article\">\n" +
|
"\t\t\t\t\t<div id=\"article\">\n" +
|
||||||
"\t\t\t\t\t\t<header class=\"mbm\">\n" +
|
"\t\t\t\t\t\t<header class=\"mbm\">\n" +
|
||||||
"\t\t\t\t\t\t\t<h1>"+ titleText +"</h1>\n" +
|
"\t\t\t\t\t\t\t<h1>" + titleText + "</h1>\n" +
|
||||||
"\t\t\t\t\t\t\t<p>Open Original: <a href=\""+ originalUrlText +"\">"+ originalUrlDesc +"</a></p>\n" +
|
"\t\t\t\t\t\t\t<p>Open Original: <a href=\"" + originalUrlText + "\">" + originalUrlDesc + "</a></p>\n" +
|
||||||
"\t\t\t\t\t\t</header>\n" +
|
"\t\t\t\t\t\t</header>\n" +
|
||||||
"\t\t\t\t\t\t<article>";
|
"\t\t\t\t\t\t<article>";
|
||||||
String htmlFooter = "</article>\n" +
|
String htmlFooter = "</article>\n" +
|
||||||
@ -102,22 +81,10 @@ public class ReadArticle extends Activity {
|
|||||||
"</html>";
|
"</html>";
|
||||||
|
|
||||||
|
|
||||||
setProgressBarIndeterminateVisibility(true);
|
webViewContent = (WebView) findViewById(R.id.webViewContent);
|
||||||
setProgressBarVisibility(true);
|
|
||||||
|
|
||||||
webViewContent = (WebView)findViewById(R.id.webViewContent);
|
|
||||||
webViewContent.setWebChromeClient(new WebChromeClient() {
|
|
||||||
public void onProgressChanged(WebView view, int progress) {
|
|
||||||
setProgress(progress * 100);
|
|
||||||
if(progress == 100) {
|
|
||||||
setProgressBarIndeterminateVisibility(false);
|
|
||||||
setProgressBarVisibility(false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
webViewContent.loadDataWithBaseURL("file:///android_asset/", htmlHeader + htmlContent + htmlFooter, "text/html", "utf-8", null);
|
webViewContent.loadDataWithBaseURL("file:///android_asset/", htmlHeader + htmlContent + htmlFooter, "text/html", "utf-8", null);
|
||||||
|
|
||||||
btnMarkRead = (Button)findViewById(R.id.btnMarkRead);
|
btnMarkRead = (Button) findViewById(R.id.btnMarkRead);
|
||||||
btnMarkRead.setOnClickListener(new OnClickListener() {
|
btnMarkRead.setOnClickListener(new OnClickListener() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -148,15 +115,4 @@ public class ReadArticle extends Activity {
|
|||||||
super.onDestroy();
|
super.onDestroy();
|
||||||
database.close();
|
database.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onOptionsItemSelected(MenuItem item) {
|
|
||||||
switch (item.getItemId()) {
|
|
||||||
case android.R.id.home:
|
|
||||||
this.finish();
|
|
||||||
return super.onOptionsItemSelected(item);
|
|
||||||
default:
|
|
||||||
return super.onOptionsItemSelected(item);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -1,54 +1,51 @@
|
|||||||
package fr.gaulupeau.apps.Poche;
|
package fr.gaulupeau.apps.Poche;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import fr.gaulupeau.apps.InThePoche.R;
|
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.text.Html;
|
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
import android.widget.BaseAdapter;
|
import android.widget.BaseAdapter;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import fr.gaulupeau.apps.InThePoche.R;
|
||||||
|
|
||||||
public class ReadingListAdapter extends BaseAdapter {
|
public class ReadingListAdapter extends BaseAdapter {
|
||||||
private Context context;
|
private Context context;
|
||||||
private List<Article> listArticles;
|
private List<Article> listArticles;
|
||||||
|
|
||||||
public ReadingListAdapter(Context context, List<Article> listArticles) {
|
public ReadingListAdapter(Context context, List<Article> listArticles) {
|
||||||
this.context = context;
|
this.context = context;
|
||||||
this.listArticles = listArticles;
|
this.listArticles = listArticles;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public int getCount() {
|
public int getCount() {
|
||||||
return listArticles.size();
|
return listArticles.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
public Object getItem(int position) {
|
public Object getItem(int position) {
|
||||||
return listArticles.get(position);
|
return listArticles.get(position);
|
||||||
}
|
}
|
||||||
|
|
||||||
public long getItemId(int position) {
|
public long getItemId(int position) {
|
||||||
return position;
|
return position;
|
||||||
}
|
}
|
||||||
|
|
||||||
public View getView(int position, View convertView, ViewGroup parent) {
|
|
||||||
Article entry = listArticles.get(position);
|
|
||||||
if (convertView == null) {
|
|
||||||
LayoutInflater inflater = (LayoutInflater) context
|
|
||||||
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
|
|
||||||
convertView = inflater.inflate(R.layout.article_list, null);
|
|
||||||
}
|
|
||||||
TextView tvTitle = (TextView) convertView.findViewById(R.id.listitem_titre);
|
|
||||||
//Log.e("title", entry.title);
|
|
||||||
tvTitle.setText(entry.title);
|
|
||||||
|
|
||||||
return convertView;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
public View getView(int position, View convertView, ViewGroup parent) {
|
||||||
|
Article entry = listArticles.get(position);
|
||||||
|
if (convertView == null) {
|
||||||
|
LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
|
||||||
|
convertView = inflater.inflate(R.layout.article_list, parent, false);
|
||||||
|
}
|
||||||
|
TextView tvTitle = (TextView) convertView.findViewById(R.id.listitem_titre);
|
||||||
|
TextView tvHost = (TextView) convertView.findViewById(R.id.listitem_textview_url);
|
||||||
|
|
||||||
|
tvTitle.setText(entry.title);
|
||||||
|
tvHost.setText(entry.getHostOfUrl());
|
||||||
|
|
||||||
|
return convertView;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,24 +1,22 @@
|
|||||||
package fr.gaulupeau.apps.Poche;
|
package fr.gaulupeau.apps.Poche;
|
||||||
|
|
||||||
import static fr.gaulupeau.apps.Poche.Helpers.PREFS_NAME;
|
|
||||||
import fr.gaulupeau.apps.InThePoche.R;
|
|
||||||
import android.app.Activity;
|
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
import android.os.Build;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.view.MenuItem;
|
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.View.OnClickListener;
|
import android.view.View.OnClickListener;
|
||||||
import android.widget.Button;
|
import android.widget.Button;
|
||||||
import android.widget.EditText;
|
import android.widget.EditText;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
public class Settings extends Activity {
|
import fr.gaulupeau.apps.InThePoche.R;
|
||||||
|
|
||||||
|
import static fr.gaulupeau.apps.Poche.Helpers.PREFS_NAME;
|
||||||
|
|
||||||
|
public class Settings extends BaseActionBarActivity {
|
||||||
Button btnDone;
|
Button btnDone;
|
||||||
EditText editPocheUrl;
|
EditText editPocheUrl;
|
||||||
EditText editAPIUsername;
|
EditText editAPIUsername;
|
||||||
EditText editAPIToken;
|
EditText editAPIToken;
|
||||||
EditText editGlobalToken;
|
|
||||||
TextView textViewVersion;
|
TextView textViewVersion;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -26,36 +24,28 @@ public class Settings extends Activity {
|
|||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
setContentView(R.layout.settings);
|
setContentView(R.layout.settings);
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
|
SharedPreferences settings = getSharedPreferences(PREFS_NAME, 0);
|
||||||
try {
|
String pocheUrl = settings.getString("pocheUrl", "http://");
|
||||||
getActionBar().setDisplayHomeAsUpEnabled(true);
|
String apiUsername = settings.getString("APIUsername", "");
|
||||||
} catch (Exception e) {
|
String apiToken = settings.getString("APIToken", "");
|
||||||
//
|
editPocheUrl = (EditText) findViewById(R.id.pocheUrl);
|
||||||
}
|
editPocheUrl.setText(pocheUrl);
|
||||||
}
|
editAPIUsername = (EditText) findViewById(R.id.APIUsername);
|
||||||
|
editAPIUsername.setText(apiUsername);
|
||||||
SharedPreferences settings = getSharedPreferences(PREFS_NAME, 0);
|
editAPIToken = (EditText) findViewById(R.id.APIToken);
|
||||||
String pocheUrl = settings.getString("pocheUrl", "http://");
|
editAPIToken.setText(apiToken);
|
||||||
String apiUsername = settings.getString("APIUsername", "");
|
btnDone = (Button) findViewById(R.id.btnDone);
|
||||||
String apiToken = settings.getString("APIToken", "");
|
btnDone.setOnClickListener(new OnClickListener() {
|
||||||
editPocheUrl = (EditText)findViewById(R.id.pocheUrl);
|
|
||||||
editPocheUrl.setText(pocheUrl);
|
|
||||||
editAPIUsername = (EditText)findViewById(R.id.APIUsername);
|
|
||||||
editAPIUsername.setText(apiUsername);
|
|
||||||
editAPIToken = (EditText)findViewById(R.id.APIToken);
|
|
||||||
editAPIToken.setText(apiToken);
|
|
||||||
btnDone = (Button)findViewById(R.id.btnDone);
|
|
||||||
btnDone.setOnClickListener(new OnClickListener() {
|
|
||||||
public void onClick(View v) {
|
public void onClick(View v) {
|
||||||
SharedPreferences settings = getSharedPreferences(PREFS_NAME, 0);
|
SharedPreferences settings = getSharedPreferences(PREFS_NAME, 0);
|
||||||
SharedPreferences.Editor editor = settings.edit();
|
SharedPreferences.Editor editor = settings.edit();
|
||||||
editor.putString("pocheUrl", editPocheUrl.getText().toString());
|
editor.putString("pocheUrl", editPocheUrl.getText().toString());
|
||||||
editor.putString("APIUsername", editAPIUsername.getText().toString());
|
editor.putString("APIUsername", editAPIUsername.getText().toString());
|
||||||
editor.putString("APIToken", editAPIToken.getText().toString());
|
editor.putString("APIToken", editAPIToken.getText().toString());
|
||||||
editor.commit();
|
editor.commit();
|
||||||
finish();
|
finish();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
try {
|
try {
|
||||||
textViewVersion = (TextView) findViewById(R.id.version);
|
textViewVersion = (TextView) findViewById(R.id.version);
|
||||||
textViewVersion.setText(getApplicationContext().getPackageManager().getPackageInfo(getApplicationContext().getPackageName(), 0).versionName);
|
textViewVersion.setText(getApplicationContext().getPackageManager().getPackageInfo(getApplicationContext().getPackageName(), 0).versionName);
|
||||||
@ -63,15 +53,4 @@ public class Settings extends Activity {
|
|||||||
//
|
//
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onOptionsItemSelected(MenuItem item) {
|
|
||||||
switch (item.getItemId()) {
|
|
||||||
case android.R.id.home:
|
|
||||||
this.finish();
|
|
||||||
return true;
|
|
||||||
default:
|
|
||||||
return super.onOptionsItemSelected(item);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
package fr.gaulupeau.apps.Poche;
|
package fr.gaulupeau.apps.Poche;
|
||||||
|
|
||||||
public class arrays {
|
public class arrays {
|
||||||
public static String[] PodcastTitle;
|
public static String[] PodcastTitle;
|
||||||
public static String[] PodcastURL;
|
public static String[] PodcastURL;
|
||||||
public static String[] PodcastContent;
|
public static String[] PodcastContent;
|
||||||
public static String[] PodcastMedia;
|
public static String[] PodcastMedia;
|
||||||
public static String[] PodcastDate;
|
public static String[] PodcastDate;
|
||||||
}
|
}
|
||||||
|
Before Width: | Height: | Size: 7.5 KiB After Width: | Height: | Size: 7.5 KiB |
@ -10,7 +10,8 @@
|
|||||||
<LinearLayout
|
<LinearLayout
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:orientation="vertical" >
|
android:orientation="vertical"
|
||||||
|
tools:ignore="WebViewLayout" >
|
||||||
|
|
||||||
<WebView
|
<WebView
|
||||||
android:id="@+id/webViewContent"
|
android:id="@+id/webViewContent"
|
||||||
|
@ -1,14 +1,22 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<LinearLayout
|
<LinearLayout
|
||||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
android:orientation="vertical" android:padding="10sp"
|
android:orientation="vertical" android:padding="8sp"
|
||||||
android:layout_width="fill_parent" android:layout_height="fill_parent" >
|
android:layout_width="fill_parent" android:layout_height="fill_parent" >
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/listitem_titre"
|
android:id="@+id/listitem_titre"
|
||||||
android:layout_width="fill_parent"
|
android:layout_width="fill_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:textSize="20sp"
|
android:textSize="18sp"
|
||||||
android:typeface="serif" />
|
android:textColor="@android:color/black"
|
||||||
|
android:paddingBottom="4sp"/>
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/listitem_textview_url"
|
||||||
|
android:layout_width="fill_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:textSize="12sp"
|
||||||
|
android:singleLine="true" />
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
@ -6,8 +6,6 @@
|
|||||||
<string name="author">GAULUPEAU Jonathan - 2013</string>
|
<string name="author">GAULUPEAU Jonathan - 2013</string>
|
||||||
<string name="instructions">Um eine Website zu speichern benutze einfach den <i>Teilen</i> Button deines Browsers und drücke dann auf <i>Bag it!</i>.\nDann wirst du zur Login-Seite deiner wallabag weitergeleitet. \nFertig!\nErfahre mehr über wallabag auf:\n http://www.wallabag.org</string>
|
<string name="instructions">Um eine Website zu speichern benutze einfach den <i>Teilen</i> Button deines Browsers und drücke dann auf <i>Bag it!</i>.\nDann wirst du zur Login-Seite deiner wallabag weitergeleitet. \nFertig!\nErfahre mehr über wallabag auf:\n http://www.wallabag.org</string>
|
||||||
<string name="btnDone">Speichern</string>
|
<string name="btnDone">Speichern</string>
|
||||||
<string name="which_browser">Welchen Browser möchtest du benutzen?</string>
|
|
||||||
<string name="authorSite">http://cv.gaulupeau.fr</string>
|
|
||||||
<string name="url_label"><b><u>Deine wallabag URL:</u></b></string>
|
<string name="url_label"><b><u>Deine wallabag URL:</u></b></string>
|
||||||
<string name="url_help">Beispiele:\n<i>http://wallabag.example.com</i>\n<i>http://www.example.com/wallabag</i></string>
|
<string name="url_help">Beispiele:\n<i>http://wallabag.example.com</i>\n<i>http://www.example.com/wallabag</i></string>
|
||||||
<string name="btnGetPost">Artikelliste - %1$d ungelesene</string>
|
<string name="btnGetPost">Artikelliste - %1$d ungelesene</string>
|
||||||
@ -17,10 +15,10 @@
|
|||||||
<string name="menuShowAll">Alle anzeigen</string>
|
<string name="menuShowAll">Alle anzeigen</string>
|
||||||
<string name="menuWipeDb">Datenbank leeren</string>
|
<string name="menuWipeDb">Datenbank leeren</string>
|
||||||
<string name="txtSyncDone">Synchronisieren erfolgreich!</string>
|
<string name="txtSyncDone">Synchronisieren erfolgreich!</string>
|
||||||
<string name="txtSyncFailed">Synchronisieren fehlgeschlagen!</string>
|
|
||||||
<string name="txtNetOffline">Internetverbindung prüfen!</string>
|
<string name="txtNetOffline">Internetverbindung prüfen!</string>
|
||||||
<string name="txtConfigNotSet">Bitte konfiguriere die App zunächst!</string>
|
<string name="txtConfigNotSet">Bitte konfiguriere die App zunächst!</string>
|
||||||
<string name="txtGlobalToken"><b><u>Globales API Token:</u></b></string>
|
|
||||||
<string name="txtAPIUsername"><b><u>Deine User ID:</u></b></string>
|
<string name="txtAPIUsername"><b><u>Deine User ID:</u></b></string>
|
||||||
<string name="txtAPIToken"><b><u>Dein Token:</u></b></string>
|
<string name="txtAPIToken"><b><u>Dein Token:</u></b></string>
|
||||||
|
<string name="error">Fehler</string>
|
||||||
|
<string name="error_feed">Fehler beim laden des Feeds</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
@ -1,5 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<resources>
|
|
||||||
<style name="app_theme" parent="android:Theme.Holo.Light"/>
|
|
||||||
<style name="mainActivity_theme" parent="android:Theme.Holo.Light" />
|
|
||||||
</resources>
|
|
@ -1,5 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<resources>
|
|
||||||
<style name="app_theme" parent="android:Theme.DeviceDefault.Light.DarkActionBar"/>
|
|
||||||
<style name="mainActivity_theme" parent="android:Theme.DeviceDefault.Light.NoActionBar" />
|
|
||||||
</resources>
|
|
@ -6,8 +6,6 @@
|
|||||||
<string name="author">GAULUPEAU Jonathan - 2013</string>
|
<string name="author">GAULUPEAU Jonathan - 2013</string>
|
||||||
<string name="instructions">To save a web page to wallabag, open the page in a browser then tap <i>Share</i> and tap on <i>Bag it!</i>. \nYou could then see your wallabag login page. \nAnd it\'s done ! \nMore infos about wallabag at:\n http://www.wallabag.org</string>
|
<string name="instructions">To save a web page to wallabag, open the page in a browser then tap <i>Share</i> and tap on <i>Bag it!</i>. \nYou could then see your wallabag login page. \nAnd it\'s done ! \nMore infos about wallabag at:\n http://www.wallabag.org</string>
|
||||||
<string name="btnDone">Save</string>
|
<string name="btnDone">Save</string>
|
||||||
<string name="which_browser">Which browser would you like to use?</string>
|
|
||||||
<string name="authorSite">http://cv.gaulupeau.fr</string>
|
|
||||||
<string name="url_label"><b><u>Your wallabag URL :</u></b></string>
|
<string name="url_label"><b><u>Your wallabag URL :</u></b></string>
|
||||||
<string name="url_help">Examples:\n<i>http://wallabag.example.fr</i>\n<i>http://www.example.fr/wallabag</i></string>
|
<string name="url_help">Examples:\n<i>http://wallabag.example.fr</i>\n<i>http://www.example.fr/wallabag</i></string>
|
||||||
<string name="btnGetPost">List articles - %1$d unread</string>
|
<string name="btnGetPost">List articles - %1$d unread</string>
|
||||||
@ -17,10 +15,10 @@
|
|||||||
<string name="menuShowAll">Show All</string>
|
<string name="menuShowAll">Show All</string>
|
||||||
<string name="menuWipeDb">Wipe Database</string>
|
<string name="menuWipeDb">Wipe Database</string>
|
||||||
<string name="txtSyncDone">Synchronize done !</string>
|
<string name="txtSyncDone">Synchronize done !</string>
|
||||||
<string name="txtSyncFailed">Synchronize failed !</string>
|
|
||||||
<string name="txtNetOffline">Check Internet Connectivity !</string>
|
<string name="txtNetOffline">Check Internet Connectivity !</string>
|
||||||
<string name="txtConfigNotSet">Please configure the app before Syncing !</string>
|
<string name="txtConfigNotSet">Please configure the app before Syncing !</string>
|
||||||
<string name="txtGlobalToken"><b><u>API global token :</u></b></string>
|
|
||||||
<string name="txtAPIUsername"><b><u>Your User ID:</u></b></string>
|
<string name="txtAPIUsername"><b><u>Your User ID:</u></b></string>
|
||||||
<string name="txtAPIToken"><b><u>Your Token:</u></b></string>
|
<string name="txtAPIToken"><b><u>Your Token:</u></b></string>
|
||||||
|
<string name="error">Error</string>
|
||||||
|
<string name="error_feed">Error loading feed</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<resources>
|
<resources>
|
||||||
<style name="app_theme" parent="android:Theme.Light"/>
|
<style name="app_theme" parent="Theme.AppCompat.Light.DarkActionBar"/>
|
||||||
<style name="mainActivity_theme" parent="android:Theme.Light.NoTitleBar" />
|
<style name="mainActivity_theme" parent="Theme.AppCompat.Light.NoActionBar" />
|
||||||
</resources>
|
</resources>
|
||||||
|
BIN
gradle/wrapper/gradle-wrapper.jar
vendored
Normal file
BIN
gradle/wrapper/gradle-wrapper.jar
vendored
Normal file
Binary file not shown.
6
gradle/wrapper/gradle-wrapper.properties
vendored
Normal file
6
gradle/wrapper/gradle-wrapper.properties
vendored
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
#Sun Jun 22 17:29:26 CEST 2014
|
||||||
|
distributionBase=GRADLE_USER_HOME
|
||||||
|
distributionPath=wrapper/dists
|
||||||
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
|
zipStorePath=wrapper/dists
|
||||||
|
distributionUrl=http\://services.gradle.org/distributions/gradle-1.12-all.zip
|
Loading…
Reference in New Issue
Block a user