Skip to content

Commit

Permalink
Initial commit
Browse files Browse the repository at this point in the history
  • Loading branch information
moaz authored and moaz committed Jan 23, 2023
0 parents commit 481cc1e
Show file tree
Hide file tree
Showing 57 changed files with 1,369 additions and 0 deletions.
15 changes: 15 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
*.iml
.gradle
/local.properties
/.idea/caches
/.idea/libraries
/.idea/modules.xml
/.idea/workspace.xml
/.idea/navEditor.xml
/.idea/assetWizardSettings.xml
.DS_Store
/build
/captures
.externalNativeBuild
.cxx
local.properties
3 changes: 3 additions & 0 deletions .idea/.gitignore

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

6 changes: 6 additions & 0 deletions .idea/compiler.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

18 changes: 18 additions & 0 deletions .idea/gradle.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

17 changes: 17 additions & 0 deletions .idea/misc.xml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions app/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
/build
63 changes: 63 additions & 0 deletions app/build.gradle
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
plugins {
id 'com.android.application'
id 'org.jetbrains.kotlin.android'
id 'kotlin-kapt'
id 'com.google.gms.google-services'
id 'kotlin-parcelize'
}

android {
compileSdk 33

defaultConfig {
applicationId "com.example.workingtimerv2"
minSdk 23
targetSdk 33
versionCode 1
versionName "1.0"

testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
}

buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
}
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
kotlinOptions {
jvmTarget = '1.8'
}
buildFeatures {
viewBinding true
dataBinding true
}
buildToolsVersion '30.0.3'
}

dependencies {

implementation 'androidx.core:core-ktx:1.7.0'
implementation 'androidx.appcompat:appcompat:1.6.0'
implementation 'com.google.android.material:material:1.7.0'
implementation 'androidx.constraintlayout:constraintlayout:2.1.4'
testImplementation 'junit:junit:4.13.2'
androidTestImplementation 'androidx.test.ext:junit:1.1.5'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.5.1'

implementation platform('com.google.firebase:firebase-bom:31.1.0')
implementation 'com.google.firebase:firebase-analytics'
implementation 'com.google.firebase:firebase-auth-ktx'
implementation 'com.google.firebase:firebase-firestore-ktx'

var lifecycle_version = "2.5.1"

// ViewModel
implementation("androidx.lifecycle:lifecycle-viewmodel-ktx:$lifecycle_version")
// LiveData
implementation("androidx.lifecycle:lifecycle-livedata-ktx:$lifecycle_version")
}
39 changes: 39 additions & 0 deletions app/google-services.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
{
"project_info": {
"project_number": "740626445173",
"project_id": "workingtimer2-ac1fb",
"storage_bucket": "workingtimer2-ac1fb.appspot.com"
},
"client": [
{
"client_info": {
"mobilesdk_app_id": "1:740626445173:android:0afeb41588fd258835993c",
"android_client_info": {
"package_name": "com.example.workingtimerv2"
}
},
"oauth_client": [
{
"client_id": "740626445173-476d9bp8lu0ejg6r8r0pu5rsj4h8q5qv.apps.googleusercontent.com",
"client_type": 3
}
],
"api_key": [
{
"current_key": "AIzaSyBBwXLw301tVINW4c9qOcG08FvgcLxxSK0"
}
],
"services": {
"appinvite_service": {
"other_platform_oauth_client": [
{
"client_id": "740626445173-476d9bp8lu0ejg6r8r0pu5rsj4h8q5qv.apps.googleusercontent.com",
"client_type": 3
}
]
}
}
}
],
"configuration_version": "1"
}
21 changes: 21 additions & 0 deletions app/proguard-rules.pro
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
# Add project specific ProGuard rules here.
# You can control the set of applied configuration files using the
# proguardFiles setting in build.gradle.
#
# For more details, see
# http://developer.android.com/guide/developing/tools/proguard.html

# If your project uses WebView with JS, uncomment the following
# and specify the fully qualified class name to the JavaScript interface
# class:
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
# public *;
#}

# Uncomment this to preserve the line number information for
# debugging stack traces.
#-keepattributes SourceFile,LineNumberTable

# If you keep the line number information, uncomment this to
# hide the original source file name.
#-renamesourcefileattribute SourceFile
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
package com.example.workingtimerv2

import androidx.test.platform.app.InstrumentationRegistry
import androidx.test.ext.junit.runners.AndroidJUnit4

import org.junit.Test
import org.junit.runner.RunWith

import org.junit.Assert.*

