commit 56d7b7a3bad9f458de6308be7eb2dc0d3a0217d5 Author: AdityaGaikwad Date: Thu May 2 14:49:19 2024 +0530 Initial commit diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..aa724b7 --- /dev/null +++ b/.gitignore @@ -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 diff --git a/.idea/.gitignore b/.idea/.gitignore new file mode 100644 index 0000000..26d3352 --- /dev/null +++ b/.idea/.gitignore @@ -0,0 +1,3 @@ +# Default ignored files +/shelf/ +/workspace.xml diff --git a/.idea/compiler.xml b/.idea/compiler.xml new file mode 100644 index 0000000..b589d56 --- /dev/null +++ b/.idea/compiler.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/.idea/deploymentTargetDropDown.xml b/.idea/deploymentTargetDropDown.xml new file mode 100644 index 0000000..0c0c338 --- /dev/null +++ b/.idea/deploymentTargetDropDown.xml @@ -0,0 +1,10 @@ + + + + + + + + + + \ No newline at end of file diff --git a/.idea/gradle.xml b/.idea/gradle.xml new file mode 100644 index 0000000..0897082 --- /dev/null +++ b/.idea/gradle.xml @@ -0,0 +1,19 @@ + + + + + + + \ No newline at end of file diff --git a/.idea/kotlinc.xml b/.idea/kotlinc.xml new file mode 100644 index 0000000..fdf8d99 --- /dev/null +++ b/.idea/kotlinc.xml @@ -0,0 +1,6 @@ + + + + + \ No newline at end of file diff --git a/.idea/migrations.xml b/.idea/migrations.xml new file mode 100644 index 0000000..f8051a6 --- /dev/null +++ b/.idea/migrations.xml @@ -0,0 +1,10 @@ + + + + + + \ No newline at end of file diff --git a/.idea/misc.xml b/.idea/misc.xml new file mode 100644 index 0000000..8978d23 --- /dev/null +++ b/.idea/misc.xml @@ -0,0 +1,9 @@ + + + + + + + + \ No newline at end of file diff --git a/app/.gitignore b/app/.gitignore new file mode 100644 index 0000000..42afabf --- /dev/null +++ b/app/.gitignore @@ -0,0 +1 @@ +/build \ No newline at end of file diff --git a/app/build.gradle b/app/build.gradle new file mode 100644 index 0000000..39eb805 --- /dev/null +++ b/app/build.gradle @@ -0,0 +1,55 @@ +plugins { + alias(libs.plugins.androidApplication) + alias(libs.plugins.jetbrainsKotlinAndroid) +} + +android { + namespace 'com.woka' + compileSdk 34 + + defaultConfig { + applicationId "com.woka" + minSdk 24 + targetSdk 34 + 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 + } +} + +dependencies { + implementation "com.airbnb.android:lottie:6.4.0" + implementation "androidx.core:core-splashscreen:1.0.1" + + implementation 'com.google.android.flexbox:flexbox:3.0.0' + + implementation libs.androidx.core.ktx + implementation libs.androidx.appcompat + implementation libs.material + implementation libs.androidx.activity + implementation libs.androidx.constraintlayout + implementation libs.androidx.navigation.fragment.ktx + implementation libs.androidx.navigation.ui.ktx + testImplementation libs.junit + androidTestImplementation libs.androidx.junit + androidTestImplementation libs.androidx.espresso.core +} \ No newline at end of file diff --git a/app/proguard-rules.pro b/app/proguard-rules.pro new file mode 100644 index 0000000..481bb43 --- /dev/null +++ b/app/proguard-rules.pro @@ -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 \ No newline at end of file diff --git a/app/src/androidTest/java/com/woka/ExampleInstrumentedTest.kt b/app/src/androidTest/java/com/woka/ExampleInstrumentedTest.kt new file mode 100644 index 0000000..098c28d --- /dev/null +++ b/app/src/androidTest/java/com/woka/ExampleInstrumentedTest.kt @@ -0,0 +1,24 @@ +package com.woka + +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.woka", appContext.packageName) + } +} \ No newline at end of file diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml new file mode 100644 index 0000000..a9bb014 --- /dev/null +++ b/app/src/main/AndroidManifest.xml @@ -0,0 +1,40 @@ + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/ic_launcher-playstore.png b/app/src/main/ic_launcher-playstore.png new file mode 100644 index 0000000..f409304 Binary files /dev/null and b/app/src/main/ic_launcher-playstore.png differ diff --git a/app/src/main/java/com/woka/WokaApp.kt b/app/src/main/java/com/woka/WokaApp.kt new file mode 100644 index 0000000..0c4c666 --- /dev/null +++ b/app/src/main/java/com/woka/WokaApp.kt @@ -0,0 +1,16 @@ +package com.woka + +import android.app.Application +import com.woka.userPreference.UserPreference + +class WokaApp: Application() { + + companion object{ + var userPrefs: UserPreference? = null + } + + override fun onCreate() { + super.onCreate() + userPrefs = UserPreference(applicationContext) + } +} \ No newline at end of file diff --git a/app/src/main/java/com/woka/onboard/InterestTopicView.kt b/app/src/main/java/com/woka/onboard/InterestTopicView.kt new file mode 100644 index 0000000..fb4b2cd --- /dev/null +++ b/app/src/main/java/com/woka/onboard/InterestTopicView.kt @@ -0,0 +1,33 @@ +package com.woka.onboard + +import android.content.Context +import android.widget.LinearLayout +import android.widget.TextView +import androidx.cardview.widget.CardView +import com.woka.R + +class InterestTopicView(context: Context, topicName: String): LinearLayout(context) { + + var isTopicSelected = false + private set + + init { + inflate(context, R.layout.layout_interest_topic, this) + findViewById(R.id.interest_topic_txt).text = topicName + + findViewById(R.id.interest_card).setOnClickListener { + val card = it as CardView + if (!isTopicSelected){ + card.setCardBackgroundColor(context.resources.getColor(R.color.white)) + card.elevation = 5f + }else{ + card.setCardBackgroundColor(context.resources.getColor(R.color.white_60)) + card.elevation = 0f + } + + isTopicSelected = !isTopicSelected + } + } + + constructor(context: Context): this(context, "None") +} \ No newline at end of file diff --git a/app/src/main/java/com/woka/onboard/OnboardActivity.kt b/app/src/main/java/com/woka/onboard/OnboardActivity.kt new file mode 100644 index 0000000..aee0a55 --- /dev/null +++ b/app/src/main/java/com/woka/onboard/OnboardActivity.kt @@ -0,0 +1,46 @@ +package com.woka.onboard + +import android.media.MediaPlayer +import android.os.Bundle +import androidx.activity.enableEdgeToEdge +import androidx.core.view.ViewCompat +import androidx.core.view.WindowCompat +import androidx.core.view.WindowInsetsCompat +import com.woka.R +import com.woka.utils.WokaBaseActivity + +class OnboardActivity : WokaBaseActivity() { + + private var player: MediaPlayer? = null + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + enableEdgeToEdge() + setContentView(R.layout.activity_onboard) + ViewCompat.setOnApplyWindowInsetsListener(findViewById(R.id.main)) { v, insets -> + val systemBars = insets.getInsets(WindowInsetsCompat.Type.systemBars()) + v.setPadding(systemBars.left, systemBars.top, systemBars.right, systemBars.bottom) + insets + } + + player = MediaPlayer.create(this, R.raw.audiotwo) + player?.isLooping = true + } + + override fun onStart() { + super.onStart() + player?.start() + } + + override fun onStop() { + super.onStop() + player?.pause() + } + + override fun onDestroy() { + super.onDestroy() + player?.stop() + player?.release() + player = null + } +} \ No newline at end of file diff --git a/app/src/main/java/com/woka/onboard/OnboardingAdapter.kt b/app/src/main/java/com/woka/onboard/OnboardingAdapter.kt new file mode 100644 index 0000000..7a9ab5e --- /dev/null +++ b/app/src/main/java/com/woka/onboard/OnboardingAdapter.kt @@ -0,0 +1,43 @@ +package com.woka.onboard + +import android.view.LayoutInflater +import android.view.ViewGroup +import androidx.recyclerview.widget.RecyclerView +import com.woka.R +import com.woka.databinding.OnboardSlideBinding + +class OnboardingAdapter : RecyclerView.Adapter() { + + class ViewHolder(val binding: OnboardSlideBinding) : RecyclerView.ViewHolder(binding.root) + + override fun onCreateViewHolder(parent: ViewGroup, viewType: Int) = ViewHolder( + OnboardSlideBinding.inflate(LayoutInflater.from(parent.context), parent, false) + ) + + override fun onBindViewHolder(holder: ViewHolder, position: Int) { + with(holder) { + val context = binding.root.context + binding.apply { + when (position){ + 0 -> { + title.text = context.getString(R.string.slide_1_title) + subtitle.text = context.getString(R.string.slide_1_subtitle) + image.setImageResource(R.drawable.slide1) + } + 1 -> { + title.text = context.getString(R.string.slide_2_title) +// subtitle.text = context.getString(R.string.slide_2_subtitle) + image.setImageResource(R.drawable.slide2) + } + 2 ->{ + title.text = context.getString(R.string.slide_3_title) +// subtitle.text = context.getString(R.string.slide_3_subtitle) + image.setImageResource(R.drawable.slide3) + } + } + } + } + } + + override fun getItemCount() = 3 +} \ No newline at end of file diff --git a/app/src/main/java/com/woka/onboard/WelcomeActivity.kt b/app/src/main/java/com/woka/onboard/WelcomeActivity.kt new file mode 100644 index 0000000..0180ee4 --- /dev/null +++ b/app/src/main/java/com/woka/onboard/WelcomeActivity.kt @@ -0,0 +1,24 @@ +package com.woka.onboard + +import android.os.Bundle +import androidx.activity.enableEdgeToEdge +import androidx.core.splashscreen.SplashScreen.Companion.installSplashScreen +import androidx.core.view.ViewCompat +import androidx.core.view.WindowInsetsCompat +import com.woka.R +import com.woka.utils.WokaBaseActivity + +class WelcomeActivity : WokaBaseActivity() { + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + installSplashScreen() + enableEdgeToEdge() + setContentView(R.layout.activity_welcome) + ViewCompat.setOnApplyWindowInsetsListener(findViewById(R.id.main)) { v, insets -> + val systemBars = insets.getInsets(WindowInsetsCompat.Type.systemBars()) + v.setPadding(systemBars.left, systemBars.top, systemBars.right, systemBars.bottom) + insets + } + } +} \ No newline at end of file diff --git a/app/src/main/java/com/woka/onboard/fragments/AgeSelectionFragment.kt b/app/src/main/java/com/woka/onboard/fragments/AgeSelectionFragment.kt new file mode 100644 index 0000000..d49510a --- /dev/null +++ b/app/src/main/java/com/woka/onboard/fragments/AgeSelectionFragment.kt @@ -0,0 +1,49 @@ +package com.woka.onboard.fragments + +import android.graphics.Color +import android.os.Bundle +import android.view.LayoutInflater +import android.view.View +import android.view.ViewGroup +import android.view.WindowManager +import androidx.fragment.app.Fragment +import androidx.navigation.fragment.findNavController +import com.woka.R +import com.woka.databinding.FragmentAgeSelectBinding +import com.woka.onboard.fragments.GetEmailFragment.Companion.IS_UNDER_16 + +class AgeSelectionFragment : Fragment() { + + private lateinit var binding: FragmentAgeSelectBinding + + override fun onCreateView( + inflater: LayoutInflater, container: ViewGroup?, + savedInstanceState: Bundle? + ): View? { + binding = FragmentAgeSelectBinding.inflate(inflater, container, false) + activity?.window?.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS) + activity?.window?.statusBarColor = Color.parseColor("#6ed5fe") + + clickEvents() + + return binding.root + } + + private fun clickEvents() { + binding.under26.setOnClickListener { + val args = Bundle() + args.putBoolean(IS_UNDER_16, true) + findNavController().navigate(R.id.action_age_select_fragment_to_getEmailFragment, args) + } + + binding.above16.setOnClickListener { + val args = Bundle() + args.putBoolean(IS_UNDER_16, false) + findNavController().navigate(R.id.action_age_select_fragment_to_getEmailFragment, args) + } + + binding.backBtn.setOnClickListener{ + activity?.onBackPressedDispatcher?.onBackPressed() + } + } +} \ No newline at end of file diff --git a/app/src/main/java/com/woka/onboard/fragments/GetCodeFragment.kt b/app/src/main/java/com/woka/onboard/fragments/GetCodeFragment.kt new file mode 100644 index 0000000..369c9f9 --- /dev/null +++ b/app/src/main/java/com/woka/onboard/fragments/GetCodeFragment.kt @@ -0,0 +1,96 @@ +package com.woka.onboard.fragments + +import android.os.Bundle +import androidx.fragment.app.Fragment +import android.view.LayoutInflater +import android.view.View +import android.view.ViewGroup +import androidx.core.widget.addTextChangedListener +import androidx.navigation.fragment.findNavController +import com.woka.R +import com.woka.databinding.FragmentGetCodeBinding +import com.woka.onboard.fragments.GetEmailFragment.Companion.IS_UNDER_16 +import com.woka.utils.closeKeyboard + +class GetCodeFragment : Fragment() { + + private lateinit var binding: FragmentGetCodeBinding + + private var isUnder16 = false + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + arguments?.let { + isUnder16 = it.getBoolean(IS_UNDER_16, false) + } + } + + override fun onCreateView( + inflater: LayoutInflater, container: ViewGroup?, + savedInstanceState: Bundle? + ): View? { + binding = FragmentGetCodeBinding.inflate(inflater, container, false) + + initViews() + + clickEvents() + + return binding.root + } + + private fun initViews() { + binding.apply { + et1.addTextChangedListener { + if (it?.isEmpty() == false){ + et2.requestFocus() + } + } + + et2.addTextChangedListener { + if (it?.isEmpty() == false){ + et3.requestFocus() + }else{ + et1.requestFocus() + } + } + + et3.addTextChangedListener { + if (it?.isEmpty() == false){ + et4.requestFocus() + }else{ + et2.requestFocus() + } + } + + et4.addTextChangedListener { + if (it?.isEmpty() == false){ + // close keyboard + activity?.closeKeyboard() + }else{ + et3.requestFocus() + } + } + + if (isUnder16){ + title.text = getString(R.string.please_get_otp_under_16) + infoText.text = getString(R.string.request_them_for_verification_) + } + + binding.next.setOnClickListener { + val args = Bundle().apply { + putBoolean(IS_UNDER_16, isUnder16) + } + + findNavController().navigate(R.id.action_getCodeFragment_to_signUpFragment, args) + } + } + } + + private fun clickEvents() { + binding.apply { + backBtn.setOnClickListener { + activity?.onBackPressedDispatcher?.onBackPressed() + } + } + } +} \ No newline at end of file diff --git a/app/src/main/java/com/woka/onboard/fragments/GetEmailFragment.kt b/app/src/main/java/com/woka/onboard/fragments/GetEmailFragment.kt new file mode 100644 index 0000000..01994cd --- /dev/null +++ b/app/src/main/java/com/woka/onboard/fragments/GetEmailFragment.kt @@ -0,0 +1,76 @@ +package com.woka.onboard.fragments + +import android.os.Bundle +import android.util.Patterns +import androidx.fragment.app.Fragment +import android.view.LayoutInflater +import android.view.View +import android.view.View.VISIBLE +import android.view.ViewGroup +import android.widget.Toast +import androidx.navigation.fragment.findNavController +import com.woka.R +import com.woka.databinding.FragmentGetEmailBinding + +class GetEmailFragment : Fragment() { + + companion object{ + const val IS_UNDER_16 = "is_under_16" + } + + private lateinit var binding: FragmentGetEmailBinding + + private var isUnder16: Boolean = false + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + arguments?.let { + isUnder16 = it.getBoolean(IS_UNDER_16, false) + } + } + + override fun onCreateView( + inflater: LayoutInflater, container: ViewGroup?, + savedInstanceState: Bundle? + ): View? { + binding = FragmentGetEmailBinding.inflate(inflater, container, false) + + initViews() + + clickEvents() + + return binding.root + } + + private fun initViews() { + binding.apply { + if (isUnder16){ + title.text = getString(R.string.let_s_be_safe) + can.text = getString(R.string.can_we_have_your_parent_s_email) + email.hint = getString(R.string.enter_your_parent_s_email) + verificationTxt.visibility = VISIBLE + } + } + } + + private fun clickEvents() { + + binding.next.setOnClickListener { + binding.email.error = null + if (!Patterns.EMAIL_ADDRESS.matcher(binding.email.text.toString()).matches()){ + binding.email.error = "Invalid email" + return@setOnClickListener + } + + val args = Bundle().apply { + putBoolean(IS_UNDER_16, isUnder16) + } + + findNavController().navigate(R.id.action_getEmailFragment_to_getCodeFragment, args) + } + + binding.backBtn.setOnClickListener { + activity?.onBackPressedDispatcher?.onBackPressed() + } + } +} \ No newline at end of file diff --git a/app/src/main/java/com/woka/onboard/fragments/GetMoreInfoFragment.kt b/app/src/main/java/com/woka/onboard/fragments/GetMoreInfoFragment.kt new file mode 100644 index 0000000..fe0f6dc --- /dev/null +++ b/app/src/main/java/com/woka/onboard/fragments/GetMoreInfoFragment.kt @@ -0,0 +1,112 @@ +package com.woka.onboard.fragments + +import android.graphics.Color +import android.os.Bundle +import android.view.LayoutInflater +import android.view.View +import android.view.View.VISIBLE +import android.view.ViewGroup +import android.widget.TextView +import android.widget.Toast +import androidx.core.view.allViews +import androidx.fragment.app.Fragment +import com.woka.R +import com.woka.databinding.FragmentGetMoreInfoBinding +import com.woka.onboard.InterestTopicView +import com.woka.onboard.fragments.GetEmailFragment.Companion.IS_UNDER_16 +import com.woka.onboard.models.Interest +import com.woka.utils.Gender + +class GetMoreInfoFragment : Fragment() { + + companion object{ + const val USER_NAME_ARG = "arg_user_name" + } + + private lateinit var binding: FragmentGetMoreInfoBinding + + private var isUnder16 = false + private var userName: String? = null + private var selectedGender: Gender = Gender.NONE + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + arguments?.let { + isUnder16 = it.getBoolean(IS_UNDER_16) + userName = it.getString(USER_NAME_ARG) + } + } + + override fun onCreateView( + inflater: LayoutInflater, container: ViewGroup?, + savedInstanceState: Bundle? + ): View? { + binding = FragmentGetMoreInfoBinding.inflate(inflater, container, false) + initViews() + clickEvents() + return binding.root + } + + private fun clickEvents() { + binding.apply { + genderM.setOnClickListener{selectGender(Gender.MALE)} + genderF.setOnClickListener{selectGender(Gender.FEMALE)} + + backBtn.setOnClickListener { activity?.onBackPressedDispatcher?.onBackPressed() } + } + } + + private fun initViews() { + selectGender(selectedGender) + + binding.apply { + if (isUnder16){ + interestView.visibility = VISIBLE + + // static + interestsFlex.apply { + addView(InterestTopicView(context, "English")) + addView(InterestTopicView(context, "Maths")) + addView(InterestTopicView(context, "Science")) + addView(InterestTopicView(context, "Entertainment")) + addView(InterestTopicView(context, "Education")) + } + + } + + name.text = userName + } + + } + + private fun selectGender(gender: Gender){ + if (selectedGender == gender) return + + binding.apply { + when(gender){ + Gender.MALE -> { + genderM.setCardBackgroundColor(Color.WHITE) + genderM.cardElevation = 5f + + genderF.setCardBackgroundColor(resources.getColor(R.color.white_50)) + genderF.cardElevation = 0f + } + Gender.FEMALE -> { + genderF.setCardBackgroundColor(Color.WHITE) + genderF.cardElevation = 5f + + genderM.setCardBackgroundColor(resources.getColor(R.color.white_50)) + genderM.cardElevation = 0f + } + Gender.NONE -> { + genderM.setCardBackgroundColor(resources.getColor(R.color.white_50)) + genderM.cardElevation = 0f + + genderF.setCardBackgroundColor(resources.getColor(R.color.white_50)) + genderF.cardElevation = 0f + } + } + + } + } +} \ No newline at end of file diff --git a/app/src/main/java/com/woka/onboard/fragments/LanguageFragment.kt b/app/src/main/java/com/woka/onboard/fragments/LanguageFragment.kt new file mode 100644 index 0000000..a388fc5 --- /dev/null +++ b/app/src/main/java/com/woka/onboard/fragments/LanguageFragment.kt @@ -0,0 +1,58 @@ +package com.woka.onboard.fragments + +import android.content.Intent +import android.os.Bundle +import android.transition.TransitionInflater +import android.view.LayoutInflater +import android.view.View +import android.view.ViewGroup +import androidx.core.app.ActivityOptionsCompat +import androidx.fragment.app.Fragment +import androidx.navigation.fragment.FragmentNavigatorExtras +import androidx.navigation.fragment.findNavController +import com.woka.R +import com.woka.databinding.FragmentLanguageBinding +import com.woka.onboard.OnboardActivity +import com.woka.utils.changeLocale + +class LanguageFragment : Fragment() { + + private lateinit var binding: FragmentLanguageBinding + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + sharedElementEnterTransition = TransitionInflater.from(context).inflateTransition(android.R.transition.move) + } + + override fun onCreateView( + inflater: LayoutInflater, container: ViewGroup?, + savedInstanceState: Bundle? + ): View? { + binding = FragmentLanguageBinding.inflate(inflater, container, false) + return binding.root + } + + override fun onViewCreated(view: View, savedInstanceState: Bundle?) { + super.onViewCreated(view, savedInstanceState) + + clickEvents() + } + + private fun clickEvents() { + binding.english.setOnClickListener { + requireActivity().changeLocale("en") + gotoOnboardActivity() + } + + binding.hindi.setOnClickListener { + requireActivity().changeLocale("hi") + gotoOnboardActivity() + } + } + + private fun gotoOnboardActivity() { + startActivity(Intent(requireActivity(), OnboardActivity::class.java), + ActivityOptionsCompat.makeSceneTransitionAnimation(requireActivity(), + binding.logo, "logo").toBundle()) + } +} \ No newline at end of file diff --git a/app/src/main/java/com/woka/onboard/fragments/OnboardFragment.kt b/app/src/main/java/com/woka/onboard/fragments/OnboardFragment.kt new file mode 100644 index 0000000..a7f782e --- /dev/null +++ b/app/src/main/java/com/woka/onboard/fragments/OnboardFragment.kt @@ -0,0 +1,60 @@ +package com.woka.onboard.fragments + +import android.graphics.Color +import android.os.Bundle +import android.transition.TransitionInflater +import android.view.LayoutInflater +import android.view.View +import android.view.ViewGroup +import android.view.WindowManager +import androidx.fragment.app.Fragment +import androidx.navigation.fragment.findNavController +import com.google.android.material.tabs.TabLayoutMediator +import com.woka.R +import com.woka.databinding.FragmentOnboardBinding +import com.woka.onboard.OnboardingAdapter + +class OnboardFragment : Fragment() { + + private lateinit var binding: FragmentOnboardBinding + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + sharedElementEnterTransition = TransitionInflater.from(context).inflateTransition(android.R.transition.move) + } + + override fun onCreateView( + inflater: LayoutInflater, container: ViewGroup?, + savedInstanceState: Bundle? + ): View? { + binding = FragmentOnboardBinding.inflate(inflater, container, false) + activity?.window?.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS) + activity?.window?.statusBarColor = Color.parseColor("#55cffe") + return binding.root + } + + override fun onViewCreated(view: View, savedInstanceState: Bundle?) { + super.onViewCreated(view, savedInstanceState) + + initViews() + + clickEvents() + } + + private fun initViews() { + binding.apply { + viewPager.adapter = OnboardingAdapter() + TabLayoutMediator(tabLayout, viewPager){tab, position -> }.attach() + } + } + + private fun clickEvents(){ + binding.backBtn.setOnClickListener{ + activity?.onBackPressedDispatcher?.onBackPressed() + } + + binding.createAccount.setOnClickListener { + findNavController().navigate(R.id.action_onboardFragment_to_age_select_fragment) + } + } +} \ No newline at end of file diff --git a/app/src/main/java/com/woka/onboard/fragments/SelectAvatarFragment.kt b/app/src/main/java/com/woka/onboard/fragments/SelectAvatarFragment.kt new file mode 100644 index 0000000..20d736e --- /dev/null +++ b/app/src/main/java/com/woka/onboard/fragments/SelectAvatarFragment.kt @@ -0,0 +1,23 @@ +package com.woka.onboard.fragments + +import android.os.Bundle +import androidx.fragment.app.Fragment +import android.view.LayoutInflater +import android.view.View +import android.view.ViewGroup +import com.woka.R +import com.woka.databinding.FragmentSelectAvatarBinding + +class SelectAvatarFragment : Fragment() { + + private lateinit var binding: FragmentSelectAvatarBinding + + override fun onCreateView( + inflater: LayoutInflater, container: ViewGroup?, + savedInstanceState: Bundle? + ): View? { + binding = FragmentSelectAvatarBinding.inflate(inflater, container, false) + + return binding.root + } +} \ No newline at end of file diff --git a/app/src/main/java/com/woka/onboard/fragments/SignInFragment.kt b/app/src/main/java/com/woka/onboard/fragments/SignInFragment.kt new file mode 100644 index 0000000..258c1ae --- /dev/null +++ b/app/src/main/java/com/woka/onboard/fragments/SignInFragment.kt @@ -0,0 +1,33 @@ +package com.woka.onboard.fragments + +import android.os.Bundle +import androidx.fragment.app.Fragment +import android.view.LayoutInflater +import android.view.View +import android.view.ViewGroup +import com.woka.R +import com.woka.databinding.FragmentSignInBinding + +class SignInFragment : Fragment() { + + private lateinit var binding: FragmentSignInBinding + + private var isUnder16 = false + + override fun onCreateView( + inflater: LayoutInflater, container: ViewGroup?, + savedInstanceState: Bundle? + ): View? { + binding = FragmentSignInBinding.inflate(inflater, container, false) + + clickEvents() + + return binding.root + } + + private fun clickEvents() { + binding.apply { + + } + } +} \ No newline at end of file diff --git a/app/src/main/java/com/woka/onboard/fragments/SignUpFragment.kt b/app/src/main/java/com/woka/onboard/fragments/SignUpFragment.kt new file mode 100644 index 0000000..89765fd --- /dev/null +++ b/app/src/main/java/com/woka/onboard/fragments/SignUpFragment.kt @@ -0,0 +1,65 @@ +package com.woka.onboard.fragments + +import android.os.Bundle +import androidx.fragment.app.Fragment +import android.view.LayoutInflater +import android.view.View +import android.view.View.VISIBLE +import android.view.ViewGroup +import androidx.navigation.fragment.findNavController +import com.woka.R +import com.woka.databinding.FragmentSignUpBinding +import com.woka.onboard.fragments.GetEmailFragment.Companion.IS_UNDER_16 +import com.woka.onboard.fragments.GetMoreInfoFragment.Companion.USER_NAME_ARG + +class SignUpFragment : Fragment() { + + private lateinit var binding: FragmentSignUpBinding + + private var isUnder16 = false + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + arguments?.let { + isUnder16 = it.getBoolean(IS_UNDER_16, false) + } + } + + override fun onCreateView( + inflater: LayoutInflater, container: ViewGroup?, + savedInstanceState: Bundle? + ): View? { + binding = FragmentSignUpBinding.inflate(inflater, container, false) + + initViews() + + clickEvents() + + return binding.root + } + + private fun initViews() { + binding.apply { + if (isUnder16){ + doNotShare.visibility = VISIBLE + } + } + } + + private fun clickEvents() { + binding.apply { + backBtn.setOnClickListener { + activity?.onBackPressedDispatcher?.onBackPressed() + } + + next.setOnClickListener { + val args = Bundle().apply { + putBoolean(IS_UNDER_16, isUnder16) + putString(USER_NAME_ARG, "Aditya") + } + + findNavController().navigate(R.id.action_signUpFragment_to_getMoreInfoFragment, args) + } + } + } +} \ No newline at end of file diff --git a/app/src/main/java/com/woka/onboard/fragments/SplashFragment.kt b/app/src/main/java/com/woka/onboard/fragments/SplashFragment.kt new file mode 100644 index 0000000..91cf52d --- /dev/null +++ b/app/src/main/java/com/woka/onboard/fragments/SplashFragment.kt @@ -0,0 +1,66 @@ +package com.woka.onboard.fragments + +import android.media.MediaPlayer +import android.os.Bundle +import android.view.LayoutInflater +import android.view.View +import android.view.ViewGroup +import androidx.fragment.app.Fragment +import androidx.lifecycle.lifecycleScope +import androidx.navigation.fragment.FragmentNavigatorExtras +import androidx.navigation.fragment.findNavController +import com.woka.R +import com.woka.databinding.FragmentSplashBinding +import kotlinx.coroutines.delay +import kotlinx.coroutines.launch + +/* + Root fragment to the launcher activity i.e. WelcomeActivity + */ +class SplashFragment : Fragment() { + + private lateinit var binding: FragmentSplashBinding + + private var player: MediaPlayer? = null + + override fun onCreateView( + inflater: LayoutInflater, container: ViewGroup?, + savedInstanceState: Bundle? + ): View? { + binding = FragmentSplashBinding.inflate(inflater, container, false) + return binding.root + } + + override fun onViewCreated(view: View, savedInstanceState: Bundle?) { + super.onViewCreated(view, savedInstanceState) + + playBgMusic() + + animateLogo() + + lifecycleScope.launch { + delay(6000) + val extras = FragmentNavigatorExtras(binding.logo to "logo") + findNavController().navigate(R.id.action_splashFragment_to_languageFragment, + null, null, extras) + } + } + + private fun playBgMusic() { + player = MediaPlayer.create(requireContext(), R.raw.audioone) + player?.start() + } + + private fun animateLogo() { + binding.logo.animate().scaleXBy(1f).scaleYBy(1f) + .setDuration(2000) + .start() + } + + override fun onDestroyView() { + super.onDestroyView() + player?.stop() + player?.release() + player = null + } +} \ No newline at end of file diff --git a/app/src/main/java/com/woka/onboard/models/Interest.kt b/app/src/main/java/com/woka/onboard/models/Interest.kt new file mode 100644 index 0000000..e4ab9df --- /dev/null +++ b/app/src/main/java/com/woka/onboard/models/Interest.kt @@ -0,0 +1,3 @@ +package com.woka.onboard.models + +data class Interest(val id: Int, val topic_name: String?) diff --git a/app/src/main/java/com/woka/userPreference/UserPreference.kt b/app/src/main/java/com/woka/userPreference/UserPreference.kt new file mode 100644 index 0000000..b7931fe --- /dev/null +++ b/app/src/main/java/com/woka/userPreference/UserPreference.kt @@ -0,0 +1,19 @@ +package com.woka.userPreference + +import android.content.Context +import android.content.Context.MODE_PRIVATE +import android.content.SharedPreferences + +class UserPreference(context: Context) { + + companion object{ + private const val USER_PREFERENCE = "woka_user_preferences" + private const val APP_LANGUAGE = "app_language" + } + + private val userPrefs: SharedPreferences = context.getSharedPreferences(USER_PREFERENCE, MODE_PRIVATE) + + var appLanguage: String + get() = userPrefs.getString(APP_LANGUAGE, "en")?:"en" + set(value) = userPrefs.edit().putString(APP_LANGUAGE, value).apply() +} \ No newline at end of file diff --git a/app/src/main/java/com/woka/utils/Extensions.kt b/app/src/main/java/com/woka/utils/Extensions.kt new file mode 100644 index 0000000..63ce23f --- /dev/null +++ b/app/src/main/java/com/woka/utils/Extensions.kt @@ -0,0 +1,42 @@ +package com.woka.utils + +import android.app.Activity +import android.content.Context +import android.content.res.Configuration +import android.view.View +import android.view.View.GONE +import android.view.View.VISIBLE +import android.view.inputmethod.InputMethodManager +import com.woka.WokaApp.Companion.userPrefs +import java.util.Locale + + +fun View.show(){ + this.visibility = VISIBLE +} + +fun View.hide(){ + this.visibility = GONE +} + +fun Context.changeLocale(language: String){ + val locale = Locale(language) + Locale.setDefault(locale) + val config: Configuration = this.resources.configuration + config.locale = locale + config.setLayoutDirection(locale) + this.resources.updateConfiguration( + config, + this.resources.displayMetrics + ) + + // saving to user preferences + userPrefs?.appLanguage = language +} + +fun Activity.closeKeyboard(){ + this.currentFocus?.let { + (this.getSystemService(Activity.INPUT_METHOD_SERVICE) as InputMethodManager) + .hideSoftInputFromWindow(it.windowToken, 0) + } +} \ No newline at end of file diff --git a/app/src/main/java/com/woka/utils/Gender.kt b/app/src/main/java/com/woka/utils/Gender.kt new file mode 100644 index 0000000..78a930c --- /dev/null +++ b/app/src/main/java/com/woka/utils/Gender.kt @@ -0,0 +1,5 @@ +package com.woka.utils + +enum class Gender(value: Int){ + MALE(0), FEMALE(1), NONE(-1) +} \ No newline at end of file diff --git a/app/src/main/java/com/woka/utils/Utils.kt b/app/src/main/java/com/woka/utils/Utils.kt new file mode 100644 index 0000000..d99f77b --- /dev/null +++ b/app/src/main/java/com/woka/utils/Utils.kt @@ -0,0 +1 @@ +package com.woka.utils \ No newline at end of file diff --git a/app/src/main/java/com/woka/utils/WokaBaseActivity.kt b/app/src/main/java/com/woka/utils/WokaBaseActivity.kt new file mode 100644 index 0000000..a62cb60 --- /dev/null +++ b/app/src/main/java/com/woka/utils/WokaBaseActivity.kt @@ -0,0 +1,23 @@ +package com.woka.utils + +import android.content.Context +import android.content.res.Configuration +import android.os.Bundle +import androidx.appcompat.app.AppCompatActivity +import androidx.core.view.WindowCompat +import com.woka.WokaApp.Companion.userPrefs +import kotlin.math.min + +/* + Every activity in this application should extend to this Activity + to establish common configurations to every activity + */ +open class WokaBaseActivity: AppCompatActivity() { + override fun attachBaseContext(newBase: Context?) { + val configuration = Configuration(newBase?.resources?.configuration) + configuration.fontScale = min(configuration.fontScale.toDouble(), 1.0).toFloat() + applyOverrideConfiguration(configuration) + super.attachBaseContext(newBase) + changeLocale(userPrefs?.appLanguage?:"en") + } +} \ No newline at end of file diff --git a/app/src/main/res/drawable-hdpi/age_bg.png b/app/src/main/res/drawable-hdpi/age_bg.png new file mode 100644 index 0000000..d53c683 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/age_bg.png differ diff --git a/app/src/main/res/drawable-hdpi/slide1.png b/app/src/main/res/drawable-hdpi/slide1.png new file mode 100644 index 0000000..92129d7 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/slide1.png differ diff --git a/app/src/main/res/drawable-hdpi/slide2.png b/app/src/main/res/drawable-hdpi/slide2.png new file mode 100644 index 0000000..a6fc50d Binary files /dev/null and b/app/src/main/res/drawable-hdpi/slide2.png differ diff --git a/app/src/main/res/drawable-hdpi/slide3.png b/app/src/main/res/drawable-hdpi/slide3.png new file mode 100644 index 0000000..6cbd269 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/slide3.png differ diff --git a/app/src/main/res/drawable-hdpi/splash_bg.png b/app/src/main/res/drawable-hdpi/splash_bg.png new file mode 100644 index 0000000..44e17db Binary files /dev/null and b/app/src/main/res/drawable-hdpi/splash_bg.png differ diff --git a/app/src/main/res/drawable-hdpi/woka_logo_full.png b/app/src/main/res/drawable-hdpi/woka_logo_full.png new file mode 100644 index 0000000..0934c89 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/woka_logo_full.png differ diff --git a/app/src/main/res/drawable-hdpi/woka_logo_half.png b/app/src/main/res/drawable-hdpi/woka_logo_half.png new file mode 100644 index 0000000..2f38600 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/woka_logo_half.png differ diff --git a/app/src/main/res/drawable-ldpi/age_bg.png b/app/src/main/res/drawable-ldpi/age_bg.png new file mode 100644 index 0000000..ae82b5e Binary files /dev/null and b/app/src/main/res/drawable-ldpi/age_bg.png differ diff --git a/app/src/main/res/drawable-ldpi/slide1.png b/app/src/main/res/drawable-ldpi/slide1.png new file mode 100644 index 0000000..fe4cbeb Binary files /dev/null and b/app/src/main/res/drawable-ldpi/slide1.png differ diff --git a/app/src/main/res/drawable-ldpi/slide2.png b/app/src/main/res/drawable-ldpi/slide2.png new file mode 100644 index 0000000..417ba83 Binary files /dev/null and b/app/src/main/res/drawable-ldpi/slide2.png differ diff --git a/app/src/main/res/drawable-ldpi/slide3.png b/app/src/main/res/drawable-ldpi/slide3.png new file mode 100644 index 0000000..ef841e8 Binary files /dev/null and b/app/src/main/res/drawable-ldpi/slide3.png differ diff --git a/app/src/main/res/drawable-ldpi/splash_bg.png b/app/src/main/res/drawable-ldpi/splash_bg.png new file mode 100644 index 0000000..54a58e1 Binary files /dev/null and b/app/src/main/res/drawable-ldpi/splash_bg.png differ diff --git a/app/src/main/res/drawable-ldpi/woka_logo_full.png b/app/src/main/res/drawable-ldpi/woka_logo_full.png new file mode 100644 index 0000000..1df7172 Binary files /dev/null and b/app/src/main/res/drawable-ldpi/woka_logo_full.png differ diff --git a/app/src/main/res/drawable-ldpi/woka_logo_half.png b/app/src/main/res/drawable-ldpi/woka_logo_half.png new file mode 100644 index 0000000..2634acc Binary files /dev/null and b/app/src/main/res/drawable-ldpi/woka_logo_half.png differ diff --git a/app/src/main/res/drawable-mdpi/age_bg.png b/app/src/main/res/drawable-mdpi/age_bg.png new file mode 100644 index 0000000..35ee639 Binary files /dev/null and b/app/src/main/res/drawable-mdpi/age_bg.png differ diff --git a/app/src/main/res/drawable-mdpi/slide1.png b/app/src/main/res/drawable-mdpi/slide1.png new file mode 100644 index 0000000..adc3f91 Binary files /dev/null and b/app/src/main/res/drawable-mdpi/slide1.png differ diff --git a/app/src/main/res/drawable-mdpi/slide2.png b/app/src/main/res/drawable-mdpi/slide2.png new file mode 100644 index 0000000..b43ef73 Binary files /dev/null and b/app/src/main/res/drawable-mdpi/slide2.png differ diff --git a/app/src/main/res/drawable-mdpi/slide3.png b/app/src/main/res/drawable-mdpi/slide3.png new file mode 100644 index 0000000..ae76959 Binary files /dev/null and b/app/src/main/res/drawable-mdpi/slide3.png differ diff --git a/app/src/main/res/drawable-mdpi/splash_bg.png b/app/src/main/res/drawable-mdpi/splash_bg.png new file mode 100644 index 0000000..12de87d Binary files /dev/null and b/app/src/main/res/drawable-mdpi/splash_bg.png differ diff --git a/app/src/main/res/drawable-mdpi/woka_logo_full.png b/app/src/main/res/drawable-mdpi/woka_logo_full.png new file mode 100644 index 0000000..725d0a9 Binary files /dev/null and b/app/src/main/res/drawable-mdpi/woka_logo_full.png differ diff --git a/app/src/main/res/drawable-mdpi/woka_logo_half.png b/app/src/main/res/drawable-mdpi/woka_logo_half.png new file mode 100644 index 0000000..867b40f Binary files /dev/null and b/app/src/main/res/drawable-mdpi/woka_logo_half.png differ diff --git a/app/src/main/res/drawable-xhdpi/age_bg.png b/app/src/main/res/drawable-xhdpi/age_bg.png new file mode 100644 index 0000000..d2f7bb5 Binary files /dev/null and b/app/src/main/res/drawable-xhdpi/age_bg.png differ diff --git a/app/src/main/res/drawable-xhdpi/slide1.png b/app/src/main/res/drawable-xhdpi/slide1.png new file mode 100644 index 0000000..53a4940 Binary files /dev/null and b/app/src/main/res/drawable-xhdpi/slide1.png differ diff --git a/app/src/main/res/drawable-xhdpi/slide2.png b/app/src/main/res/drawable-xhdpi/slide2.png new file mode 100644 index 0000000..6ee7078 Binary files /dev/null and b/app/src/main/res/drawable-xhdpi/slide2.png differ diff --git a/app/src/main/res/drawable-xhdpi/slide3.png b/app/src/main/res/drawable-xhdpi/slide3.png new file mode 100644 index 0000000..c2fc669 Binary files /dev/null and b/app/src/main/res/drawable-xhdpi/slide3.png differ diff --git a/app/src/main/res/drawable-xhdpi/splash_bg.png b/app/src/main/res/drawable-xhdpi/splash_bg.png new file mode 100644 index 0000000..4240ba5 Binary files /dev/null and b/app/src/main/res/drawable-xhdpi/splash_bg.png differ diff --git a/app/src/main/res/drawable-xhdpi/woka_logo_full.png b/app/src/main/res/drawable-xhdpi/woka_logo_full.png new file mode 100644 index 0000000..ad20d0a Binary files /dev/null and b/app/src/main/res/drawable-xhdpi/woka_logo_full.png differ diff --git a/app/src/main/res/drawable-xhdpi/woka_logo_half.png b/app/src/main/res/drawable-xhdpi/woka_logo_half.png new file mode 100644 index 0000000..e75eafd Binary files /dev/null and b/app/src/main/res/drawable-xhdpi/woka_logo_half.png differ diff --git a/app/src/main/res/drawable-xxhdpi/age_bg.png b/app/src/main/res/drawable-xxhdpi/age_bg.png new file mode 100644 index 0000000..b7a38b9 Binary files /dev/null and b/app/src/main/res/drawable-xxhdpi/age_bg.png differ diff --git a/app/src/main/res/drawable-xxhdpi/slide1.png b/app/src/main/res/drawable-xxhdpi/slide1.png new file mode 100644 index 0000000..c4647e8 Binary files /dev/null and b/app/src/main/res/drawable-xxhdpi/slide1.png differ diff --git a/app/src/main/res/drawable-xxhdpi/slide2.png b/app/src/main/res/drawable-xxhdpi/slide2.png new file mode 100644 index 0000000..df3c1d6 Binary files /dev/null and b/app/src/main/res/drawable-xxhdpi/slide2.png differ diff --git a/app/src/main/res/drawable-xxhdpi/slide3.png b/app/src/main/res/drawable-xxhdpi/slide3.png new file mode 100644 index 0000000..9142d85 Binary files /dev/null and b/app/src/main/res/drawable-xxhdpi/slide3.png differ diff --git a/app/src/main/res/drawable-xxhdpi/splash_bg.png b/app/src/main/res/drawable-xxhdpi/splash_bg.png new file mode 100644 index 0000000..50201e9 Binary files /dev/null and b/app/src/main/res/drawable-xxhdpi/splash_bg.png differ diff --git a/app/src/main/res/drawable-xxhdpi/woka_logo_full.png b/app/src/main/res/drawable-xxhdpi/woka_logo_full.png new file mode 100644 index 0000000..1a00fc1 Binary files /dev/null and b/app/src/main/res/drawable-xxhdpi/woka_logo_full.png differ diff --git a/app/src/main/res/drawable-xxhdpi/woka_logo_half.png b/app/src/main/res/drawable-xxhdpi/woka_logo_half.png new file mode 100644 index 0000000..e8a768b Binary files /dev/null and b/app/src/main/res/drawable-xxhdpi/woka_logo_half.png differ diff --git a/app/src/main/res/drawable-xxxhdpi/age_bg.png b/app/src/main/res/drawable-xxxhdpi/age_bg.png new file mode 100644 index 0000000..7b22829 Binary files /dev/null and b/app/src/main/res/drawable-xxxhdpi/age_bg.png differ diff --git a/app/src/main/res/drawable-xxxhdpi/slide1.png b/app/src/main/res/drawable-xxxhdpi/slide1.png new file mode 100644 index 0000000..79401e6 Binary files /dev/null and b/app/src/main/res/drawable-xxxhdpi/slide1.png differ diff --git a/app/src/main/res/drawable-xxxhdpi/slide2.png b/app/src/main/res/drawable-xxxhdpi/slide2.png new file mode 100644 index 0000000..0a10be2 Binary files /dev/null and b/app/src/main/res/drawable-xxxhdpi/slide2.png differ diff --git a/app/src/main/res/drawable-xxxhdpi/slide3.png b/app/src/main/res/drawable-xxxhdpi/slide3.png new file mode 100644 index 0000000..5968421 Binary files /dev/null and b/app/src/main/res/drawable-xxxhdpi/slide3.png differ diff --git a/app/src/main/res/drawable-xxxhdpi/splash_bg.png b/app/src/main/res/drawable-xxxhdpi/splash_bg.png new file mode 100644 index 0000000..c070150 Binary files /dev/null and b/app/src/main/res/drawable-xxxhdpi/splash_bg.png differ diff --git a/app/src/main/res/drawable-xxxhdpi/woka_logo_full.png b/app/src/main/res/drawable-xxxhdpi/woka_logo_full.png new file mode 100644 index 0000000..db49731 Binary files /dev/null and b/app/src/main/res/drawable-xxxhdpi/woka_logo_full.png differ diff --git a/app/src/main/res/drawable-xxxhdpi/woka_logo_half.png b/app/src/main/res/drawable-xxxhdpi/woka_logo_half.png new file mode 100644 index 0000000..ca30df9 Binary files /dev/null and b/app/src/main/res/drawable-xxxhdpi/woka_logo_half.png differ diff --git a/app/src/main/res/drawable/age_box_bg.xml b/app/src/main/res/drawable/age_box_bg.xml new file mode 100644 index 0000000..3a8e9e8 --- /dev/null +++ b/app/src/main/res/drawable/age_box_bg.xml @@ -0,0 +1,16 @@ + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/default_dot.xml b/app/src/main/res/drawable/default_dot.xml new file mode 100644 index 0000000..8f1f465 --- /dev/null +++ b/app/src/main/res/drawable/default_dot.xml @@ -0,0 +1,15 @@ + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/grad_btn_bg_4.xml b/app/src/main/res/drawable/grad_btn_bg_4.xml new file mode 100644 index 0000000..1fd236a --- /dev/null +++ b/app/src/main/res/drawable/grad_btn_bg_4.xml @@ -0,0 +1,13 @@ + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/gradient_btn_bg.xml b/app/src/main/res/drawable/gradient_btn_bg.xml new file mode 100644 index 0000000..6a06b03 --- /dev/null +++ b/app/src/main/res/drawable/gradient_btn_bg.xml @@ -0,0 +1,13 @@ + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/gradient_btn_bg_2.xml b/app/src/main/res/drawable/gradient_btn_bg_2.xml new file mode 100644 index 0000000..2e9568d --- /dev/null +++ b/app/src/main/res/drawable/gradient_btn_bg_2.xml @@ -0,0 +1,13 @@ + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/gradient_btn_bg_3.xml b/app/src/main/res/drawable/gradient_btn_bg_3.xml new file mode 100644 index 0000000..b5da50e --- /dev/null +++ b/app/src/main/res/drawable/gradient_btn_bg_3.xml @@ -0,0 +1,13 @@ + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/ic_arrow_back.xml b/app/src/main/res/drawable/ic_arrow_back.xml new file mode 100644 index 0000000..99f85de --- /dev/null +++ b/app/src/main/res/drawable/ic_arrow_back.xml @@ -0,0 +1,5 @@ + + + + + diff --git a/app/src/main/res/drawable/ic_gender_f.xml b/app/src/main/res/drawable/ic_gender_f.xml new file mode 100644 index 0000000..3864525 --- /dev/null +++ b/app/src/main/res/drawable/ic_gender_f.xml @@ -0,0 +1,280 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/app/src/main/res/drawable/ic_gender_m.xml b/app/src/main/res/drawable/ic_gender_m.xml new file mode 100644 index 0000000..0d837d2 --- /dev/null +++ b/app/src/main/res/drawable/ic_gender_m.xml @@ -0,0 +1,345 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/app/src/main/res/drawable/ic_launcher_background.xml b/app/src/main/res/drawable/ic_launcher_background.xml new file mode 100644 index 0000000..07d5da9 --- /dev/null +++ b/app/src/main/res/drawable/ic_launcher_background.xml @@ -0,0 +1,170 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/app/src/main/res/drawable/ic_launcher_foreground.xml b/app/src/main/res/drawable/ic_launcher_foreground.xml new file mode 100644 index 0000000..2b068d1 --- /dev/null +++ b/app/src/main/res/drawable/ic_launcher_foreground.xml @@ -0,0 +1,30 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/onboard_indicator_selector.xml b/app/src/main/res/drawable/onboard_indicator_selector.xml new file mode 100644 index 0000000..f6ef246 --- /dev/null +++ b/app/src/main/res/drawable/onboard_indicator_selector.xml @@ -0,0 +1,6 @@ + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/otp_et_bg.xml b/app/src/main/res/drawable/otp_et_bg.xml new file mode 100644 index 0000000..e3347a2 --- /dev/null +++ b/app/src/main/res/drawable/otp_et_bg.xml @@ -0,0 +1,25 @@ + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/round_25_shadow.xml b/app/src/main/res/drawable/round_25_shadow.xml new file mode 100644 index 0000000..7c0c3c6 --- /dev/null +++ b/app/src/main/res/drawable/round_25_shadow.xml @@ -0,0 +1,25 @@ + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/selected_dot.xml b/app/src/main/res/drawable/selected_dot.xml new file mode 100644 index 0000000..6fbeb35 --- /dev/null +++ b/app/src/main/res/drawable/selected_dot.xml @@ -0,0 +1,15 @@ + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/font/exo_2.ttf b/app/src/main/res/font/exo_2.ttf new file mode 100644 index 0000000..f4cb89c Binary files /dev/null and b/app/src/main/res/font/exo_2.ttf differ diff --git a/app/src/main/res/font/exo_2_bold.ttf b/app/src/main/res/font/exo_2_bold.ttf new file mode 100644 index 0000000..2d2fe2f Binary files /dev/null and b/app/src/main/res/font/exo_2_bold.ttf differ diff --git a/app/src/main/res/font/exo_2_extrabold.ttf b/app/src/main/res/font/exo_2_extrabold.ttf new file mode 100644 index 0000000..53c6cba Binary files /dev/null and b/app/src/main/res/font/exo_2_extrabold.ttf differ diff --git a/app/src/main/res/font/exo_2_medium.ttf b/app/src/main/res/font/exo_2_medium.ttf new file mode 100644 index 0000000..3b04a0a Binary files /dev/null and b/app/src/main/res/font/exo_2_medium.ttf differ diff --git a/app/src/main/res/font/exo_2_semibold.ttf b/app/src/main/res/font/exo_2_semibold.ttf new file mode 100644 index 0000000..dba86a0 Binary files /dev/null and b/app/src/main/res/font/exo_2_semibold.ttf differ diff --git a/app/src/main/res/font/exo_2_thin.ttf b/app/src/main/res/font/exo_2_thin.ttf new file mode 100644 index 0000000..19b9d4d Binary files /dev/null and b/app/src/main/res/font/exo_2_thin.ttf differ diff --git a/app/src/main/res/layout/activity_onboard.xml b/app/src/main/res/layout/activity_onboard.xml new file mode 100644 index 0000000..e98ee8d --- /dev/null +++ b/app/src/main/res/layout/activity_onboard.xml @@ -0,0 +1,19 @@ + + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/activity_welcome.xml b/app/src/main/res/layout/activity_welcome.xml new file mode 100644 index 0000000..25c1f90 --- /dev/null +++ b/app/src/main/res/layout/activity_welcome.xml @@ -0,0 +1,24 @@ + + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/fragment_age_select.xml b/app/src/main/res/layout/fragment_age_select.xml new file mode 100644 index 0000000..7a34c38 --- /dev/null +++ b/app/src/main/res/layout/fragment_age_select.xml @@ -0,0 +1,270 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/fragment_get_code.xml b/app/src/main/res/layout/fragment_get_code.xml new file mode 100644 index 0000000..a083dcb --- /dev/null +++ b/app/src/main/res/layout/fragment_get_code.xml @@ -0,0 +1,248 @@ + + + + + + + + + + + + + + + + + + + + + + + + + +