5e6121c538ac7ef99ab6e6fc2beb7e0fe2d6ba05.svn-base 7.4 KB

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