diff options
15 files changed, 194 insertions, 3 deletions
diff --git a/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/LoginDataSource.kt b/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/LoginDataSource.kt new file mode 100644 index 0000000..3f761ea --- /dev/null +++ b/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/LoginDataSource.kt @@ -0,0 +1,9 @@ +package com.frannazario.proyectoandroid.data.datasources + +import androidx.lifecycle.LiveData +import com.frannazario.proyectoandroid.data.responses.LoginResponse +import com.frannazario.proyectoandroid.data.responses.SigninResponse + +interface LoginDataSource { + fun login (email: String, password: String): LiveData<LoginResponse> +}
\ No newline at end of file diff --git a/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/LoginRemoteDataSource.kt b/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/LoginRemoteDataSource.kt new file mode 100644 index 0000000..3f86c06 --- /dev/null +++ b/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/LoginRemoteDataSource.kt @@ -0,0 +1,26 @@ +package com.frannazario.proyectoandroid.data.datasources + +import androidx.lifecycle.LiveData +import androidx.lifecycle.MutableLiveData +import com.frannazario.proyectoandroid.data.responses.LoginResponse +import com.google.firebase.auth.FirebaseAuth + +class LoginRemoteDataSource: LoginDataSource{ + private val auth = FirebaseAuth.getInstance() + + override fun login(email: String, password: String): LiveData<LoginResponse> { + val resultLiveData = MutableLiveData<LoginResponse>() + + auth.signInWithEmailAndPassword(email, password) + .addOnCompleteListener { task -> + if (task.isSuccessful) { + val user = auth.currentUser + resultLiveData.value = LoginResponse.Success(user) + } else { + val error = task.exception?.message ?: "Error desconocido" + resultLiveData.value = LoginResponse.Error(error) + } + } + return resultLiveData + } +}
\ No newline at end of file diff --git a/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/PasswordRecoveryDataSource.kt b/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/PasswordRecoveryDataSource.kt new file mode 100644 index 0000000..5ef08f4 --- /dev/null +++ b/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/PasswordRecoveryDataSource.kt @@ -0,0 +1,8 @@ +package com.frannazario.proyectoandroid.data.datasources + +import androidx.lifecycle.LiveData +import com.frannazario.proyectoandroid.data.responses.PasswordRecoveryResponse + +interface PasswordRecoveryDataSource { + fun recover (email: String): LiveData<PasswordRecoveryResponse> +}
\ No newline at end of file diff --git a/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/PasswordRecoveryRemoteDataSource.kt b/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/PasswordRecoveryRemoteDataSource.kt new file mode 100644 index 0000000..08335ad --- /dev/null +++ b/app/src/main/java/com/frannazario/proyectoandroid/data/datasources/PasswordRecoveryRemoteDataSource.kt @@ -0,0 +1,26 @@ +package com.frannazario.proyectoandroid.data.datasources + +import androidx.lifecycle.LiveData +import androidx.lifecycle.MutableLiveData +import com.frannazario.proyectoandroid.data.responses.PasswordRecoveryResponse +import com.google.firebase.auth.FirebaseAuth + +class PasswordRecoveryRemoteDataSource: PasswordRecoveryDataSource { + private val auth = FirebaseAuth.getInstance() + + override fun recover (email: String): LiveData<PasswordRecoveryResponse> { + val resultLiveData = MutableLiveData<PasswordRecoveryResponse>() + + auth.sendPasswordResetEmail(email) + .addOnCompleteListener { task -> + if (task.isSuccessful) { + val user = auth.currentUser + resultLiveData.value = PasswordRecoveryResponse.Success(user) + } else { + val error = task.exception?.message ?: "Error desconocido" + resultLiveData.value = PasswordRecoveryResponse.Error(error) + } + } + return resultLiveData + } +}
\ No newline at end of file diff --git a/app/src/main/java/com/frannazario/proyectoandroid/data/repositories/LoginRepository.kt b/app/src/main/java/com/frannazario/proyectoandroid/data/repositories/LoginRepository.kt new file mode 100644 index 0000000..9532534 --- /dev/null +++ b/app/src/main/java/com/frannazario/proyectoandroid/data/repositories/LoginRepository.kt @@ -0,0 +1,14 @@ +package com.frannazario.proyectoandroid.data.repositories + +import androidx.lifecycle.LiveData +import com.frannazario.proyectoandroid.data.datasources.LoginDataSource +import com.frannazario.proyectoandroid.data.datasources.LoginRemoteDataSource +import com.frannazario.proyectoandroid.data.responses.LoginResponse + +class LoginRepository( + private val remoteDataSource: LoginDataSource = LoginRemoteDataSource() + ) { + fun login (email: String, password: String): LiveData<LoginResponse> { + return remoteDataSource.login(email, password) + } +}
\ No newline at end of file diff --git a/app/src/main/java/com/frannazario/proyectoandroid/data/repositories/PasswordRecoveryRepository.kt b/app/src/main/java/com/frannazario/proyectoandroid/data/repositories/PasswordRecoveryRepository.kt new file mode 100644 index 0000000..6550ae2 --- /dev/null +++ b/app/src/main/java/com/frannazario/proyectoandroid/data/repositories/PasswordRecoveryRepository.kt @@ -0,0 +1,14 @@ +package com.frannazario.proyectoandroid.data.repositories + +import androidx.lifecycle.LiveData +import com.frannazario.proyectoandroid.data.datasources.PasswordRecoveryDataSource +import com.frannazario.proyectoandroid.data.datasources.PasswordRecoveryRemoteDataSource +import com.frannazario.proyectoandroid.data.responses.PasswordRecoveryResponse + +class PasswordRecoveryRepository ( + private val remoteDataSource: PasswordRecoveryDataSource= PasswordRecoveryRemoteDataSource() + ) { + fun recover(email: String): LiveData<PasswordRecoveryResponse> { + return remoteDataSource.recover(email) + } +}
\ No newline at end of file diff --git a/app/src/main/java/com/frannazario/proyectoandroid/data/responses/LoginResponse.kt b/app/src/main/java/com/frannazario/proyectoandroid/data/responses/LoginResponse.kt new file mode 100644 index 0000000..9eb5518 --- /dev/null +++ b/app/src/main/java/com/frannazario/proyectoandroid/data/responses/LoginResponse.kt @@ -0,0 +1,9 @@ +package com.frannazario.proyectoandroid.data.responses + +import com.google.firebase.auth.FirebaseUser + +sealed class LoginResponse { + + data class Success(val user: FirebaseUser?): LoginResponse() + data class Error(val error: String): LoginResponse() +}
\ No newline at end of file diff --git a/app/src/main/java/com/frannazario/proyectoandroid/data/responses/PasswordRecoveryResponse.kt b/app/src/main/java/com/frannazario/proyectoandroid/data/responses/PasswordRecoveryResponse.kt new file mode 100644 index 0000000..98b5e39 --- /dev/null +++ b/app/src/main/java/com/frannazario/proyectoandroid/data/responses/PasswordRecoveryResponse.kt @@ -0,0 +1,8 @@ +package com.frannazario.proyectoandroid.data.responses + +import com.google.firebase.auth.FirebaseUser + +sealed class PasswordRecoveryResponse { + data class Success(val user: FirebaseUser?): PasswordRecoveryResponse() + data class Error(val error: String): PasswordRecoveryResponse() +}
\ No newline at end of file diff --git a/app/src/main/java/com/frannazario/proyectoandroid/data/viewmodels/LoginViewModel.kt b/app/src/main/java/com/frannazario/proyectoandroid/data/viewmodels/LoginViewModel.kt new file mode 100644 index 0000000..9fe0988 --- /dev/null +++ b/app/src/main/java/com/frannazario/proyectoandroid/data/viewmodels/LoginViewModel.kt @@ -0,0 +1,18 @@ +package com.frannazario.proyectoandroid.data.viewmodels + +import androidx.lifecycle.LiveData +import androidx.lifecycle.MutableLiveData +import androidx.lifecycle.ViewModel +import com.frannazario.proyectoandroid.data.repositories.LoginRepository +import com.frannazario.proyectoandroid.data.responses.LoginResponse + +class LoginViewModel(private val repository: LoginRepository= LoginRepository()): ViewModel() { + private val loginResponseLiveData = MutableLiveData<LoginResponse>() + fun getLoginResultLiveData(): LiveData<LoginResponse> { + return loginResponseLiveData + } + fun login(email: String, password: String) { + val response = repository.login(email, password) + loginResponseLiveData.postValue(response.value) + } +} diff --git a/app/src/main/java/com/frannazario/proyectoandroid/data/viewmodels/PasswordRecoveryViewModel.kt b/app/src/main/java/com/frannazario/proyectoandroid/data/viewmodels/PasswordRecoveryViewModel.kt new file mode 100644 index 0000000..b2511a8 --- /dev/null +++ b/app/src/main/java/com/frannazario/proyectoandroid/data/viewmodels/PasswordRecoveryViewModel.kt @@ -0,0 +1,20 @@ +package com.frannazario.proyectoandroid.data.viewmodels + +import androidx.lifecycle.LiveData +import androidx.lifecycle.MutableLiveData +import androidx.lifecycle.ViewModel +import com.frannazario.proyectoandroid.data.repositories.PasswordRecoveryRepository +import com.frannazario.proyectoandroid.data.responses.PasswordRecoveryResponse + +class PasswordRecoveryViewModel(private val repository: PasswordRecoveryRepository = PasswordRecoveryRepository()): ViewModel() { + private val passwordRecoveryResponseLiveData = MutableLiveData<PasswordRecoveryResponse>() + + fun getPasswordRecoveryResultLiveData(): LiveData<PasswordRecoveryResponse> { + return passwordRecoveryResponseLiveData + } + + fun recover (email: String) { + val response = repository.recover(email) + passwordRecoveryResponseLiveData.postValue(response.value) + } +} diff --git a/app/src/main/java/com/frannazario/proyectoandroid/presentation/fragments/LoginFragment.kt b/app/src/main/java/com/frannazario/proyectoandroid/presentation/fragments/LoginFragment.kt index fcabbe1..7167738 100644 --- a/app/src/main/java/com/frannazario/proyectoandroid/presentation/fragments/LoginFragment.kt +++ b/app/src/main/java/com/frannazario/proyectoandroid/presentation/fragments/LoginFragment.kt @@ -7,11 +7,19 @@ import android.view.ViewGroup import androidx.fragment.app.Fragment import androidx.navigation.fragment.findNavController import com.frannazario.proyectoandroid.R +import com.frannazario.proyectoandroid.data.responses.LoginResponse +import com.frannazario.proyectoandroid.data.viewmodels.LoginViewModel import com.frannazario.proyectoandroid.databinding.FragmentLoginBinding class LoginFragment: Fragment() { private lateinit var binding: FragmentLoginBinding + private lateinit var viewModel: LoginViewModel + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + viewModel = LoginViewModel() + } override fun onCreateView( inflater: LayoutInflater, container: ViewGroup?, @@ -26,4 +34,15 @@ class LoginFragment: Fragment() { } return binding.root } + + + override fun onViewCreated(view: View, savedInstanceState: Bundle?) { + super.onViewCreated(view, savedInstanceState) + viewModel.getLoginResultLiveData().observe(viewLifecycleOwner) { response -> + when (response) { + is LoginResponse.Success -> {} + is LoginResponse.Error -> {} + } + } + } }
\ No newline at end of file diff --git a/app/src/main/java/com/frannazario/proyectoandroid/presentation/fragments/PasswordRecoveryFragment.kt b/app/src/main/java/com/frannazario/proyectoandroid/presentation/fragments/PasswordRecoveryFragment.kt index 35b56d0..7c7d922 100644 --- a/app/src/main/java/com/frannazario/proyectoandroid/presentation/fragments/PasswordRecoveryFragment.kt +++ b/app/src/main/java/com/frannazario/proyectoandroid/presentation/fragments/PasswordRecoveryFragment.kt @@ -5,10 +5,18 @@ import android.view.LayoutInflater import android.view.View import android.view.ViewGroup import androidx.fragment.app.Fragment +import com.frannazario.proyectoandroid.data.responses.PasswordRecoveryResponse +import com.frannazario.proyectoandroid.data.viewmodels.PasswordRecoveryViewModel import com.frannazario.proyectoandroid.databinding.FragmentPasswordRecoveryBinding class PasswordRecoveryFragment: Fragment() { private lateinit var binding: FragmentPasswordRecoveryBinding + private lateinit var viewModel: PasswordRecoveryViewModel + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + viewModel = PasswordRecoveryViewModel() + } override fun onCreateView( inflater: LayoutInflater, @@ -18,4 +26,14 @@ class PasswordRecoveryFragment: Fragment() { binding = FragmentPasswordRecoveryBinding.inflate(inflater, container, false) return binding.root } + + override fun onViewCreated(view: View, savedInstanceState: Bundle?) { + super.onViewCreated(view, savedInstanceState) + viewModel.getPasswordRecoveryResultLiveData().observe(viewLifecycleOwner) { response -> + when (response) { + is PasswordRecoveryResponse.Success -> {} + is PasswordRecoveryResponse.Error -> {} + } + } + } }
\ No newline at end of file diff --git a/app/src/main/res/layout/fragment_login.xml b/app/src/main/res/layout/fragment_login.xml index ca2d5bc..61f0a8d 100644 --- a/app/src/main/res/layout/fragment_login.xml +++ b/app/src/main/res/layout/fragment_login.xml @@ -59,6 +59,6 @@ app:layout_constraintTop_toBottomOf="@id/forget_password_btn" app:layout_constraintStart_toStartOf="parent" app:layout_constraintEnd_toEndOf="parent" - android:text="@string/signin" /> + android:text="@string/signup" /> </androidx.constraintlayout.widget.ConstraintLayout>
\ No newline at end of file diff --git a/app/src/main/res/values-es/strings.xml b/app/src/main/res/values-es/strings.xml index 3f7cc92..a4a8581 100644 --- a/app/src/main/res/values-es/strings.xml +++ b/app/src/main/res/values-es/strings.xml @@ -1,9 +1,10 @@ <?xml version="1.0" encoding="utf-8"?> <resources> <string name="field_email">Correo electronico</string> + <string name="field_password">Contrasena</string> <string name="field_signin">Registro</string> <string name="field_password">Contraseña</string> <string name="forgot_password">Olvidé la contraseña</string> - <string name="signin">Registrarte</string> + <string name="signup">Registrarte</string> <string name="login">Acceder</string> </resources>
\ No newline at end of file diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index 84a3e04..b04b94d 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -2,9 +2,10 @@ <string name="app_name" translatable="false">Proyecto android</string> <string name="field_email">Email</string> + <string name="field_password">Password</string> <string name="field_signin">Sign in</string> <string name="field_password">Password</string> <string name="forgot_password">Forget password</string> - <string name="signin">Sign in</string> + <string name="signup">Sign Up</string> <string name="login">Login</string> </resources>
\ No newline at end of file |