Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/patrickyin/clean-architecture-android-kotlin
Using Uncle Bob's clean architecture with Kotlin language and the latest Android technologies(Rx, Dagger2 etc.).
https://github.com/patrickyin/clean-architecture-android-kotlin
Last synced: 5 days ago
JSON representation
Using Uncle Bob's clean architecture with Kotlin language and the latest Android technologies(Rx, Dagger2 etc.).
- Host: GitHub
- URL: https://github.com/patrickyin/clean-architecture-android-kotlin
- Owner: patrickyin
- License: apache-2.0
- Created: 2018-03-18T07:08:56.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2019-04-18T00:06:53.000Z (over 5 years ago)
- Last Synced: 2024-08-16T16:49:21.622Z (4 months ago)
- Language: Kotlin
- Homepage:
- Size: 407 KB
- Stars: 331
- Watchers: 15
- Forks: 46
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-android - Android Clean Architecture - Kotlin - A base project using the Uncle Bob's clean architecture with Kotlin language and the latest Android technologies. (Development Alternatives / Kotlin)
- awesome-android-complete-reference - Android Clean Architecture - Kotlin - A base project using the Uncle Bob's clean architecture with Kotlin language and the latest Android technologies. (Uncategorized / Uncategorized)
- awesome-android - Android Clean Architecture - Kotlin - A base project using the Uncle Bob's clean architecture with Kotlin language and the latest Android technologies. (Development Alternatives / Kotlin)
README
# Android Clean Architecture - Kotlin
[![Build Status](https://travis-ci.org/patrickyin/clean-architecture-android-kotlin.svg?branch=master)](https://travis-ci.org/patrickyin/clean-architecture-android-kotlin) [![Android Arsenal](https://img.shields.io/badge/Android%20Arsenal-clean--architecture--android--kotlin-green.svg?style=flat )]( https://android-arsenal.com/details/1/6851)
***This is an Android Clean Architecture base project using 100% Kotlin including Unit tests!***
You could use it as the base project when you create a new Android project. This architecture optimized the Clean Architecture and MVP for the Android Kotlin project. When using this architecture, you could isolate the UI, business logic and data sources, and also making the unit test easier. It uses latest and most popular technologies e.g. Dagger2, RxJava etc.
## Benefit
* Makes your new project clean
* Isolates UI, business logic and data sources' responsibilities
* Testable
* Avoids multi-threading problems## Approach of Clean Architecture for Android
There are 3 layers in the project: Data, Domain and Presentation(UI), and the UI layer contains view and presenters.![Approach of Clean Architecture for Android - Patrick Yin](./clean_architecture_pyin.png)
## Multi-threading
Base `UseCase` class handles the thread of Rx chains, it puts whole chain on IO thread, and then changes back to Android main thread(UI thread) for the steps after use case execution. That means when you write the project based on this project, then you don't have to worry about any multi-threading issue.## Requirements & configurations
#### Requirements
- JDK 8
- Android SDK API 26
- Kotlin Gradle plugin 1.2.30 *(it will be installed automatically when this project is synced)*#### Configurations
- minSdkVersion=21
- targetSdkVersion=26## Language
* [Kotlin](https://kotlinlang.org/)## Libraries
* [AndroidX](https://developer.android.com/jetpack/androidx)
* [Dagger 2](https://google.github.io/dagger/)
* [RxJava2](https://github.com/ReactiveX/RxJava/wiki/What's-different-in-2.0)
* [RxAndroid](https://github.com/ReactiveX/RxAndroid)
* [OkHttp](http://square.github.io/okhttp/)
* [Retrofit](http://square.github.io/retrofit/)
* [Gson](https://github.com/google/gson)
* [JUnit 4](https://junit.org/junit4/)
* [Mockito](http://site.mockito.org/)
* [PowerMock](https://github.com/powermock/powermock/)
* [Espresso](https://developer.android.com/training/testing/espresso/index.html)## More about The Clean Architecture
[The Clean Architecture](https://8thlight.com/blog/uncle-bob/2012/08/13/the-clean-architecture.html)
[S.O.L.I.D Principle](https://en.wikipedia.org/wiki/SOLID_(object-oriented_design))
More articles available on my blog:
## TODO
## Bugs and Feedback
For bugs, feature requests, and discussion please use [GitHub Issues](https://github.com/patrickyin/clean-architecture-android-kotlin/issues). For general usage questions please use the [StackOverflow](https://stackoverflow.com/questions/tagged/clean-architecture%20&%20android%20&%20kotlin).
## License
```
Copyright 2017 Patrick YinLicensed 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 athttp://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.
```