X-Git-Url: https://git.ktnx.net/?p=mobile-ledger.git;a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Fui%2Fprofiles%2FProfileDetailFragment.java;h=59f27a7906798d7bae098eb68ba9cf0f5ab1bb9f;hp=004763a7ac87a45343018d67b095872aa612efc6;hb=8d69552b756ba44e254251edf08206f8866c639b;hpb=e322f11defd133f4e85cd80ef5f2d9131d6877e0
diff --git a/app/src/main/java/net/ktnx/mobileledger/ui/profiles/ProfileDetailFragment.java b/app/src/main/java/net/ktnx/mobileledger/ui/profiles/ProfileDetailFragment.java
index 004763a7..59f27a79 100644
--- a/app/src/main/java/net/ktnx/mobileledger/ui/profiles/ProfileDetailFragment.java
+++ b/app/src/main/java/net/ktnx/mobileledger/ui/profiles/ProfileDetailFragment.java
@@ -1,30 +1,26 @@
/*
* Copyright © 2019 Damyan Ivanov.
- * This file is part of Mobile-Ledger.
- * Mobile-Ledger is free software: you can distribute it and/or modify it
+ * This file is part of MoLe.
+ * MoLe is free software: you can distribute it and/or modify it
* under the term of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your opinion), any later version.
*
- * Mobile-Ledger is distributed in the hope that it will be useful,
+ * MoLe is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License terms for details.
*
* You should have received a copy of the GNU General Public License
- * along with Mobile-Ledger. If not, see .
+ * along with MoLe. If not, see .
*/
package net.ktnx.mobileledger.ui.profiles;
import android.app.Activity;
+import android.content.Context;
+import android.graphics.drawable.ColorDrawable;
import android.os.Bundle;
-import android.support.annotation.NonNull;
-import android.support.annotation.Nullable;
-import android.support.design.widget.CollapsingToolbarLayout;
-import android.support.design.widget.FloatingActionButton;
-import android.support.design.widget.TextInputLayout;
-import android.support.v4.app.Fragment;
import android.text.Editable;
import android.text.TextWatcher;
import android.util.Log;
@@ -34,19 +30,33 @@ import android.view.MenuInflater;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
+import android.widget.AdapterView;
+import android.widget.ArrayAdapter;
import android.widget.LinearLayout;
+import android.widget.Spinner;
import android.widget.Switch;
import android.widget.TextView;
+import com.google.android.material.appbar.CollapsingToolbarLayout;
+import com.google.android.material.floatingactionbutton.FloatingActionButton;
+import com.google.android.material.textfield.TextInputLayout;
+
import net.ktnx.mobileledger.R;
import net.ktnx.mobileledger.model.Data;
import net.ktnx.mobileledger.model.MobileLedgerProfile;
-import net.ktnx.mobileledger.ui.activity.ProfileListActivity;
+import net.ktnx.mobileledger.ui.activity.ProfileDetailActivity;
+import net.ktnx.mobileledger.utils.Colors;
+
+import java.util.List;
+
+import androidx.annotation.ColorInt;
+import androidx.annotation.NonNull;
+import androidx.annotation.Nullable;
+import androidx.fragment.app.Fragment;
/**
* A fragment representing a single Profile detail screen.
- * This fragment is either contained in a {@link ProfileListActivity}
- * in two-pane mode (on tablets) or a {@link ProfileDetailActivity}
+ * a {@link ProfileDetailActivity}
* on handsets.
*/
public class ProfileDetailFragment extends Fragment {
@@ -61,6 +71,7 @@ public class ProfileDetailFragment extends Fragment {
*/
private MobileLedgerProfile mProfile;
private TextView url;
+ private Switch postingPermitted;
private TextInputLayout urlLayout;
private LinearLayout authParams;
private Switch useAuthentication;
@@ -71,6 +82,7 @@ public class ProfileDetailFragment extends Fragment {
private TextView profileName;
private TextInputLayout profileNameLayout;
private FloatingActionButton fab;
+ private Spinner colorSpinner;
/**
* Mandatory empty constructor for the fragment manager to instantiate the
@@ -126,9 +138,12 @@ public class ProfileDetailFragment extends Fragment {
if (mProfile != null) {
mProfile.setName(profileName.getText());
mProfile.setUrl(url.getText());
+ mProfile.setPostingPermitted(postingPermitted.isChecked());
mProfile.setAuthEnabled(useAuthentication.isChecked());
mProfile.setAuthUserName(userName.getText());
mProfile.setAuthPassword(password.getText());
+ mProfile.setThemeId(colorSpinner.getSelectedItem());
+// Log.d("profiles", String.format("Selected item is %d", mProfile.getThemeId()));
mProfile.storeInDB();
Log.d("profiles", "profile stored in DB");
Data.profiles.triggerItemChangedNotification(mProfile);
@@ -140,11 +155,17 @@ public class ProfileDetailFragment extends Fragment {
}
}
else {
- mProfile = new MobileLedgerProfile(profileName.getText(), url.getText(),
- useAuthentication.isChecked(), userName.getText(), password.getText());
+ mProfile =
+ new MobileLedgerProfile(profileName.getText(), postingPermitted.isChecked(),
+ url.getText(), useAuthentication.isChecked(), userName.getText(),
+ password.getText(),
+ Integer.valueOf((String) colorSpinner.getSelectedItem()));
mProfile.storeInDB();
Data.profiles.add(mProfile);
MobileLedgerProfile.storeProfilesOrder();
+
+ // first profile ever?
+ if (Data.profiles.getList().size() == 1) Data.profile.set(mProfile);
}
Activity activity = getActivity();
@@ -162,12 +183,48 @@ public class ProfileDetailFragment extends Fragment {
profileNameLayout = rootView.findViewById(R.id.profile_name_layout);
url = rootView.findViewById(R.id.url);
urlLayout = rootView.findViewById(R.id.url_layout);
+ postingPermitted = rootView.findViewById(R.id.profile_permit_posting);
authParams = rootView.findViewById(R.id.auth_params);
useAuthentication = rootView.findViewById(R.id.enable_http_auth);
userName = rootView.findViewById(R.id.auth_user_name);
userNameLayout = rootView.findViewById(R.id.auth_user_name_layout);
password = rootView.findViewById(R.id.password);
passwordLayout = rootView.findViewById(R.id.password_layout);
+ colorSpinner = rootView.findViewById(R.id.colorSpinner);
+
+ ColorListAdapter adapter =
+ new ColorListAdapter(rootView.getContext(), R.layout.color_selector_item);
+ adapter.add(-1);
+ for (int i = 0; i < 360; i += 15) adapter.add(i);
+ Log.d("profiles", String.format("color count: %s", adapter.getCount()));
+// adapter.setDropDownViewResource(R.layout.color_selector_item);
+ colorSpinner.setAdapter(adapter);
+ colorSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
+ @Override
+ public void onNothingSelected(AdapterView> parent) {
+
+ }
+ @Override
+ public void onItemSelected(AdapterView> parent, View view, int position, long id) {
+ final int primaryColor;
+ final int degrees = (Integer) parent.getAdapter().getItem(position);
+ if (degrees < 0) {
+ primaryColor = Colors.getPrimaryColorForHue(Colors.DEFAULT_HUE_DEG);
+ }
+ else primaryColor = Colors.getPrimaryColorForHue(degrees);
+
+ if (colorSpinner != null) {
+ colorSpinner.setBackgroundColor(primaryColor);
+// for (int i = 0; i < colorSpinner.getChildCount(); i++) {
+// View v = colorSpinner.getChildAt(i);
+//
+// if (v instanceof TextView) {
+// ((TextView) v).setTextColor(Color.TRANSPARENT);
+// }
+// }
+ }
+ }
+ });
useAuthentication.setOnCheckedChangeListener((buttonView, isChecked) -> {
Log.d("profiles", isChecked ? "auth enabled " : "auth disabled");
@@ -182,19 +239,37 @@ public class ProfileDetailFragment extends Fragment {
if (mProfile != null) {
profileName.setText(mProfile.getName());
+ postingPermitted.setChecked(mProfile.isPostingPermitted());
url.setText(mProfile.getUrl());
useAuthentication.setChecked(mProfile.isAuthEnabled());
authParams.setVisibility(mProfile.isAuthEnabled() ? View.VISIBLE : View.GONE);
userName.setText(mProfile.isAuthEnabled() ? mProfile.getAuthUserName() : "");
password.setText(mProfile.isAuthEnabled() ? mProfile.getAuthPassword() : "");
+
+ colorSpinner.setSelection(0);
+ int i = 0;
+ int sought = mProfile.getThemeId();
+// Log.d("profiles", String.format("Looking for %d",sought));
+ while (i < adapter.getCount()) {
+ int item = Integer.valueOf(String.valueOf(adapter.getItem(i)));
+// Log.d("profiles", String.format("Item %d is %d", i, item));
+ if (item == sought) {
+ colorSpinner.setSelection(i);
+ break;
+ }
+
+ i++;
+ }
}
else {
profileName.setText("");
url.setText("");
+ postingPermitted.setChecked(true);
useAuthentication.setChecked(false);
authParams.setVisibility(View.GONE);
userName.setText("");
password.setText("");
+ colorSpinner.setSelection(0);
}
return rootView;
@@ -248,4 +323,43 @@ public class ProfileDetailFragment extends Fragment {
return valid;
}
+ private class ColorListAdapter extends ArrayAdapter {
+ public ColorListAdapter(@NonNull Context context, int resource) {
+ super(context, resource);
+ }
+ public ColorListAdapter(@NonNull Context context, int resource, int textViewResourceId) {
+ super(context, resource, textViewResourceId);
+ }
+ public ColorListAdapter(@NonNull Context context, int resource,
+ @NonNull Integer[] objects) {
+ super(context, resource, objects);
+ }
+ public ColorListAdapter(@NonNull Context context, int resource, int textViewResourceId,
+ @NonNull Integer[] objects) {
+ super(context, resource, textViewResourceId, objects);
+ }
+ public ColorListAdapter(@NonNull Context context, int resource,
+ @NonNull List objects) {
+ super(context, resource, objects);
+ }
+ public ColorListAdapter(@NonNull Context context, int resource, int textViewResourceId,
+ @NonNull List objects) {
+ super(context, resource, textViewResourceId, objects);
+ }
+ @Override
+ public @NonNull
+ View getView(int position, @Nullable View convertView, @NonNull ViewGroup parent) {
+ Integer hueDeg = getItem(position);
+ int hue = ((hueDeg == null) || (hueDeg == -1)) ? Colors.DEFAULT_HUE_DEG : hueDeg;
+ @ColorInt int primaryColor = Colors.getPrimaryColorForHue(hue);
+
+ View view = convertView;
+ if (convertView == null) {
+ view = getLayoutInflater().inflate(R.layout.color_selector_item, null);
+ }
+
+ view.setBackground(new ColorDrawable(primaryColor));
+ return view;
+ }
+ }
}