├── 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