Commit b75379ba authored by Varun Patil's avatar Varun Patil

Show and init logout button and user in settings only if logged in

parent 12485107
...@@ -90,10 +90,10 @@ public class SettingsFragment extends Fragment { ...@@ -90,10 +90,10 @@ public class SettingsFragment extends Fragment {
// Check if we exist // Check if we exist
if (getActivity() == null || getView() == null) return; if (getActivity() == null || getView() == null) return;
Button updateProfileButton = getActivity().findViewById(R.id.settings_update_profile); Button updateProfileButton = getView().findViewById(R.id.settings_update_profile);
Button feedbackButton = getActivity().findViewById(R.id.settings_feedback); Button feedbackButton = getView().findViewById(R.id.settings_feedback);
Button aboutButton = getActivity().findViewById(R.id.settings_about); Button aboutButton = getView().findViewById(R.id.settings_about);
Button logoutButton = getActivity().findViewById(R.id.settings_logout); Button logoutButton = getView().findViewById(R.id.settings_logout);
updateProfileButton.setOnClickListener(new View.OnClickListener() { updateProfileButton.setOnClickListener(new View.OnClickListener() {
@Override @Override
...@@ -121,30 +121,36 @@ public class SettingsFragment extends Fragment { ...@@ -121,30 +121,36 @@ public class SettingsFragment extends Fragment {
} }
}); });
logoutButton.setOnClickListener(new View.OnClickListener() { // Logged in user vs Guest
@Override final SessionManager sessionManager = new SessionManager(getContext());
public void onClick(View v) { if (sessionManager.isLoggedIn()) {
RetrofitInterface retrofitInterface = ServiceGenerator.createService(RetrofitInterface.class); logoutButton.setOnClickListener(new View.OnClickListener() {
retrofitInterface.logout("sessionid=" + getArguments().getString(Constants.SESSION_ID)).enqueue(new Callback<Void>() { @Override
@Override public void onClick(View v) {
public void onResponse(Call<Void> call, Response<Void> response) { RetrofitInterface retrofitInterface = ServiceGenerator.createService(RetrofitInterface.class);
if (response.isSuccessful()) { retrofitInterface.logout("sessionid=" + getArguments().getString(Constants.SESSION_ID)).enqueue(new Callback<Void>() {
SessionManager sessionManager = new SessionManager(getContext()); @Override
sessionManager.logout(); public void onResponse(Call<Void> call, Response<Void> response) {
Intent intent = new Intent(getContext(), LoginActivity.class); if (response.isSuccessful()) {
startActivity(intent); sessionManager.logout();
getActivity().finish(); Intent intent = new Intent(getContext(), LoginActivity.class);
startActivity(intent);
getActivity().finish();
}
//Server Error
} }
//Server Error
} @Override
public void onFailure(Call<Void> call, Throwable t) {
@Override //Network Error
public void onFailure(Call<Void> call, Throwable t) { }
//Network Error });
} }
}); });
} } else {
}); logoutButton.setVisibility(View.GONE);
getView().findViewById(R.id.role_card_layout).setVisibility(View.GONE);
}
} }
private void openWebURL(String URL) { private void openWebURL(String URL) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment