Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/derohimat/android-base-mvp

Android Base MVP Concept with RXJava, Dagger, Event Bus, Retrofit, Glide, OkHTTP
https://github.com/derohimat/android-base-mvp

android architecture dagger example-project mvp mvp-concept okhttp rxjava sign

Last synced: about 1 month ago
JSON representation

Android Base MVP Concept with RXJava, Dagger, Event Bus, Retrofit, Glide, OkHTTP

Awesome Lists containing this project

README

        

[![Android Arsenal](https://img.shields.io/badge/Android%20Arsenal-Android%20Base%20MVP%20Concept-blue.svg?style=flat)](https://android-arsenal.com/details/1/4213)

[ ![Download](https://api.bintray.com/packages/derohimat/BaseApp/android-base-mvp/images/download.svg?version=2.0.1) ](https://bintray.com/derohimat/BaseApp/android-base-mvp/2.0.1/link)

# Android Base MVP Concept

### Architecture

### Requirements :
Min SDK Version 15
Target SDK Version 27
Check the compileSdkVersion, and buildToolsVersion to be the latest
Build Tools Version 27.0.3
Java 1.8

### Step by step

Step 1. Add it in your root build.gradle at the end of repositories:

allprojects {
repositories {
...
maven { url "https://jitpack.io" }
}
}

Step 2. Add the dependency

dependencies {
compile 'com.github.derohimat:android-base-mvp:1.0'
}

Step 3. Add this library for version **0.4 and up**

//----- The core of Reactive Programming
compile 'io.reactivex:rxjava:1.2.5'
compile 'io.reactivex:rxandroid:1.2.1'

Step 4. Change **```extends MvpView```** to **```extends BaseView```**

Step 5. Modify applicationId "**net.derohimat.samplebasemvp**" to your package name

Step 6. Profit

Step 7. Star this repository :)

## How to implement a new screen following MVP

Imagine you have to implement a sign in screen.

1. Create a new package under ui called signin
2. Create an new Activity called **```ActivitySignIn```**. You could also use a Fragment.
3. Define the view interface that your Activity is going to implement. Create a new interface called **```SignInView```** that extends **```BaseView```**. Add the methods that you think will be necessary, e.g. **```showSignInSuccessful()```**
4. Create a **```SignInPresenter```** class that extends **```BasePresenter```**
5. Implement the methods in **```SignInPresenter```** that your Activity requires to perform the necessary actions, e.g. **```signIn(String email)```**. Once the sign in action finishes you should call **```getView().showSignInSuccessful()```**.
6. Create a **```SignInPresenterTest```** and write unit tests for **```signIn(email)```**. Remember to mock the **```SignInView```** and also the DataManager.
7. Make your **```ActivitySignIn implement SignInView```** and implement the required methods like **```showSignInSuccessful()```**
8. In your activity, inject a new instance of **```SignInPresenter```** and call **```presenter.attachView(this)```** from onCreate and **```presenter.detachView()```** from **```onDestroy()```**. Also, set up a click listener in your button that calls **```presenter.signIn(email)```**.

### Library :
- [Retrofit 2](http://square.github.io/retrofit/)
- [OkHTTP 3](http://square.github.io/okhttp/)
- [RXJava](https://github.com/ReactiveX/RxJava)
- [Dagger 2](http://google.github.io/dagger/)
- [Event Bus](https://github.com/greenrobot/EventBus)
- [XRecyclerView](https://github.com/jianghejie/XRecyclerView)
- [Butterknife 7](https://github.com/JakeWharton/butterknife)

### Inspired by

https://github.com/AndreiD/UltimateAndroidTemplateRx

https://github.com/zetbaitsu/Benih

### License
Copyright 2016 Deni Rohimat

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.