From b3a51f064c4dfb27f54cd9526803338d2e8dc296 Mon Sep 17 00:00:00 2001
From: Runt <qingingrunt2010@qq.com>
Date: Sat, 13 Aug 2022 16:26:49 +0000
Subject: [PATCH] 添加注释,部分优化

---
 app/src/main/java/com/runt/open/mvvm/ui/login/LoginViewModel.java |  100 ++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 93 insertions(+), 7 deletions(-)

diff --git a/app/src/main/java/com/runt/open/mvvm/ui/login/LoginViewModel.java b/app/src/main/java/com/runt/open/mvvm/ui/login/LoginViewModel.java
index 866420b..e285cde 100644
--- a/app/src/main/java/com/runt/open/mvvm/ui/login/LoginViewModel.java
+++ b/app/src/main/java/com/runt/open/mvvm/ui/login/LoginViewModel.java
@@ -1,12 +1,16 @@
 package com.runt.open.mvvm.ui.login;
 
 import androidx.lifecycle.MutableLiveData;
-
+import com.runt.open.mvvm.R;
+import com.runt.open.mvvm.base.activities.BaseActivity;
 import com.runt.open.mvvm.base.model.BaseViewModel;
+import com.runt.open.mvvm.config.Configuration;
+import com.runt.open.mvvm.data.HttpApiResult;
+import com.runt.open.mvvm.data.Results;
 import com.runt.open.mvvm.retrofit.api.LoginApiCenter;
 import com.runt.open.mvvm.retrofit.observable.HttpObserver;
 import com.runt.open.mvvm.retrofit.utils.RetrofitUtils;
-
+import com.runt.open.mvvm.util.MyLog;
 import io.reactivex.Observable;
 
 /**
@@ -14,17 +18,99 @@
  */
 public class LoginViewModel extends BaseViewModel {
 
-    MutableLiveData<LoggedInUser> loginResult = new MutableLiveData<>();
+    LoginApiCenter loginApi;
 
-    public MutableLiveData<LoggedInUser> getLoginResult() {
-        return loginResult;
+    public LoginViewModel() {
+        loginApi = RetrofitUtils.getInstance().getRetrofit(LoginApiCenter.class);
     }
 
+    MutableLiveData<Results.StringApiResult> registerResult = new MutableLiveData<>();
+    HttpObserver<UserBean> logginObserver;
+
+    @Override
+    public void onCreate(BaseActivity activity) {
+        super.onCreate(activity);
+        logginObserver = new HttpObserver<UserBean>(mActivity){
+            @Override
+            protected void onSuccess(UserBean data) {
+                UserBean.setUser(data);
+                mActivity.putStringProjectPrefrence(Configuration.KEY_USERNAME, data.getUsername());
+                MyLog.i("registerlogin",data.toString());
+                mActivity.showToast(R.string.login_success);
+                mActivity.setResult(mActivity.RESULT_CODE_SUCESS);
+                mActivity.finish();
+            }
+        };
+    }
+
+
+    /**
+     * 密码登录
+     * @param username
+     * @param password
+     */
     public void login(String username, String password) {
         // can be launched in a separate asynchronous job
-        final Observable<LoggedInUser> userObservable = RetrofitUtils.getInstance().getRetrofit(LoginApiCenter.class).login(username, password);
-        httpObserverOn(userObservable,new HttpObserver<LoggedInUser>(loginResult){});
+        final Observable<HttpApiResult<UserBean>> userObservable = loginApi.login(username, password);
+        httpObserverOnLoading(userObservable,logginObserver);
     }
 
+    /**
+     * 验证码登录
+     * @param phone
+     * @param code
+     */
+    public void loginByCode(String phone,String code){
+        httpObserverOnLoading(loginApi.loginByCode(phone,code),logginObserver);
+    }
+
+    /**
+     * 重置密码
+     * @param phone
+     * @param sms
+     * @param pass
+     */
+    public void resetPwd(String phone,String sms,String pass){
+        httpObserverOnLoading(loginApi.resetLoginPwd(phone, sms, pass),logginObserver);
+    }
+
+    /**
+     * 注册
+     * @param phone
+     * @param sms
+     * @param pass
+     */
+    public void register(String phone,String sms,String pass){
+        httpObserverOnLoading(loginApi.register(phone, sms, pass), new HttpObserver<Results.StringApiResult>(){
+            @Override
+            protected void onSuccess(Results.StringApiResult data) {
+                registerResult.setValue(data);
+            }
+        });
+    }
+
+    /**
+     * 注册密码
+     * @param phone
+     */
+    public void getRegisterSMS(String phone){
+        getVerifyCode("getRegisterSMS",phone);
+    }
+
+    /**
+     * 忘记密码
+     * @param phone
+     */
+    public void getForgetSMS(String phone){
+        getVerifyCode("getForgetSMS",phone);
+    }
+
+    /**
+     * 登录验证码
+     * @param phone
+     */
+    public void getLoginSMS(String phone){
+        getVerifyCode("getLoginSMS",phone);
+    }
 
 }

--
Gitblit v1.9.1