diff --git a/app/build.gradle b/app/build.gradle
index b0ebe9e2b..83b4036c0 100644
--- a/app/build.gradle
+++ b/app/build.gradle
@@ -42,6 +42,7 @@ dependencies {
final DAGGER_VERSION = '2.0.1'
final HAMCREST_VERSION = '1.3'
final MOCKITO_VERSION = '1.10.19'
+ final STORIO_VERSION = '1.4.0'
compile fileTree(dir: 'libs', include: ['*.jar'])
@@ -54,8 +55,8 @@ dependencies {
compile 'com.squareup.retrofit:adapter-rxjava:2.0.0-beta1'
compile 'com.squareup.okhttp:okhttp-urlconnection:2.4.0'
compile 'com.squareup.okhttp:okhttp:2.4.0'
- compile 'com.pushtorefresh.storio:sqlite:1.4.0'
- compile 'com.pushtorefresh.storio:sqlite-annotations:1.4.0'
+ compile "com.pushtorefresh.storio:sqlite:$STORIO_VERSION"
+ compile "com.pushtorefresh.storio:sqlite-annotations:$STORIO_VERSION"
compile 'de.greenrobot:eventbus:2.4.0'
compile 'com.github.bumptech.glide:glide:3.6.1'
compile 'de.hdodenhof:circleimageview:1.3.0'
@@ -66,6 +67,7 @@ dependencies {
compile "com.google.dagger:dagger:$DAGGER_VERSION"
apt "com.google.dagger:dagger-compiler:$DAGGER_VERSION"
+ apt "com.pushtorefresh.storio:sqlite-annotations-processor:$STORIO_VERSION"
provided 'org.glassfish:javax.annotation:10.0-b28'
compile('com.mikepenz:materialdrawer:4.3.0@aar') {
diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml
index 445d7a99b..c6dbe092d 100644
--- a/app/src/main/AndroidManifest.xml
+++ b/app/src/main/AndroidManifest.xml
@@ -12,9 +12,9 @@
android:label="@string/app_name"
android:theme="@style/AppTheme" >
+ android:theme="@style/AppTheme.NoActionBar" >
@@ -22,14 +22,14 @@
-
-
-
-
-
-
+
+
+
diff --git a/app/src/main/java/eu/kanade/mangafeed/App.java b/app/src/main/java/eu/kanade/mangafeed/App.java
index 3e0039dcc..60fcbd186 100644
--- a/app/src/main/java/eu/kanade/mangafeed/App.java
+++ b/app/src/main/java/eu/kanade/mangafeed/App.java
@@ -27,6 +27,10 @@ public class App extends Application {
return mApplicationComponent;
}
+ public static AppComponent getComponent(Context context) {
+ return get(context).getComponent();
+ }
+
// Needed to replace the component with a test specific one
public void setComponent(AppComponent applicationComponent) {
mApplicationComponent = applicationComponent;
diff --git a/app/src/main/java/eu/kanade/mangafeed/AppComponent.java b/app/src/main/java/eu/kanade/mangafeed/AppComponent.java
index 765f1bf94..093ad1e99 100644
--- a/app/src/main/java/eu/kanade/mangafeed/AppComponent.java
+++ b/app/src/main/java/eu/kanade/mangafeed/AppComponent.java
@@ -7,6 +7,8 @@ import javax.inject.Singleton;
import dagger.Component;
import eu.kanade.mangafeed.data.DataModule;
import eu.kanade.mangafeed.ui.activity.MainActivity;
+import eu.kanade.mangafeed.ui.activity.MangaDetailActivity;
+import eu.kanade.mangafeed.ui.fragment.LibraryFragment;
@Singleton
@Component(
@@ -18,6 +20,8 @@ import eu.kanade.mangafeed.ui.activity.MainActivity;
public interface AppComponent {
void inject(MainActivity mainActivity);
+ void inject(LibraryFragment libraryFragment);
+ void inject(MangaDetailActivity mangaDetailActivity);
Application application();
}
\ No newline at end of file
diff --git a/app/src/main/java/eu/kanade/mangafeed/data/helpers/DatabaseHelper.java b/app/src/main/java/eu/kanade/mangafeed/data/helpers/DatabaseHelper.java
index 2b767e0f5..afa07905e 100644
--- a/app/src/main/java/eu/kanade/mangafeed/data/helpers/DatabaseHelper.java
+++ b/app/src/main/java/eu/kanade/mangafeed/data/helpers/DatabaseHelper.java
@@ -2,42 +2,44 @@ package eu.kanade.mangafeed.data.helpers;
import android.content.Context;
+import com.pushtorefresh.storio.sqlite.SQLiteTypeMapping;
import com.pushtorefresh.storio.sqlite.StorIOSQLite;
import com.pushtorefresh.storio.sqlite.impl.DefaultStorIOSQLite;
-import com.pushtorefresh.storio.sqlite.queries.Query;
-import java.util.List;
+import eu.kanade.mangafeed.data.managers.ChapterManager;
+import eu.kanade.mangafeed.data.models.Chapter;
+import eu.kanade.mangafeed.data.models.ChapterStorIOSQLiteDeleteResolver;
+import eu.kanade.mangafeed.data.models.ChapterStorIOSQLiteGetResolver;
+import eu.kanade.mangafeed.data.models.ChapterStorIOSQLitePutResolver;
+import eu.kanade.mangafeed.data.models.Manga;
+import eu.kanade.mangafeed.data.models.MangaStorIOSQLiteDeleteResolver;
+import eu.kanade.mangafeed.data.models.MangaStorIOSQLiteGetResolver;
+import eu.kanade.mangafeed.data.models.MangaStorIOSQLitePutResolver;
+import eu.kanade.mangafeed.data.managers.MangaManager;
-import eu.kanade.mangafeed.data.entities.Manga;
-import eu.kanade.mangafeed.data.tables.MangasTable;
-import rx.Observable;
-
-/**
- * Created by len on 23/09/2015.
- */
public class DatabaseHelper {
private StorIOSQLite db;
+ public MangaManager manga;
+ public ChapterManager chapter;
public DatabaseHelper(Context context) {
db = DefaultStorIOSQLite.builder()
.sqliteOpenHelper(new DbOpenHelper(context))
- .build();
- }
-
- public StorIOSQLite getStorIODb() {
- return db;
- }
-
- public Observable> getMangas() {
- return db.get()
- .listOfObjects(Manga.class)
- .withQuery(Query.builder()
- .table(MangasTable.TABLE)
+ .addTypeMapping(Manga.class, SQLiteTypeMapping.builder()
+ .putResolver(new MangaStorIOSQLitePutResolver())
+ .getResolver(new MangaStorIOSQLiteGetResolver())
+ .deleteResolver(new MangaStorIOSQLiteDeleteResolver())
.build())
- .prepare()
- .createObservable();
+ .addTypeMapping(Chapter.class, SQLiteTypeMapping.builder()
+ .putResolver(new ChapterStorIOSQLitePutResolver())
+ .getResolver(new ChapterStorIOSQLiteGetResolver())
+ .deleteResolver(new ChapterStorIOSQLiteDeleteResolver())
+ .build())
+ .build();
+ manga = new MangaManager(db);
+ chapter = new ChapterManager(db);
}
}
diff --git a/app/src/main/java/eu/kanade/mangafeed/data/helpers/DbOpenHelper.java b/app/src/main/java/eu/kanade/mangafeed/data/helpers/DbOpenHelper.java
index d3e0fcd4d..8354343c4 100644
--- a/app/src/main/java/eu/kanade/mangafeed/data/helpers/DbOpenHelper.java
+++ b/app/src/main/java/eu/kanade/mangafeed/data/helpers/DbOpenHelper.java
@@ -7,9 +7,6 @@ import android.support.annotation.NonNull;
import eu.kanade.mangafeed.data.tables.MangasTable;
-/**
- * Created by len on 23/09/2015.
- */
public class DbOpenHelper extends SQLiteOpenHelper {
public static final String DATABASE_NAME = "mangafeed.db";
diff --git a/app/src/main/java/eu/kanade/mangafeed/data/managers/BaseManager.java b/app/src/main/java/eu/kanade/mangafeed/data/managers/BaseManager.java
new file mode 100644
index 000000000..bab0ca881
--- /dev/null
+++ b/app/src/main/java/eu/kanade/mangafeed/data/managers/BaseManager.java
@@ -0,0 +1,12 @@
+package eu.kanade.mangafeed.data.managers;
+
+import com.pushtorefresh.storio.sqlite.StorIOSQLite;
+
+public abstract class BaseManager {
+
+ protected StorIOSQLite db;
+
+ public BaseManager(StorIOSQLite db) {
+ this.db = db;
+ }
+}
diff --git a/app/src/main/java/eu/kanade/mangafeed/data/managers/ChapterManager.java b/app/src/main/java/eu/kanade/mangafeed/data/managers/ChapterManager.java
new file mode 100644
index 000000000..daf9689a5
--- /dev/null
+++ b/app/src/main/java/eu/kanade/mangafeed/data/managers/ChapterManager.java
@@ -0,0 +1,33 @@
+package eu.kanade.mangafeed.data.managers;
+
+import com.pushtorefresh.storio.sqlite.StorIOSQLite;
+import com.pushtorefresh.storio.sqlite.queries.Query;
+
+import java.util.List;
+
+import eu.kanade.mangafeed.data.models.Chapter;
+import eu.kanade.mangafeed.data.models.Manga;
+import eu.kanade.mangafeed.data.tables.ChaptersTable;
+import rx.Observable;
+
+/**
+ * Created by len on 26/09/2015.
+ */
+public class ChapterManager extends BaseManager {
+
+ public ChapterManager(StorIOSQLite db) {
+ super(db);
+ }
+
+ public Observable> get(Manga manga) {
+ return db.get()
+ .listOfObjects(Chapter.class)
+ .withQuery(Query.builder()
+ .table(ChaptersTable.TABLE)
+ .where(ChaptersTable.COLUMN_MANGA_ID + "=?")
+ .whereArgs(manga.id)
+ .build())
+ .prepare()
+ .createObservable();
+ }
+}
diff --git a/app/src/main/java/eu/kanade/mangafeed/data/managers/MangaManager.java b/app/src/main/java/eu/kanade/mangafeed/data/managers/MangaManager.java
new file mode 100644
index 000000000..6a6519b0a
--- /dev/null
+++ b/app/src/main/java/eu/kanade/mangafeed/data/managers/MangaManager.java
@@ -0,0 +1,37 @@
+package eu.kanade.mangafeed.data.managers;
+
+import com.pushtorefresh.storio.sqlite.StorIOSQLite;
+import com.pushtorefresh.storio.sqlite.operations.put.PutResult;
+import com.pushtorefresh.storio.sqlite.queries.Query;
+
+import java.util.List;
+
+import eu.kanade.mangafeed.data.models.Manga;
+import eu.kanade.mangafeed.data.tables.MangasTable;
+import rx.Observable;
+
+public class MangaManager extends BaseManager {
+ List mangass;
+
+ public MangaManager(StorIOSQLite db) {
+ super(db);
+ }
+
+ public Observable> get() {
+ return db.get()
+ .listOfObjects(Manga.class)
+ .withQuery(Query.builder()
+ .table(MangasTable.TABLE)
+ .build())
+ .prepare()
+ .createObservable();
+ }
+
+ public Observable insert(Manga manga) {
+ return db.put()
+ .object(manga)
+ .prepare()
+ .createObservable();
+ }
+
+}
diff --git a/app/src/main/java/eu/kanade/mangafeed/data/models/Chapter.java b/app/src/main/java/eu/kanade/mangafeed/data/models/Chapter.java
new file mode 100644
index 000000000..030f7e8f4
--- /dev/null
+++ b/app/src/main/java/eu/kanade/mangafeed/data/models/Chapter.java
@@ -0,0 +1,67 @@
+package eu.kanade.mangafeed.data.models;
+
+import android.support.annotation.NonNull;
+import android.support.annotation.Nullable;
+
+import com.pushtorefresh.storio.sqlite.annotations.StorIOSQLiteColumn;
+import com.pushtorefresh.storio.sqlite.annotations.StorIOSQLiteType;
+
+import eu.kanade.mangafeed.data.tables.ChaptersTable;
+
+@StorIOSQLiteType(table = ChaptersTable.TABLE)
+public class Chapter {
+
+ @Nullable
+ @StorIOSQLiteColumn(name = ChaptersTable.COLUMN_ID, key = true)
+ public Long id;
+
+ @NonNull
+ @StorIOSQLiteColumn(name = ChaptersTable.COLUMN_MANGA_ID)
+ public int manga_id;
+
+ @NonNull
+ @StorIOSQLiteColumn(name = ChaptersTable.COLUMN_URL)
+ public String url;
+
+ @NonNull
+ @StorIOSQLiteColumn(name = ChaptersTable.COLUMN_NAME)
+ public String name;
+
+ @NonNull
+ @StorIOSQLiteColumn(name = ChaptersTable.COLUMN_READ)
+ public int read;
+
+ @NonNull
+ @StorIOSQLiteColumn(name = ChaptersTable.COLUMN_DATE_FETCH)
+ public long date_fetch;
+
+
+ public Chapter() {}
+
+ @Override
+ public boolean equals(Object o) {
+ if (this == o) return true;
+ if (o == null || getClass() != o.getClass()) return false;
+
+ Chapter chapter = (Chapter) o;
+
+ if (manga_id != chapter.manga_id) return false;
+ if (read != chapter.read) return false;
+ if (date_fetch != chapter.date_fetch) return false;
+ if (id != null ? !id.equals(chapter.id) : chapter.id != null) return false;
+ if (!url.equals(chapter.url)) return false;
+ return name.equals(chapter.name);
+
+ }
+
+ @Override
+ public int hashCode() {
+ int result = id != null ? id.hashCode() : 0;
+ result = 31 * result + manga_id;
+ result = 31 * result + url.hashCode();
+ result = 31 * result + name.hashCode();
+ result = 31 * result + read;
+ result = 31 * result + (int) (date_fetch ^ (date_fetch >>> 32));
+ return result;
+ }
+}
diff --git a/app/src/main/java/eu/kanade/mangafeed/data/entities/Manga.java b/app/src/main/java/eu/kanade/mangafeed/data/models/Manga.java
similarity index 97%
rename from app/src/main/java/eu/kanade/mangafeed/data/entities/Manga.java
rename to app/src/main/java/eu/kanade/mangafeed/data/models/Manga.java
index cf22206a0..4fb5483ad 100644
--- a/app/src/main/java/eu/kanade/mangafeed/data/entities/Manga.java
+++ b/app/src/main/java/eu/kanade/mangafeed/data/models/Manga.java
@@ -1,8 +1,4 @@
-package eu.kanade.mangafeed.data.entities;
-
-/**
- * Created by len on 23/09/2015.
- */
+package eu.kanade.mangafeed.data.models;
import android.support.annotation.NonNull;
import android.support.annotation.Nullable;
@@ -74,7 +70,7 @@ public class Manga {
@StorIOSQLiteColumn(name = MangasTable.COLUMN_CHAPTER_ORDER)
public int chapter_order;
- Manga() {}
+ public Manga() {}
public Manga(String title) {
this.title = title;
diff --git a/app/src/main/java/eu/kanade/mangafeed/ui/activity/MangaDetailActivity.java b/app/src/main/java/eu/kanade/mangafeed/ui/activity/MangaDetailActivity.java
new file mode 100644
index 000000000..183e18cbf
--- /dev/null
+++ b/app/src/main/java/eu/kanade/mangafeed/ui/activity/MangaDetailActivity.java
@@ -0,0 +1,56 @@
+package eu.kanade.mangafeed.ui.activity;
+
+import android.support.v7.app.AppCompatActivity;
+import android.os.Bundle;
+import android.view.Menu;
+import android.view.MenuItem;
+
+import de.greenrobot.event.EventBus;
+import eu.kanade.mangafeed.R;
+import eu.kanade.mangafeed.data.models.Manga;
+
+public class MangaDetailActivity extends AppCompatActivity {
+
+ Manga manga;
+
+ @Override
+ protected void onCreate(Bundle savedInstanceState) {
+ super.onCreate(savedInstanceState);
+ setContentView(R.layout.activity_manga_detail);
+ EventBus.getDefault().registerSticky(this);
+ }
+
+ @Override
+ public boolean onCreateOptionsMenu(Menu menu) {
+ // Inflate the menu; this adds items to the action bar if it is present.
+ getMenuInflater().inflate(R.menu.menu_manga_detail, menu);
+ return true;
+ }
+
+ @Override
+ public boolean onOptionsItemSelected(MenuItem item) {
+ // Handle action bar item clicks here. The action bar will
+ // automatically handle clicks on the Home/Up button, so long
+ // as you specify a parent activity in AndroidManifest.xml.
+ int id = item.getItemId();
+
+ //noinspection SimplifiableIfStatement
+ if (id == R.id.action_settings) {
+ return true;
+ }
+
+ return super.onOptionsItemSelected(item);
+ }
+
+ @Override
+ public void onDestroy() {
+ EventBus.getDefault().unregister(this);
+
+ super.onDestroy();
+ }
+
+ public void onEvent(Manga manga) {
+ this.manga = manga;
+ //loadChapters();
+ }
+}
diff --git a/app/src/main/java/eu/kanade/mangafeed/ui/adapter/LibraryAdapter.java b/app/src/main/java/eu/kanade/mangafeed/ui/adapter/LibraryAdapter.java
index d0aec712e..ef1f53a4a 100644
--- a/app/src/main/java/eu/kanade/mangafeed/ui/adapter/LibraryAdapter.java
+++ b/app/src/main/java/eu/kanade/mangafeed/ui/adapter/LibraryAdapter.java
@@ -11,12 +11,12 @@ import android.widget.TextView;
import com.bumptech.glide.Glide;
-import java.util.ArrayList;
+import java.util.List;
import butterknife.Bind;
import butterknife.ButterKnife;
import eu.kanade.mangafeed.R;
-import eu.kanade.mangafeed.data.entities.Manga;
+import eu.kanade.mangafeed.data.models.Manga;
import uk.co.ribot.easyadapter.annotations.LayoutId;
/**
@@ -28,9 +28,9 @@ public class LibraryAdapter extends ArrayAdapter {
Context context;
int layoutResourceId;
- ArrayList data;
+ List data;
- public LibraryAdapter(Context context, int layoutResourceId, ArrayList data) {
+ public LibraryAdapter(Context context, int layoutResourceId, List data) {
super(context, layoutResourceId, data);
this.context = context;
this.layoutResourceId = layoutResourceId;
diff --git a/app/src/main/java/eu/kanade/mangafeed/ui/fragment/LibraryFragment.java b/app/src/main/java/eu/kanade/mangafeed/ui/fragment/LibraryFragment.java
index 4ed4dc3d3..22579f659 100644
--- a/app/src/main/java/eu/kanade/mangafeed/ui/fragment/LibraryFragment.java
+++ b/app/src/main/java/eu/kanade/mangafeed/ui/fragment/LibraryFragment.java
@@ -1,26 +1,38 @@
package eu.kanade.mangafeed.ui.fragment;
-import android.os.Bundle;
import android.app.Fragment;
+import android.content.Intent;
+import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.GridView;
-import java.util.ArrayList;
+import java.util.List;
+
+import javax.inject.Inject;
import butterknife.Bind;
import butterknife.ButterKnife;
+import de.greenrobot.event.EventBus;
+import eu.kanade.mangafeed.App;
import eu.kanade.mangafeed.R;
-import eu.kanade.mangafeed.data.entities.Manga;
+import eu.kanade.mangafeed.data.helpers.DatabaseHelper;
+import eu.kanade.mangafeed.data.models.Manga;
import eu.kanade.mangafeed.ui.activity.BaseActivity;
import eu.kanade.mangafeed.ui.adapter.LibraryAdapter;
+import rx.functions.Action1;
public class LibraryFragment extends Fragment {
@Bind(R.id.gridView)
GridView grid;
+ @Inject
+ DatabaseHelper db;
+
+ List mangas;
+
public static LibraryFragment newInstance() {
LibraryFragment fragment = new LibraryFragment();
Bundle args = new Bundle();
@@ -33,19 +45,27 @@ public class LibraryFragment extends Fragment {
Bundle savedInstanceState) {
// Inflate the layout for this fragment
View view = inflater.inflate(R.layout.fragment_library, container, false);
+ App.getComponent(getActivity()).inject(this);
((BaseActivity) getActivity()).getSupportActionBar().setTitle(R.string.library_title);
-
ButterKnife.bind(this, view);
- ArrayList mangas = new ArrayList<>();
- mangas.add(new Manga("One Piece"));
- mangas.add(new Manga("Berserk"));
- mangas.add(new Manga("Fate/stay night: Unlimited Blade Works"));
+ db.manga.get().subscribe(
+ result -> {
+ mangas = result;
- LibraryAdapter adapter = new LibraryAdapter(getActivity(),
- R.layout.item_library, mangas);
+ LibraryAdapter adapter = new LibraryAdapter(getActivity(),
+ R.layout.item_library, mangas);
- grid.setAdapter(adapter);
+ grid.setAdapter(adapter);
+ grid.setOnItemClickListener(
+ (parent, v, position, id) -> {
+ Intent intent = new Intent(".ui.activity.MangaDetailActivity");
+ EventBus.getDefault().postSticky(adapter.getItem(position));
+ startActivity(intent);
+ }
+ );
+ }
+ );
return view;
}
diff --git a/app/src/main/res/layout/activity_manga_detail.xml b/app/src/main/res/layout/activity_manga_detail.xml
new file mode 100644
index 000000000..469662e58
--- /dev/null
+++ b/app/src/main/res/layout/activity_manga_detail.xml
@@ -0,0 +1,18 @@
+
+
+
+
+
diff --git a/app/src/main/res/layout/item_chapter.xml b/app/src/main/res/layout/item_chapter.xml
new file mode 100644
index 000000000..74e72cb48
--- /dev/null
+++ b/app/src/main/res/layout/item_chapter.xml
@@ -0,0 +1,60 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/app/src/main/res/menu/menu_manga_detail.xml b/app/src/main/res/menu/menu_manga_detail.xml
new file mode 100644
index 000000000..4f27727c0
--- /dev/null
+++ b/app/src/main/res/menu/menu_manga_detail.xml
@@ -0,0 +1,7 @@
+
diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml
index 5cc5ab3b9..400af76be 100644
--- a/app/src/main/res/values/strings.xml
+++ b/app/src/main/res/values/strings.xml
@@ -26,5 +26,9 @@
Recent updates
Catalogues
Settings
+ MangaDetailActivity
+
+ Hello world!
+ Settings