• Stars
    star
    514
  • Rank 86,040 (Top 2 %)
  • Language
    Kotlin
  • License
    MIT License
  • Created over 5 years ago
  • Updated 2 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

A sample Kotlin app which was built with modular structure, Kotlin DSL, Kotlin Coroutines, TDD and MVVM patterns.

A sample modern Kotlin application - Documentation still under maintenance

ktlint Codacy Badge codebeat badge CodeFactor Kotlin Version API License

This project is a sample that presents modern, the recent approach to Android application development using Kotlin and latest technology stack.

The goal of the project is to demonstrate best practices, provide a set of guidelines, and present modern Android application architecture that is modular, scalable, maintainable and testable. This application may look simple, but it has all of these small details that will set the rock-solid foundation of the larger app suitable for bigger teams and long application lifecycle management.

💥 Powered by TvMaze.

License

Table of Contents

Development

Environment setup

First off, you require the latest Android Studio 3.5 (or newer) to be able to build the app.

Moreover, to sign your app for release you should generate an upload key and keystore following the official documentation. Append the information used to generate it into local.properties project root file following the structure:

#Signing Config
signing.key.alias = <insert>
signing.key.password = <insert>
signing.store.file = <insert>
signing.store.password = <insert>

Code style

To maintain the style and quality of the code, are used the bellow static analysis tools. All of them use properly configuration and you find them in the project root directory .{toolName}.

Tools Config file Check command Fix command
detekt /config/detekt ./gradlew detekt ./gradlew detektFormat or ./gradlew detektAll
ktlint - ./gradlew ktlint ./gradlew ktlintFormat
spotless /spotless ./gradlew spotlessCheck ./gradlew spotlessApply
lint each module ./gradlew lint -

All these tools are integrated in pre-commit git hook, in order ensure that all static analysis and tests passes before you can commit your changes. To skip them for specific commit add this option at your git command:

git commit --no-verify

The pre-commit git hooks have exactly the same checks as CircleCI and are defined in this script. This step ensures that all commits comply with the established rules. However the continuous integration will ultimately be validated that the changes are correct.

Design

App support different screen sizes and the content has been adapted to fit for mobile devices and tablets. To do that, it has been created a flexible layout using one or more of the following concepts:

In terms of design has been followed recommendations Android Material Design comprehensive guide for visual, motion, and interaction design across platforms and devices. Granting the project in this way a great user experience (UX) and user interface (UI). For more info about UX best practices visit link.

Moreover, has been implemented support for dark theme with the following benefits:

  • Can reduce power usage by a significant amount (depending on the device’s screen technology).
  • Improves visibility for users with low vision and those who are sensitive to bright light.
  • Makes it easier for anyone to use a device in a low-light environment.

Architecture

The architecture of the application is based, apply and strictly complies with each of the following 5 points:

Modules

Modules are collection of source files and build settings that allow you to divide a project into discrete units of functionality. In this case apart from dividing by functionality/responsibility, existing the following dependence between them:

The above graph shows the app modularisation:

  • :app module depends on :base, :data, :domain and :test-shared
  • :data module depends on :base and :test-shared.
  • :domain module depends on :base, :data and :test-shared
  • :base doesn’t have any dependency.

App module

The :app module is an com.android.application, which is needed to create the app bundle. It is also responsible for initiating the dependency graph, play core and another project global libraries, differentiating especially between different app environments.

Base module

The :base module is an com.android.library only contains code and resources which are shared between other modules. Reusing this way resources, layouts, views, and components in the different modules, without the need to duplicate code.

Data module

The :data module is an com.android.library for serving network requests or accessing to the database. Providing the data source for the many features that require it.

Domain module

The :domain module is an com.android.library lays a bridge between data and view layers. It performs any business logic getting data from data module and serves to view.

Test shared module

The :test-shared module is an com.android.library, basically contains test utilities that can be used by the different modules.

Architecture components

Ideally, ViewModels shouldn’t know anything about Android. This improves testability, leak safety and modularity. ViewModels have different scopes than activities or fragments. While a ViewModel is alive and running, an activity can be in any of its lifecycle states. Activities and fragments can be destroyed and created again while the ViewModel is unaware.

Passing a reference of the View (activity or fragment) to the ViewModel is a serious risk. Lets assume the ViewModel requests data from the network and the data comes back some time later. At that moment, the View reference might be destroyed or might be an old activity that is no longer visible, generating a memory leak and, possibly, a crash.

The communication between the different layers follow the above diagram using the reactive paradigm, observing changes on components without need of callbacks avoiding leaks and edge cases related with them.

Documentation

The documentation is generated following KDoc language (the equivalent of Java's JavaDoc) via documentation engine for Kotlin Dokka.

To consult it check this link or open the project /docs directory.

Tech-stack

This project takes advantage of many popular libraries, plugins and tools of the Android ecosystem. Most of the libraries are in the stable version, unless there is a good reason to use non-stable dependency.

Mainly on:

  • Kotlin - Kotlin is a cross-platform, statically typed, general-purpose programming language with type inference.
  • Kotlin DSL - Basically, a DSL is a language that focuses on just one particular part of an application. A general-purpose language, such as Kotlin or Java, on the other hand, can be used in multiple parts of one application.

Patterns

  • Repository Pattern - The Repository Pattern is one of the most popular patterns to create an enterprise level application. It restricts us to work directly with the data in the application and creates new layers for database operations, business logic, and the application's UI.
  • Observer Pattern - The observer pattern is a software design pattern in which an object, called the subject, maintains a list of its dependents, called observers, and notifies them automatically of any state changes, usually by calling one of their methods.
  • UseCase Pattern - This pattern means to convert and pass user actions to inner layers of the application.
  • Delegation Pattern - In software engineering, the delegation pattern is an object-oriented design pattern that allows object composition to achieve the same code reuse as inheritance.
  • TDD - Test-driven development (TDD) is a software development process that relies on the repetition of a very short development cycle: requirements are turned into very specific test cases, then the software is improved so that the tests pass.

Dependencies

  • Jetpack:
    • Android KTX - provide concise, idiomatic Kotlin to Jetpack and Android platform APIs.
    • AndroidX - major improvement to the original Android Support Library, which is no longer maintained.
    • Data Binding - allows you to bind UI components in your layouts to data sources in your app using a declarative format rather than programmatically.
    • Lifecycle - perform actions in response to a change in the lifecycle status of another component, such as activities and fragments.
    • LiveData - lifecycle-aware, meaning it respects the lifecycle of other app components, such as activities, fragments, or services.
    • ViewModel - designed to store and manage UI-related data in a lifecycle conscious way. The ViewModel class allows data to survive configuration changes such as screen rotations.
  • Coroutines - managing background threads with simplified code and reducing needs for callbacks.
  • Dagger2 - dependency injector for replacement all FactoryFactory classes.
  • Retrofit2 - type-safe HTTP client.
  • Glide - image loading library for Android.
  • Gson - makes it easy to parse JSON into Kotlin objects.
  • Timber - a logger with a small, extensible API which provides utility on top of Android's normal Log class.
  • and more...

Test dependencies

  • Espresso - to write concise, beautiful, and reliable Android UI tests
  • JUnit - a simple framework to write repeatable tests. It is an instance of the xUnit architecture for unit testing frameworks.
  • Mockito - most popular Mocking framework for unit tests written in Java.
  • Mockk - provides DSL to mock behavior. Built from zero to fit Kotlin language.
  • AndroidX - the androidx test library provides an extensive framework for testing Android apps.
  • and more...

Plugins

  • Ktlint - an anti-bikeshedding Kotlin linter with built-in formatter.
  • Detekt - a static code analysis tool for the Kotlin programming language.
  • Spotless - a code formatter can do more than just find formatting errors.
  • Versions - make easy to determine which dependencies have updates.
  • Jacoco - code coverage library
  • and more...

Resources

Projects

This is project is a sample, to inspire you and should handle most of the common cases, but obviously not all. If you need to take a look at additional resources to find solutions for your project, visit these interesting projects:

Articles

A collection of very interesting articles related last android community tendencies and recommendations for start to take in consideration for your current/next project:

Libraries

The open-source community create and maintains tons of awesome libraries making your job more easy, giving the opportunity to use them in your developments. Here are a very important collection of them:

Best practices

Avoid reinventing the wheel by following these guidelines:

Codelabs

Google Developers Codelabs provide a guided, tutorial, hands-on coding experience. Most codelabs will step you through the process of building a small application, or adding a new feature to an existing application. They cover a wide range of android concepts to learn and practice:

Contributions

All contributions are welcome! Please feel free to post questions, recommendations, ideas, bugs by create new issue following the template or if you want create directly new pull request.

Roadmap:

  • - A detail screen to be added
  • - Cards to have more detail
  • - Some screenshots to be added
  • - Write common DSL scripts

License

Copyright 2019 nuhkoca.com

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.

More Repositories

1

kotlin-android-fastlane-firebase-app-distribution

A repository that shows how to use Firebase App Distribution to distribute android app to testers by fastlane.
Ruby
92
star
2

DaggerExoPlayer

This repository demonstrates ExoPlayer injection with Dagger2
Kotlin
58
star
3

libbra

A currency tracker app demonstration. It refreshes currency list every single second based on the main currency. In addition to that, main currency is selectable.
Kotlin
53
star
4

NewsApp-MVVM-AAC-Room-DataBinding-RxJava2-Retrofit2-Glide4

A showcase and a playground with MVVM, Android Architecture Components, Room Persistence Library, DataBinding, RxJava2, Retrofit2, Glide4 and so on.
Java
36
star
5

market_tech_challenge

A best use case Android application sample with latest patterns. This app is developer as part of Kariyer.net Tech Challenge.
Kotlin
32
star
6

Trippo-The_Travel_Guide

Trippo is your smart travel guide - it’s free and works offline, too! You can skim through tours, locations, POIs, city walks, articles and so on. This guide will save you from a serious headache!
Java
32
star
7

AndroidRecommendedArchitecture

This is the recommended Android architecture by Google that can support both online and offline work.
Kotlin
22
star
8

tinder-scarlet-websocket-sample

This sample project demonstrate how to fetch crypto currency info using Scarlet Websocket library of Tinder.
Kotlin
19
star
9

HiltDataBindingSample

As I thought of that the gist piece doesn't seem to be clear enough to be understood by developers, I decided to create this sample repository. Hope this clears things up for you!
Kotlin
19
star
10

vivy-challenge

A doctor finder for you!
Kotlin
17
star
11

scenic_hiking

Scenic Hiking is a hiking app that users can choose locations and navigate to them accordingly.
Kotlin
13
star
12

udacity-xyz-reader-app

This project is the fifth task of the Udacity Google Android Developer Nanodegree Scholarship.
Java
12
star
13

BestCoin

A cryptocurrency app
Java
11
star
14

GlideAppModuleSample

This repository demonstrates usage of AppGlideModule of Glide library
Java
10
star
15

udacity-baking-app

This project is the third task of the Udacity Google Android Developer Nanodegree Scholarship.
Java
6
star
16

nuhkoca

5
star
17

activity-box

⚡️📌 Update a pinned gist to contain the latest activity of a user
5
star
18

deep-learning-cross-entropy

Cross Entropy approach in Deep Learning as part of Udacity Pytorch Nanodegree
Python
4
star
19

firebase-mlkit-samples

This repository is a showcase for text, face and label recognization using Firebase ML Kit
Java
3
star
20

mao-trailer-app

A movie/tv series app using Dagger, Retrofit, RxJava, DataBinding and Room.
Java
3
star
21

package-management-mvp

Java
2
star
22

DataBindingInterface

Java
2
star
23

FirebaseFunctions

JavaScript
2
star
24

Proje-Bulteni-Android-App

An Android App that I developed for a NPO (Web service doesn't work anymore)
Java
2
star
25

udacity-movie-app

This project is the second task of the Udacity Google Android Developer Nanodegree Scholarship.
Java
2
star
26

deep-learning-softmax

Softmax approach in Deep Learning as part of Udacity Pytorch Nanodegree
Python
1
star
27

ktlint-sample

Kotlin
1
star
28

deep-learning-perceptron

Perceptron approach in Deep Learning as part of Udacity Pytorch Nanodegree
Python
1
star
29

udacity-builditbigger-app

This project is the fourth task of the Android Nanodegree Scholarship.
Java
1
star
30

MVPCleanCodeDemo

RxJava, Dagger, Retrofit = MVP
Java
1
star
31

mvvm-with-testing

This repo is a sample app that works with MVVM and Espresso testing.
Java
1
star
32

udacity-sandwich-club-starter-code

This project is the first task of the Udacity Google Android Developer Nanodegree Scholarship.
Java
1
star
33

buildSrc-precompiled-script-sample

Kotlin
1
star
34

github-slideshow

A robot powered training repository 🤖
Ruby
1
star