├── app
├── .gitignore
├── src
│ └── main
│ │ ├── res
│ │ ├── mipmap-hdpi
│ │ │ └── ic_launcher.png
│ │ ├── mipmap-mdpi
│ │ │ └── ic_launcher.png
│ │ ├── mipmap-xhdpi
│ │ │ └── ic_launcher.png
│ │ ├── mipmap-xxhdpi
│ │ │ └── ic_launcher.png
│ │ ├── mipmap-xxxhdpi
│ │ │ └── ic_launcher.png
│ │ ├── values
│ │ │ ├── colors.xml
│ │ │ ├── styles.xml
│ │ │ ├── arrays.xml
│ │ │ ├── strings.xml
│ │ │ └── ids.xml
│ │ ├── values-v21
│ │ │ └── styles.xml
│ │ └── drawable
│ │ │ └── bg_arrow_back.xml
│ │ ├── kotlin
│ │ └── com
│ │ │ └── baculsoft
│ │ │ └── sample
│ │ │ └── kotlinreactive
│ │ │ ├── ext
│ │ │ └── CommonExt.kt
│ │ │ ├── main
│ │ │ ├── MainActivity.kt
│ │ │ ├── MainItemUI.kt
│ │ │ ├── MainUI.kt
│ │ │ └── MainAdapter.kt
│ │ │ ├── observable
│ │ │ ├── ObservableActivity.kt
│ │ │ └── ObservableUI.kt
│ │ │ ├── flowable
│ │ │ ├── FlowableActivity.kt
│ │ │ └── FlowableUI.kt
│ │ │ ├── single
│ │ │ ├── SingleActivity.kt
│ │ │ └── SingleUI.kt
│ │ │ ├── completable
│ │ │ ├── CompletableActivity.kt
│ │ │ └── CompletableUI.kt
│ │ │ └── maybe
│ │ │ ├── MaybeActivity.kt
│ │ │ └── MaybeUI.kt
│ │ └── AndroidManifest.xml
├── proguard-rules.pro
└── build.gradle
├── settings.gradle
├── README.md
├── gradle
└── wrapper
│ ├── gradle-wrapper.jar
│ └── gradle-wrapper.properties
├── .gitignore
├── gradlew.bat
├── gradlew
└── LICENSE
/app/.gitignore:
--------------------------------------------------------------------------------
1 | /build
2 |
--------------------------------------------------------------------------------
/settings.gradle:
--------------------------------------------------------------------------------
1 | include ':app'
2 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # Reactive Concept With Kotlin
2 | Reactive Programming Concept Using RxJava and RxAndroid with Kotlin
3 |
--------------------------------------------------------------------------------
/gradle/wrapper/gradle-wrapper.jar:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/KotlinID/reactive-concept-kotlin/HEAD/gradle/wrapper/gradle-wrapper.jar
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-hdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/KotlinID/reactive-concept-kotlin/HEAD/app/src/main/res/mipmap-hdpi/ic_launcher.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-mdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/KotlinID/reactive-concept-kotlin/HEAD/app/src/main/res/mipmap-mdpi/ic_launcher.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/KotlinID/reactive-concept-kotlin/HEAD/app/src/main/res/mipmap-xhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xxhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/KotlinID/reactive-concept-kotlin/HEAD/app/src/main/res/mipmap-xxhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/KotlinID/reactive-concept-kotlin/HEAD/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png
--------------------------------------------------------------------------------
/app/src/main/res/values/colors.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 | #FFFFFF
4 | #000000
5 | #64B5F6
6 |
--------------------------------------------------------------------------------
/gradle/wrapper/gradle-wrapper.properties:
--------------------------------------------------------------------------------
1 | distributionBase=GRADLE_USER_HOME
2 | distributionPath=wrapper/dists
3 | zipStoreBase=GRADLE_USER_HOME
4 | zipStorePath=wrapper/dists
5 | distributionUrl=https\://services.gradle.org/distributions/gradle-4.5-all.zip
6 |
--------------------------------------------------------------------------------
/app/src/main/res/values/styles.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
8 |
--------------------------------------------------------------------------------
/app/src/main/res/values/arrays.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 | - @string/menu_observable
5 | - @string/menu_flowable
6 | - @string/menu_single
7 | - @string/menu_completable
8 | - @string/menu_maybe
9 |
10 |
--------------------------------------------------------------------------------
/app/src/main/res/values-v21/styles.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
9 |
--------------------------------------------------------------------------------
/app/src/main/kotlin/com/baculsoft/sample/kotlinreactive/ext/CommonExt.kt:
--------------------------------------------------------------------------------
1 | package com.baculsoft.sample.kotlinreactive.ext
2 |
3 | import android.support.v7.widget.Toolbar
4 |
5 | internal val Toolbar.statusBarHeight: Int
6 | get() {
7 | val resourceId: Int = resources.getIdentifier("status_bar_height", "dimen", "android")
8 |
9 | return when {
10 | resourceId > 0 -> resources.getDimensionPixelSize(resourceId)
11 | else -> 0
12 | }
13 | }
--------------------------------------------------------------------------------
/app/src/main/res/drawable/bg_arrow_back.xml:
--------------------------------------------------------------------------------
1 |
2 |
7 |
8 |
11 |
12 |
--------------------------------------------------------------------------------
/app/src/main/res/values/strings.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 | Kotlin Reactive
4 | Observable Example
5 | Flowable Example
6 | Single Example
7 | Completable Example
8 | Maybe Example
9 | Observable
10 | Flowable
11 | Single
12 | Completable
13 | Maybe
14 | Subscribe
15 |
--------------------------------------------------------------------------------
/app/proguard-rules.pro:
--------------------------------------------------------------------------------
1 | # Add project specific ProGuard rules here.
2 | # You can control the set of applied configuration files using the
3 | # proguardFiles setting in build.gradle.
4 | #
5 | # For more details, see
6 | # http://developer.android.com/guide/developing/tools/proguard.html
7 |
8 | # If your project uses WebView with JS, uncomment the following
9 | # and specify the fully qualified class name to the JavaScript interface
10 | # class:
11 | #-keepclassmembers class fqcn.of.javascript.interface.for.webview {
12 | # public *;
13 | #}
14 |
15 | # Uncomment this to preserve the line number information for
16 | # debugging stack traces.
17 | #-keepattributes SourceFile,LineNumberTable
18 |
19 | # If you keep the line number information, uncomment this to
20 | # hide the original source file name.
21 | #-renamesourcefileattribute SourceFile
22 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | # Built application files
2 | *.apk
3 | *.ap_
4 |
5 | # Files for the ART/Dalvik VM
6 | *.dex
7 |
8 | # Java class files
9 | *.class
10 |
11 | # Generated files
12 | bin/
13 | gen/
14 | out/
15 |
16 | # Gradle files
17 | .gradle/
18 | build/
19 |
20 | # Local configuration file (sdk path, etc)
21 | local.properties
22 |
23 | # Proguard folder generated by Eclipse
24 | proguard/
25 |
26 | # Log Files
27 | *.log
28 |
29 | # Android Studio Navigation editor temp files
30 | .navigation/
31 |
32 | # Android Studio captures folder
33 | captures/
34 |
35 | # Intellij
36 | *.iml
37 | .idea/
38 |
39 | # Keystore files
40 | *.jks
41 |
42 | # External native build folder generated in Android Studio 2.2 and later
43 | .externalNativeBuild
44 |
45 | # Google Services (e.g. APIs or Firebase)
46 | google-services.json
47 |
48 | # Freeline
49 | freeline.py
50 | freeline/
51 | freeline_project_description.json
52 |
--------------------------------------------------------------------------------
/app/src/main/AndroidManifest.xml:
--------------------------------------------------------------------------------
1 |
2 |
5 |
6 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
--------------------------------------------------------------------------------
/app/build.gradle:
--------------------------------------------------------------------------------
1 | apply plugin: 'com.android.application'
2 | apply plugin: 'kotlin-android'
3 | apply plugin: 'kotlin-android-extensions'
4 |
5 | android {
6 | compileSdkVersion 27
7 | buildToolsVersion "27.0.3"
8 | defaultConfig {
9 | applicationId "com.baculsoft.sample.kotlinreactive"
10 | minSdkVersion 19
11 | targetSdkVersion 27
12 | versionCode 1
13 | versionName "1.0.0"
14 | }
15 | buildTypes {
16 | debug {
17 | minifyEnabled false
18 | proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
19 | }
20 | }
21 | sourceSets {
22 | main.java.srcDirs += 'src/main/kotlin'
23 | }
24 | }
25 |
26 | dependencies {
27 | implementation 'com.android.support:support-v4:27.0.2'
28 | implementation 'com.android.support:appcompat-v7:27.0.2'
29 | implementation 'com.android.support:design:27.0.2'
30 | implementation 'org.jetbrains.kotlin:kotlin-stdlib:1.2.21'
31 | implementation 'org.jetbrains.anko:anko-sdk25:0.10.4'
32 | implementation 'org.jetbrains.anko:anko-support-v4:0.10.4'
33 | implementation 'org.jetbrains.anko:anko-appcompat-v7:0.10.4'
34 | implementation 'org.jetbrains.anko:anko-recyclerview-v7:0.10.4'
35 | implementation 'org.jetbrains.anko:anko-design:0.10.4'
36 | implementation 'io.reactivex.rxjava2:rxandroid:2.0.1'
37 | implementation 'io.reactivex.rxjava2:rxjava:2.1.9'
38 | }
39 |
--------------------------------------------------------------------------------
/app/src/main/res/values/ids.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 |
30 |
31 |
32 |
33 |
--------------------------------------------------------------------------------
/app/src/main/kotlin/com/baculsoft/sample/kotlinreactive/main/MainActivity.kt:
--------------------------------------------------------------------------------
1 | package com.baculsoft.sample.kotlinreactive.main
2 |
3 | import android.os.Bundle
4 | import android.support.v7.app.AppCompatActivity
5 | import android.support.v7.widget.LinearLayoutManager
6 | import android.support.v7.widget.RecyclerView
7 | import android.support.v7.widget.Toolbar
8 | import com.baculsoft.sample.kotlinreactive.R
9 | import com.baculsoft.sample.kotlinreactive.ext.statusBarHeight
10 | import org.jetbrains.anko.find
11 | import org.jetbrains.anko.setContentView
12 |
13 | class MainActivity : AppCompatActivity() {
14 |
15 | override fun onCreate(savedInstanceState: Bundle?) {
16 | super.onCreate(savedInstanceState)
17 | MainUI().setContentView(this)
18 | setToolbar()
19 | setAdapter()
20 | }
21 |
22 | private fun setToolbar() {
23 | val toolbar = find(R.id.toolbar_main)
24 | toolbar.title = title
25 | toolbar.setPadding(0, toolbar.statusBarHeight, 0, 0)
26 |
27 | setSupportActionBar(toolbar)
28 | }
29 |
30 | private fun setAdapter() {
31 | val recyclerView = find(R.id.rv_main)
32 | val layoutManager = LinearLayoutManager(this)
33 | val menu = resources.getStringArray(R.array.types).toList()
34 | val adapter = MainAdapter(menu)
35 |
36 | recyclerView.layoutManager = layoutManager
37 | recyclerView.smoothScrollToPosition(recyclerView.bottom)
38 | recyclerView.adapter = adapter
39 | }
40 | }
--------------------------------------------------------------------------------
/app/src/main/kotlin/com/baculsoft/sample/kotlinreactive/main/MainItemUI.kt:
--------------------------------------------------------------------------------
1 | package com.baculsoft.sample.kotlinreactive.main
2 |
3 | import android.support.v4.content.ContextCompat
4 | import android.util.TypedValue
5 | import android.view.View
6 | import android.view.ViewGroup
7 | import com.baculsoft.sample.kotlinreactive.R
8 | import org.jetbrains.anko.AnkoComponent
9 | import org.jetbrains.anko.AnkoContext
10 | import org.jetbrains.anko.backgroundResource
11 | import org.jetbrains.anko.dip
12 | import org.jetbrains.anko.margin
13 | import org.jetbrains.anko.matchParent
14 | import org.jetbrains.anko.padding
15 | import org.jetbrains.anko.relativeLayout
16 | import org.jetbrains.anko.textColor
17 | import org.jetbrains.anko.textView
18 | import org.jetbrains.anko.wrapContent
19 |
20 | class MainItemUI : AnkoComponent {
21 |
22 | override fun createView(ui: AnkoContext): View = with(ui) {
23 | val typedValue = TypedValue()
24 |
25 | relativeLayout {
26 | ctx.theme.resolveAttribute(android.R.attr.selectableItemBackground, typedValue, true)
27 | backgroundResource = typedValue.resourceId
28 | isClickable = true
29 | padding = dip(8)
30 | lparams(width = matchParent, height = wrapContent)
31 |
32 | textView {
33 | id = R.id.tv_main_menu
34 | textColor = ContextCompat.getColor(ctx, R.color.colorPrimaryDark)
35 | textSize = 16f
36 | }.lparams {
37 | width = matchParent
38 | height = wrapContent
39 | margin = dip(8)
40 | }
41 | }
42 | }
43 | }
--------------------------------------------------------------------------------
/app/src/main/kotlin/com/baculsoft/sample/kotlinreactive/main/MainUI.kt:
--------------------------------------------------------------------------------
1 | package com.baculsoft.sample.kotlinreactive.main
2 |
3 | import android.annotation.SuppressLint
4 | import android.support.v4.content.ContextCompat
5 | import com.baculsoft.sample.kotlinreactive.R
6 | import org.jetbrains.anko.AnkoComponent
7 | import org.jetbrains.anko.AnkoContext
8 | import org.jetbrains.anko.alignParentTop
9 | import org.jetbrains.anko.appcompat.v7.toolbar
10 | import org.jetbrains.anko.backgroundColor
11 | import org.jetbrains.anko.below
12 | import org.jetbrains.anko.design.appBarLayout
13 | import org.jetbrains.anko.design.coordinatorLayout
14 | import org.jetbrains.anko.dip
15 | import org.jetbrains.anko.matchParent
16 | import org.jetbrains.anko.recyclerview.v7.recyclerView
17 | import org.jetbrains.anko.relativeLayout
18 | import org.jetbrains.anko.wrapContent
19 |
20 | class MainUI : AnkoComponent {
21 |
22 | @SuppressLint("NewApi")
23 | override fun createView(ui: AnkoContext) = with(ui) {
24 | coordinatorLayout {
25 | id = R.id.content_main
26 | backgroundColor = ContextCompat.getColor(ctx, R.color.colorPrimary)
27 |
28 | relativeLayout {
29 | appBarLayout {
30 | id = R.id.abl_main
31 | backgroundColor = ContextCompat.getColor(ctx, R.color.colorAccent)
32 | elevation = dip(4).toFloat()
33 |
34 | toolbar {
35 | id = R.id.toolbar_main
36 | setTitleTextColor(ContextCompat.getColor(ctx, R.color.colorPrimary))
37 | }.lparams {
38 | width = matchParent
39 | height = wrapContent
40 | }
41 | }.lparams {
42 | alignParentTop()
43 | width = matchParent
44 | height = wrapContent
45 | }
46 |
47 | recyclerView {
48 | id = R.id.rv_main
49 | }.lparams { below(R.id.abl_main) }
50 | }
51 | }
52 | }
53 | }
--------------------------------------------------------------------------------
/app/src/main/kotlin/com/baculsoft/sample/kotlinreactive/observable/ObservableActivity.kt:
--------------------------------------------------------------------------------
1 | package com.baculsoft.sample.kotlinreactive.observable
2 |
3 | import android.os.Bundle
4 | import android.support.v4.content.ContextCompat
5 | import android.support.v7.app.AppCompatActivity
6 | import android.support.v7.widget.Toolbar
7 | import android.view.MenuItem
8 | import android.widget.Button
9 | import android.widget.TextView
10 | import com.baculsoft.sample.kotlinreactive.R
11 | import com.baculsoft.sample.kotlinreactive.ext.statusBarHeight
12 | import io.reactivex.Observable
13 | import io.reactivex.android.schedulers.AndroidSchedulers
14 | import io.reactivex.schedulers.Schedulers
15 | import org.jetbrains.anko.find
16 | import org.jetbrains.anko.setContentView
17 |
18 | class ObservableActivity : AppCompatActivity() {
19 |
20 | override fun onCreate(savedInstanceState: Bundle?) {
21 | super.onCreate(savedInstanceState)
22 | ObservableUI().setContentView(this)
23 | setToolbar()
24 | addListener()
25 | }
26 |
27 | override fun onOptionsItemSelected(item: MenuItem?): Boolean {
28 | when (item?.itemId) {
29 | android.R.id.home -> {
30 | onBackPressed()
31 | }
32 | }
33 |
34 | return super.onOptionsItemSelected(item)
35 | }
36 |
37 | private fun setToolbar() {
38 | val toolbar = find(R.id.toolbar_observable)
39 | toolbar.title = resources.getString(R.string.menu_observable)
40 | toolbar.navigationIcon = ContextCompat.getDrawable(this, R.drawable.bg_arrow_back)
41 | toolbar.setPadding(0, toolbar.statusBarHeight, 0, 0)
42 |
43 | setSupportActionBar(toolbar)
44 | }
45 |
46 | private fun addListener() {
47 | val button = find