/**
* Instrumented test, which will execute on an Android device.
*
* See [testing documentation](http://d.android.com/tools/testing).
*/
@RunWith(AndroidJUnit4::class)
class ExampleInstrumentedTest {
@Test
fun useAppContext() {
// Context of the app under test.
val appContext = InstrumentationRegistry.getInstrumentation().targetContext
assertEquals("com.example.workingtimerv2", appContext.packageName)
}
}
39 changes: 39 additions & 0 deletions app/src/google-services.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
{
"project_info": {
"project_number": "740626445173",
"project_id": "workingtimer2-ac1fb",
"storage_bucket": "workingtimer2-ac1fb.appspot.com"
},
"client": [
{
"client_info": {
"mobilesdk_app_id": "1:740626445173:android:0afeb41588fd258835993c",
"android_client_info": {
"package_name": "com.example.workingtimerv2"
}
},
"oauth_client": [
{
"client_id": "740626445173-476d9bp8lu0ejg6r8r0pu5rsj4h8q5qv.apps.googleusercontent.com",
"client_type": 3
}
],
"api_key": [
{
"current_key": "AIzaSyBBwXLw301tVINW4c9qOcG08FvgcLxxSK0"
}
],
"services": {
"appinvite_service": {
"other_platform_oauth_client": [
{
"client_id": "740626445173-476d9bp8lu0ejg6r8r0pu5rsj4h8q5qv.apps.googleusercontent.com",
"client_type": 3
}
]
}
}
}
],
"configuration_version": "1"
}
35 changes: 35 additions & 0 deletions app/src/main/AndroidManifest.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
package="com.example.workingtimerv2">

<application
android:allowBackup="true"
android:dataExtractionRules="@xml/data_extraction_rules"
android:fullBackupContent="@xml/backup_rules"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/Theme.WorkingTimerV2"
tools:targetApi="31">
<activity
android:name=".ui.home.HomeActivity"
android:exported="false" />
<activity
android:name=".ui.register.RegisterActivity"
android:exported="true" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />

<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity
android:name=".ui.splash.SplashActivity"
android:exported="true">

</activity>
</application>

</manifest>
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
package com.example.workingtimerv2

import androidx.databinding.BindingAdapter
import com.google.android.material.textfield.TextInputLayout

@BindingAdapter("app:error")
fun setError (textInputLayout: TextInputLayout, error: String?) {
textInputLayout.error = error
}
10 changes: 10 additions & 0 deletions app/src/main/java/com/example/workingtimerv2/DataUtils.kt
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
package com.example.workingtimerv2

import com.example.workingtimerv2.model.AppUser
import com.google.firebase.firestore.auth.User

object DataUtils {

var user: AppUser? = null
var firebaseUser: User? = null
}
69 changes: 69 additions & 0 deletions app/src/main/java/com/example/workingtimerv2/base/BaseActivity.kt
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
package com.example.workingtimerv2.base

import android.app.ProgressDialog
import android.content.DialogInterface
import android.os.Bundle
import androidx.appcompat.app.AlertDialog
import androidx.appcompat.app.AppCompatActivity
import androidx.databinding.DataBindingUtil
import androidx.databinding.ViewDataBinding

open abstract class BaseActivity<DB: ViewDataBinding , VM: BaseViewModel<*>>: AppCompatActivity() {

lateinit var viewModel:VM
lateinit var viewDataBinding: DB

override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
viewDataBinding = DataBindingUtil.setContentView(this,getLayoutId())
viewModel = initViewModel()
subscribeToLiveData()
}

fun subscribeToLiveData(){
viewModel.messageLiveData.observe(this) {
showDialog(it)
}

viewModel.showLoading.observe(this) {
if (it) showLoading()
else hideLoading()
}
}

var alertDialog : AlertDialog?= null
fun showDialog(message: String,
posActionName:String? = null, posAction: DialogInterface.OnClickListener?=null,
negActionName:String? = null, negAction: DialogInterface.OnClickListener?=null,
cancelable : Boolean = true){

val defAction = DialogInterface.OnClickListener { dialog, which -> dialog!!.dismiss() }
val builder = AlertDialog.Builder(this).setMessage(message)
if (posActionName!=null) builder.setPositiveButton(posActionName, posAction ?: defAction)
if (negActionName!=null) builder.setPositiveButton(negActionName, negAction ?: defAction)
builder.setCancelable(cancelable)

alertDialog = builder.show()
}

fun hideDialog(){
alertDialog?.dismiss()
alertDialog = null
}


var progressDialog: ProgressDialog? = null
fun showLoading(){
progressDialog = ProgressDialog(this)
progressDialog?.setMessage("Loading....")
progressDialog?.setCancelable(false)
progressDialog?.show()
}
fun hideLoading(){
progressDialog?.dismiss()
progressDialog = null
}

abstract fun getLayoutId():Int
abstract fun initViewModel():VM
}
Loading

0 comments on commit 481cc1e

Please sign in to comment.