dce2cd3780f006d0f1f2888521a899906059e557.svn-base 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. package eVVM.apk.ui.login;
  2. import android.content.Intent;
  3. import android.text.TextUtils;
  4. import android.util.Log;
  5. import android.view.View;
  6. import android.widget.Button;
  7. import android.widget.TextView;
  8. import com.hjq.permissions.OnPermission;
  9. import com.hjq.permissions.Permission;
  10. import com.hjq.permissions.XXPermissions;
  11. import com.hjq.widget.ClearEditText;
  12. import java.util.List;
  13. import butterknife.BindView;
  14. import butterknife.OnClick;
  15. import eVVM.apk.R;
  16. import eVVM.apk.helper.InputTextHelper;
  17. import eVVM.apk.helper.MD5;
  18. import eVVM.apk.helper.SPUtils;
  19. import eVVM.apk.mvp.MvpActivity;
  20. import eVVM.apk.ui.My.ExamineActivity;
  21. import eVVM.apk.ui.bean.LoginBean;
  22. import eVVM.apk.ui.home.FactorAdminActivity;
  23. import eVVM.apk.ui.home.FactoryOperatorActivity;
  24. import eVVM.apk.ui.home.HomeActivity;
  25. import eVVM.apk.ui.launcher.LikeActivity;
  26. import eVVM.apk.ui.login.login.LoginContract;
  27. import eVVM.apk.ui.login.login.LoginPresenter;
  28. public class LoginActivity extends MvpActivity<LoginPresenter> implements LoginContract.View {
  29. @BindView(R.id.login_et_phone)
  30. ClearEditText loginEtPhone;
  31. @BindView(R.id.login_et_pwd)
  32. ClearEditText loginEtPwd; //密码输入框
  33. @BindView(R.id.login_tv_forgetpwd)
  34. TextView loginTvForgetpwd; //忘记密码
  35. @BindView(R.id.login_btn_login)
  36. Button loginBtnLogin; //登录
  37. @BindView(R.id.login_tv_goregist)
  38. TextView loginTvGoregist; //去注册
  39. private String getMD5Pwd;
  40. private String userPhone;
  41. @Override
  42. protected int getLayoutId() {
  43. return R.layout.activity_login;
  44. }
  45. @Override
  46. protected int getTitleId() {
  47. return 0;
  48. }
  49. @Override
  50. protected void initView() {
  51. new InputTextHelper.Builder(this)
  52. .setMain(loginBtnLogin)
  53. .addView(loginEtPhone)
  54. .addView(loginEtPwd)
  55. .build();
  56. }
  57. @Override
  58. protected void initData() {
  59. getPermissions();
  60. String user_phone = (String) SPUtils.get("USER_PHONE", "");
  61. String user_pwd = (String) SPUtils.get("USER_PWD", "");
  62. if (TextUtils.isEmpty(user_phone) && TextUtils.isEmpty(user_pwd)) {
  63. //用户没有登录过
  64. } else {
  65. // if (!checkGpsAndNfc()) {
  66. // return;
  67. // }
  68. showLoading();
  69. //登陆过 进行自动登录
  70. userPhone = user_phone;
  71. getMD5Pwd = user_pwd;
  72. getPresenter().login(user_phone, user_pwd);
  73. }
  74. }
  75. private void getPermissions() {
  76. // 联系人
  77. String[] CONTACTS = new String[]{
  78. Permission.CAMERA,
  79. Permission.RECEIVE_SMS,
  80. Permission.READ_SMS,
  81. Permission.READ_EXTERNAL_STORAGE,
  82. Permission.WRITE_EXTERNAL_STORAGE,
  83. Permission.ACCESS_FINE_LOCATION,
  84. Permission.ACCESS_COARSE_LOCATION,
  85. Permission.REQUEST_INSTALL_PACKAGES};
  86. XXPermissions.with(LoginActivity.this)
  87. //.constantRequest() //可设置被拒绝后继续申请,直到用户授权或者永久拒绝
  88. //.permission(Permission.SYSTEM_ALERT_WINDOW, Permission.REQUEST_INSTALL_PACKAGES) //支持请求6.0悬浮窗权限8.0请求安装权限
  89. .permission(CONTACTS) //不指定权限则自动获取清单中的危险权限
  90. .request(new OnPermission() {
  91. @Override
  92. public void hasPermission(List<String> granted, boolean isAll) {
  93. /*if (isAll) {
  94. toast("获取权限成功");
  95. }else {
  96. toast("获取权限成功,部分权限未正常授予");
  97. }*/
  98. }
  99. @Override
  100. public void noPermission(List<String> denied, boolean quick) {
  101. /*if(quick) {
  102. toast("被永久拒绝授权,请手动授予权限");
  103. //如果是被永久拒绝就跳转到应用权限系统设置页面
  104. XXPermissions.gotoPermissionSettings(LoginActivity.this);
  105. }else {
  106. //toast("获取权限失败,部分功能可能无法使用");
  107. }*/
  108. }
  109. });
  110. }
  111. @OnClick({R.id.login_tv_forgetpwd, R.id.login_btn_login, R.id.login_tv_goregist})
  112. public void onViewClicked(View view) {
  113. // if (!checkGpsAndNfc()) {
  114. // return;
  115. // }
  116. switch (view.getId()) {
  117. case R.id.login_tv_forgetpwd:
  118. startActivity(PasswordForgetActivity.class);
  119. break;
  120. case R.id.login_btn_login:
  121. if (loginEtPhone.getText().toString().length() != 11) {
  122. toast(getString(R.string.common_phone_input_error));
  123. } else {
  124. //登录 密码进行md5加密
  125. getMD5Pwd = MD5.GetMD5Code(loginEtPwd.getText().toString().trim());
  126. userPhone = loginEtPhone.getText().toString().trim();
  127. getPresenter().login(userPhone, getMD5Pwd);
  128. showLoading();
  129. }
  130. break;
  131. case R.id.login_tv_goregist:
  132. startActivity(RegisterActivity.class);
  133. break;
  134. }
  135. }
  136. @Override
  137. protected LoginPresenter createPresenter() {
  138. return new LoginPresenter();
  139. }
  140. @Override
  141. public void loginError(String msg) {
  142. showComplete();
  143. toast(msg);
  144. }
  145. @Override
  146. public void loginSuccess(LoginBean data) {
  147. // 处理登录
  148. showComplete();
  149. LoginBean.DataBean userData = data.getData();
  150. SPUtils.put("USER_ID", userData.getId() + "");
  151. SPUtils.put("USER_TOKEN", userData.getToken() + "");
  152. if (userData.getStatus() == 1) {//状态(0禁用 1正常 2删除 3未审核 4审核未通过 5未完成注册 6未同意协议)
  153. Log.e("userData", "" + userData.getPassword());
  154. //保存用户数据
  155. SPUtils.put("USER_PHONE", userPhone + "");
  156. SPUtils.put("USER_PWD", getMD5Pwd + "");
  157. SPUtils.put("USER_ROLEID", userData.getRoleId() + "");
  158. SPUtils.put("USER_FACTORY_ID", userData.getFactoryId() + "");
  159. SPUtils.put("USER_NAME", userData.getUserName() + "");
  160. SPUtils.put("PHONE_MODEL", userData.getPhoneModel());
  161. switch (userData.getRoleId()) { //根据不同角色 跳转进入不同的页面
  162. case 2: //医生
  163. startActivityFinish(HomeActivity.class);
  164. break;
  165. case 3: //医药企业管理员
  166. startActivityFinish(FactorAdminActivity.class);
  167. break;
  168. case 4: //医药企业操作员
  169. startActivityFinish(FactoryOperatorActivity.class);
  170. break;
  171. }
  172. } else if (userData.getStatus() == 0) {
  173. toast("当前账号已被禁用");
  174. } else if (userData.getStatus() == 2) {
  175. toast("当前账号已被删除");
  176. } else if (userData.getStatus() == 3) {
  177. toast("您的账号正在审核中,请耐心等待");
  178. } else if (userData.getStatus() == 4) {
  179. toast("审核未通过");
  180. } else if (userData.getStatus() == 5) {
  181. // toast("未完成注册");
  182. Intent in = new Intent(this,AuthenticationActivity.class);
  183. in.putExtra("registerUserId",data.getData().getId()+"");
  184. startActivity(in);
  185. } else if (userData.getStatus() == 6) {
  186. startActivity(ExamineActivity.class);
  187. }
  188. }
  189. }