mirror of
https://github.com/oliexdev/openScale.git
synced 2025-08-20 07:21:40 +02:00
Use radio button to indicate selected user in preference
And group all users in a preference category.x
This commit is contained in:
@@ -298,18 +298,22 @@ public class UserSettingsActivity extends BaseAppCompatActivity {
|
|||||||
int userId = getIntent().getExtras().getInt(EXTRA_ID);
|
int userId = getIntent().getExtras().getInt(EXTRA_ID);
|
||||||
|
|
||||||
OpenScale openScale = OpenScale.getInstance(getApplicationContext());
|
OpenScale openScale = OpenScale.getInstance(getApplicationContext());
|
||||||
|
boolean isSelected = openScale.getSelectedScaleUserId() == userId;
|
||||||
|
|
||||||
openScale.clearScaleData(userId);
|
openScale.clearScaleData(userId);
|
||||||
openScale.deleteScaleUser(userId);
|
openScale.deleteScaleUser(userId);
|
||||||
|
|
||||||
List<ScaleUser> scaleUser = openScale.getScaleUserList();
|
if (isSelected) {
|
||||||
|
List<ScaleUser> scaleUser = openScale.getScaleUserList();
|
||||||
|
|
||||||
int lastUserId = -1;
|
int lastUserId = -1;
|
||||||
|
if (!scaleUser.isEmpty()) {
|
||||||
|
lastUserId = scaleUser.get(0).getId();
|
||||||
|
}
|
||||||
|
|
||||||
if (!scaleUser.isEmpty()) {
|
openScale.selectScaleUser(lastUserId);
|
||||||
lastUserId = scaleUser.get(0).getId();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
openScale.selectScaleUser(lastUserId);
|
|
||||||
openScale.updateScaleData();
|
openScale.updateScaleData();
|
||||||
|
|
||||||
Intent returnIntent = new Intent();
|
Intent returnIntent = new Intent();
|
||||||
|
@@ -1,4 +1,5 @@
|
|||||||
/* Copyright (C) 2014 olie.xdev <olie.xdev@googlemail.com>
|
/* Copyright (C) 2014 olie.xdev <olie.xdev@googlemail.com>
|
||||||
|
* 2018 Erik Johansson <erik@ejohansson.se>
|
||||||
*
|
*
|
||||||
* This program is free software: you can redistribute it and/or modify
|
* This program is free software: you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License as published by
|
* it under the terms of the GNU General Public License as published by
|
||||||
@@ -15,103 +16,120 @@
|
|||||||
*/
|
*/
|
||||||
package com.health.openscale.gui.preferences;
|
package com.health.openscale.gui.preferences;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.preference.Preference;
|
import android.preference.Preference;
|
||||||
|
import android.preference.PreferenceCategory;
|
||||||
import android.preference.PreferenceFragment;
|
import android.preference.PreferenceFragment;
|
||||||
|
import android.util.TypedValue;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.RadioButton;
|
||||||
|
|
||||||
import com.health.openscale.R;
|
import com.health.openscale.R;
|
||||||
import com.health.openscale.core.OpenScale;
|
import com.health.openscale.core.OpenScale;
|
||||||
import com.health.openscale.core.datatypes.ScaleUser;
|
import com.health.openscale.core.datatypes.ScaleUser;
|
||||||
import com.health.openscale.gui.activities.UserSettingsActivity;
|
import com.health.openscale.gui.activities.UserSettingsActivity;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import static android.app.Activity.RESULT_OK;
|
import static android.app.Activity.RESULT_OK;
|
||||||
|
|
||||||
public class UsersPreferences extends PreferenceFragment {
|
public class UsersPreferences extends PreferenceFragment {
|
||||||
|
private static final String PREFERENCE_KEY_ADD_USER = "addUser";
|
||||||
|
private static final String PREFERENCE_KEY_USERS = "users";
|
||||||
|
|
||||||
|
PreferenceCategory users;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCreate(Bundle savedInstanceState) {
|
public void onCreate(Bundle savedInstanceState) {
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
|
|
||||||
addPreferencesFromResource(R.xml.users_preferences);
|
addPreferencesFromResource(R.xml.users_preferences);
|
||||||
|
|
||||||
|
Preference addUser = findPreference(PREFERENCE_KEY_ADD_USER);
|
||||||
|
addUser.setOnPreferenceClickListener(new Preference.OnPreferenceClickListener() {
|
||||||
|
@Override
|
||||||
|
public boolean onPreferenceClick(Preference preference) {
|
||||||
|
Intent intent = new Intent(preference.getContext(), UserSettingsActivity.class);
|
||||||
|
intent.putExtra(UserSettingsActivity.EXTRA_MODE, UserSettingsActivity.ADD_USER_REQUEST);
|
||||||
|
startActivityForResult(intent, UserSettingsActivity.ADD_USER_REQUEST);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
users = (PreferenceCategory) findPreference(PREFERENCE_KEY_USERS);
|
||||||
updateUserPreferences();
|
updateUserPreferences();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateUserPreferences() {
|
private void updateUserPreferences() {
|
||||||
OpenScale openScale = OpenScale.getInstance(getActivity().getApplicationContext());
|
users.removeAll();
|
||||||
|
for (ScaleUser scaleUser : OpenScale.getInstance(getActivity()).getScaleUserList()) {
|
||||||
int selectedUserId = openScale.getSelectedScaleUserId();
|
users.addPreference(new UserPreference(getActivity(), users, scaleUser));
|
||||||
|
|
||||||
getPreferenceScreen().removeAll();
|
|
||||||
|
|
||||||
List<ScaleUser> scaleUserList = openScale.getScaleUserList();
|
|
||||||
|
|
||||||
for (ScaleUser scaleUser : scaleUserList)
|
|
||||||
{
|
|
||||||
Preference prefUser = new Preference(getActivity());
|
|
||||||
prefUser.setOnPreferenceClickListener(new onClickListenerUserSelect());
|
|
||||||
|
|
||||||
if (scaleUser.getId() == selectedUserId) {
|
|
||||||
prefUser.setTitle("> " + scaleUser.getUserName());
|
|
||||||
} else
|
|
||||||
{
|
|
||||||
prefUser.setTitle(scaleUser.getUserName());
|
|
||||||
}
|
|
||||||
|
|
||||||
prefUser.setKey(Integer.toString(scaleUser.getId()));
|
|
||||||
|
|
||||||
getPreferenceScreen().addPreference(prefUser);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Preference prefAddUser = new Preference(getActivity());
|
|
||||||
|
|
||||||
prefAddUser.setOnPreferenceClickListener(new onClickListenerAddUser());
|
|
||||||
prefAddUser.setTitle("+ " + getResources().getString(R.string.label_add_user));
|
|
||||||
|
|
||||||
getPreferenceScreen().addPreference(prefAddUser);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onActivityResult(int requestCode, int resultCode, Intent data)
|
public void onActivityResult(int requestCode, int resultCode, Intent data) {
|
||||||
{
|
if (resultCode != RESULT_OK) {
|
||||||
if (requestCode == UserSettingsActivity.ADD_USER_REQUEST) {
|
return;
|
||||||
if (resultCode == RESULT_OK) {
|
|
||||||
updateUserPreferences();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
if (requestCode == UserSettingsActivity.ADD_USER_REQUEST
|
||||||
|
|| requestCode == UserSettingsActivity.EDIT_USER_REQUEST) {
|
||||||
if (requestCode == UserSettingsActivity.EDIT_USER_REQUEST) {
|
updateUserPreferences();
|
||||||
if (resultCode == RESULT_OK) {
|
|
||||||
updateUserPreferences();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private class onClickListenerUserSelect implements Preference.OnPreferenceClickListener {
|
class UserPreference extends Preference {
|
||||||
|
PreferenceCategory preferenceCategory;
|
||||||
|
ScaleUser scaleUser;
|
||||||
|
RadioButton radioButton;
|
||||||
|
|
||||||
|
UserPreference(Context context, PreferenceCategory category, ScaleUser scaleUser) {
|
||||||
|
super(context);
|
||||||
|
|
||||||
|
preferenceCategory = category;
|
||||||
|
this.scaleUser = scaleUser;
|
||||||
|
|
||||||
|
setTitle(scaleUser.getUserName());
|
||||||
|
setWidgetLayoutResource(R.layout.user_preference_widget_layout);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onPreferenceClick(Preference preference) {
|
protected void onBindView(View view) {
|
||||||
Intent intent = new Intent(preference.getContext(), UserSettingsActivity.class);
|
super.onBindView(view);
|
||||||
intent.putExtra(UserSettingsActivity.EXTRA_MODE, UserSettingsActivity.EDIT_USER_REQUEST);
|
|
||||||
intent.putExtra(UserSettingsActivity.EXTRA_ID, Integer.parseInt(preference.getKey()));
|
|
||||||
startActivityForResult(intent, UserSettingsActivity.EDIT_USER_REQUEST);
|
|
||||||
|
|
||||||
return false;
|
view.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
Intent intent = new Intent(getActivity(), UserSettingsActivity.class);
|
||||||
|
intent.putExtra(UserSettingsActivity.EXTRA_MODE, UserSettingsActivity.EDIT_USER_REQUEST);
|
||||||
|
intent.putExtra(UserSettingsActivity.EXTRA_ID, scaleUser.getId());
|
||||||
|
startActivityForResult(intent, UserSettingsActivity.EDIT_USER_REQUEST);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
TypedValue outValue = new TypedValue();
|
||||||
|
getActivity().getTheme().resolveAttribute(R.attr.selectableItemBackground, outValue, true);
|
||||||
|
view.setBackgroundResource(outValue.resourceId);
|
||||||
|
|
||||||
|
radioButton = view.findViewById(R.id.user_radio_button);
|
||||||
|
radioButton.setChecked(scaleUser.getId() == OpenScale.getInstance(getContext()).getSelectedScaleUserId());
|
||||||
|
|
||||||
|
radioButton.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
for (int i = 0; i < preferenceCategory.getPreferenceCount(); ++i) {
|
||||||
|
UserPreference pref = (UserPreference) preferenceCategory.getPreference(i);
|
||||||
|
pref.setChecked(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
radioButton.setChecked(true);
|
||||||
|
OpenScale.getInstance(getContext()).selectScaleUser(scaleUser.getId());
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setChecked(boolean checked) {
|
||||||
|
radioButton.setChecked(checked);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private class onClickListenerAddUser implements Preference.OnPreferenceClickListener {
|
|
||||||
@Override
|
|
||||||
public boolean onPreferenceClick(Preference preference) {
|
|
||||||
Intent intent = new Intent(preference.getContext(), UserSettingsActivity.class);
|
|
||||||
intent.putExtra(UserSettingsActivity.EXTRA_MODE, UserSettingsActivity.ADD_USER_REQUEST);
|
|
||||||
startActivityForResult(intent, UserSettingsActivity.ADD_USER_REQUEST);
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -0,0 +1,18 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:orientation="horizontal">
|
||||||
|
|
||||||
|
<View
|
||||||
|
android:layout_width="1dp"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:background="?android:attr/listDivider" />
|
||||||
|
|
||||||
|
<RadioButton
|
||||||
|
android:id="@+id/user_radio_button"
|
||||||
|
android:layout_width="0dp"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginLeft="16dp"
|
||||||
|
android:layout_weight="1" />
|
||||||
|
</LinearLayout>
|
@@ -1,4 +1,14 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android">
|
<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
|
|
||||||
</PreferenceScreen>
|
<Preference
|
||||||
|
android:key="addUser"
|
||||||
|
android:title="@string/label_add_user">
|
||||||
|
</Preference>
|
||||||
|
|
||||||
|
<PreferenceCategory
|
||||||
|
android:key="users"
|
||||||
|
android:title="@string/title_users">
|
||||||
|
|
||||||
|
</PreferenceCategory>
|
||||||
|
</PreferenceScreen>
|
||||||
|
Reference in New Issue
Block a user