From 92a5055e0236ae42ae7c7bbd9bd0fc9572ccf4f1 Mon Sep 17 00:00:00 2001 From: Nicholas Hallahan Date: Wed, 6 Jan 2016 06:16:21 -0800 Subject: [PATCH 1/9] basic fragment #103 --- app/build.gradle | 5 +- .../SelectMultipleTagValueFragment.java | 92 +++++++++++++++++++ .../tagswipe/SelectOneTagValueFragment.java | 9 +- .../openmapkit/tagswipe/TagSwipeActivity.java | 3 +- .../fragment_select_multiple_tag_value.xml | 13 +++ app/src/main/res/values/strings.xml | 6 +- 6 files changed, 115 insertions(+), 13 deletions(-) create mode 100644 app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java create mode 100644 app/src/main/res/layout/fragment_select_multiple_tag_value.xml diff --git a/app/build.gradle b/app/build.gradle index ab1a357..8dcd39c 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -25,8 +25,9 @@ repositories { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'com.android.support:appcompat-v7:22.2.1' - compile 'com.android.support:design:22.2.1' compile group: 'com.google.guava', name: 'guava', version: '18.0' compile project(':MapboxAndroidSDK') + compile 'com.android.support:appcompat-v7:22.2.1' + compile 'com.android.support:design:22.2.1' + compile 'com.android.support:support-v4:21.0.3' } diff --git a/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java b/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java new file mode 100644 index 0000000..56673e9 --- /dev/null +++ b/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java @@ -0,0 +1,92 @@ +package org.redcross.openmapkit.tagswipe; + +import android.content.Context; +import android.net.Uri; +import android.os.Bundle; +import android.support.v4.app.Fragment; +import android.view.LayoutInflater; +import android.view.View; +import android.view.ViewGroup; + +import org.redcross.openmapkit.R; + +/** + * A simple {@link Fragment} subclass. + * Activities that contain this fragment must implement the + * {@link SelectMultipleTagValueFragment.OnFragmentInteractionListener} interface + * to handle interaction events. + * Use the {@link SelectMultipleTagValueFragment#newInstance} factory method to + * create an instance of this fragment. + */ +public class SelectMultipleTagValueFragment extends Fragment { + + private static final String IDX = "IDX"; + + private TagEdit tagEdit; + private View rootView; + + private OnFragmentInteractionListener mListener; + + public SelectMultipleTagValueFragment() { + // Required empty public constructor + } + + + public static SelectMultipleTagValueFragment newInstance(int idx) { + SelectMultipleTagValueFragment fragment = new SelectMultipleTagValueFragment(); + Bundle args = new Bundle(); + args.putInt(IDX, idx); + fragment.setArguments(args); + return fragment; + } + + private void setupWidgets() { + + } + + @Override + public void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + if (getArguments() != null) { + int idx = getArguments().getInt(IDX); + tagEdit = TagEdit.getTag(idx); + } + } + + @Override + public View onCreateView(LayoutInflater inflater, ViewGroup container, + Bundle savedInstanceState) { + // Inflate the layout for this fragment + rootView = inflater.inflate(R.layout.fragment_select_multiple_tag_value, container, false); + setupWidgets(); + return rootView; + } + + // TODO: Rename method, update argument and hook method into UI event + public void onButtonPressed(Uri uri) { + if (mListener != null) { + mListener.onFragmentInteraction(uri); + } + } + + @Override + public void onDetach() { + super.onDetach(); + mListener = null; + } + + /** + * This interface must be implemented by activities that contain this + * fragment to allow an interaction in this fragment to be communicated + * to the activity and potentially other fragments contained in that + * activity. + *

+ * See the Android Training lesson Communicating with Other Fragments for more information. + */ + public interface OnFragmentInteractionListener { + // TODO: Update argument type and name + void onFragmentInteraction(Uri uri); + } +} diff --git a/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectOneTagValueFragment.java b/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectOneTagValueFragment.java index 8e88a5e..03cc2e3 100644 --- a/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectOneTagValueFragment.java +++ b/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectOneTagValueFragment.java @@ -1,6 +1,5 @@ package org.redcross.openmapkit.tagswipe; -import android.app.ActionBar; import android.app.Activity; import android.content.Context; import android.net.Uri; @@ -11,7 +10,6 @@ import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; -import android.view.ViewParent; import android.view.inputmethod.InputMethodManager; import android.widget.EditText; import android.widget.LinearLayout; @@ -40,9 +38,6 @@ public class SelectOneTagValueFragment extends Fragment { private TagEdit tagEdit; private View rootView; - private TextView tagKeyLabelTextView; - private TextView tagKeyTextView; - private OnFragmentInteractionListener mListener; @@ -55,8 +50,8 @@ public static SelectOneTagValueFragment newInstance(int idx) { } private void setupWidgets() { - tagKeyLabelTextView = (TextView)rootView.findViewById(R.id.tagKeyLabelTextView); - tagKeyTextView = (TextView)rootView.findViewById(R.id.tagKeyTextView); + TextView tagKeyLabelTextView = (TextView) rootView.findViewById(R.id.tagKeyLabelTextView); + TextView tagKeyTextView = (TextView) rootView.findViewById(R.id.tagKeyTextView); String keyLabel = tagEdit.getTagKeyLabel(); String key = tagEdit.getTagKey(); diff --git a/app/src/main/java/org/redcross/openmapkit/tagswipe/TagSwipeActivity.java b/app/src/main/java/org/redcross/openmapkit/tagswipe/TagSwipeActivity.java index 186e2fa..d73f6d6 100644 --- a/app/src/main/java/org/redcross/openmapkit/tagswipe/TagSwipeActivity.java +++ b/app/src/main/java/org/redcross/openmapkit/tagswipe/TagSwipeActivity.java @@ -178,7 +178,8 @@ public Fragment getItem(int position) { fragment = ReadOnlyTagFragment.newInstance(position); return fragment; } else if (tagEdit.isSelectOne()) { - fragment = SelectOneTagValueFragment.newInstance(position); +// fragment = SelectOneTagValueFragment.newInstance(position); + fragment = SelectMultipleTagValueFragment.newInstance(position); return fragment; } else { fragment = StringTagValueFragment.newInstance(position); diff --git a/app/src/main/res/layout/fragment_select_multiple_tag_value.xml b/app/src/main/res/layout/fragment_select_multiple_tag_value.xml new file mode 100644 index 0000000..b9b261d --- /dev/null +++ b/app/src/main/res/layout/fragment_select_multiple_tag_value.xml @@ -0,0 +1,13 @@ + + + + + + diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index 144f164..83bfea5 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -19,7 +19,7 @@ Save Cancel + - + openmapkit/mbtiles @@ -58,9 +58,9 @@ Tags - + Hello blank fragment - + Confirm Save tag edits to ODK Collect? Add or Confirm From 397215f7ea34e4f1e67a1bac403891d23885688c Mon Sep 17 00:00:00 2001 From: Nicholas Hallahan Date: Wed, 6 Jan 2016 06:30:35 -0800 Subject: [PATCH 2/9] tag key and tag label text views are populated #103 --- .../SelectMultipleTagValueFragment.java | 19 ++++++++++ .../fragment_select_multiple_tag_value.xml | 38 ++++++++++++++++--- 2 files changed, 52 insertions(+), 5 deletions(-) diff --git a/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java b/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java index 56673e9..83922f8 100644 --- a/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java +++ b/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java @@ -7,6 +7,7 @@ import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; +import android.widget.TextView; import org.redcross.openmapkit.R; @@ -41,6 +42,24 @@ public static SelectMultipleTagValueFragment newInstance(int idx) { } private void setupWidgets() { + TextView tagKeyLabelTextView = (TextView) rootView.findViewById(R.id.tagKeyLabelTextView); + TextView tagKeyTextView = (TextView) rootView.findViewById(R.id.tagKeyTextView); + + String keyLabel = tagEdit.getTagKeyLabel(); + String key = tagEdit.getTagKey(); + + if (keyLabel != null) { + tagKeyLabelTextView.setText(keyLabel); + tagKeyTextView.setText(key); + } else { + tagKeyLabelTextView.setText(key); + tagKeyTextView.setText(""); + } + + setupCheckBoxes(); + } + + private void setupCheckBoxes() { } diff --git a/app/src/main/res/layout/fragment_select_multiple_tag_value.xml b/app/src/main/res/layout/fragment_select_multiple_tag_value.xml index b9b261d..b1924bc 100644 --- a/app/src/main/res/layout/fragment_select_multiple_tag_value.xml +++ b/app/src/main/res/layout/fragment_select_multiple_tag_value.xml @@ -4,10 +4,38 @@ android:layout_height="match_parent" tools:context="org.redcross.openmapkit.tagswipe.SelectMultipleTagValueFragment"> - - + + + + + + + + + + + From 0aac969e924fa9cfd7031c648eda0a5a80ef3ff2 Mon Sep 17 00:00:00 2001 From: Nicholas Hallahan Date: Wed, 6 Jan 2016 07:13:18 -0800 Subject: [PATCH 3/9] checkboxes are populated with values #103 --- .../SelectMultipleTagValueFragment.java | 58 ++++++++++++++++++- .../fragment_select_multiple_tag_value.xml | 10 +++- 2 files changed, 66 insertions(+), 2 deletions(-) diff --git a/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java b/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java index 83922f8..a1031ea 100644 --- a/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java +++ b/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java @@ -1,15 +1,21 @@ package org.redcross.openmapkit.tagswipe; -import android.content.Context; +import android.app.Activity; import android.net.Uri; import android.os.Bundle; import android.support.v4.app.Fragment; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; +import android.widget.CheckBox; +import android.widget.LinearLayout; import android.widget.TextView; import org.redcross.openmapkit.R; +import org.redcross.openmapkit.odkcollect.tag.ODKTag; +import org.redcross.openmapkit.odkcollect.tag.ODKTagItem; + +import java.util.Collection; /** * A simple {@link Fragment} subclass. @@ -60,7 +66,57 @@ private void setupWidgets() { } private void setupCheckBoxes() { + final LinearLayout checkboxLinearLayout = (LinearLayout)rootView.findViewById(R.id.checkboxLinearLayout); + final Activity activity = getActivity(); + ODKTag odkTag = tagEdit.getODKTag(); + if (odkTag == null) return; + + /** + * Setting up buttons with prescribed choice values. + */ + String prevTagVal = tagEdit.getTagVal(); + boolean prevTagValInTagItems = false; + Collection odkTagItems = odkTag.getItems(); + for (ODKTagItem item : odkTagItems) { + String label = item.getLabel(); + String value = item.getValue(); + if (value.equals(prevTagVal)) { + prevTagValInTagItems = true; + } + CheckBox checkBox = new CheckBox(activity); + checkBox.setTextSize(18); + TextView textView = new TextView(activity); + textView.setPadding(66, 0, 0, 25); + textView.setOnClickListener(new TextViewOnClickListener(checkBox)); + if (label != null) { + checkBox.setText(label); + textView.setText(value); + } else { + checkBox.setText(value); + textView.setText(""); + } + checkboxLinearLayout.addView(checkBox); + if (prevTagVal != null && value.equals(prevTagVal)) { + checkBox.toggle(); + } + checkboxLinearLayout.addView(textView); + } + } + /** + * Allows us to pass a CheckBox as a parameter to onClick + */ + private class TextViewOnClickListener implements View.OnClickListener { + CheckBox checkBox; + + public TextViewOnClickListener(CheckBox cb) { + checkBox = cb; + } + + @Override + public void onClick(View v) { + checkBox.toggle(); + } } @Override diff --git a/app/src/main/res/layout/fragment_select_multiple_tag_value.xml b/app/src/main/res/layout/fragment_select_multiple_tag_value.xml index b1924bc..dfaadd1 100644 --- a/app/src/main/res/layout/fragment_select_multiple_tag_value.xml +++ b/app/src/main/res/layout/fragment_select_multiple_tag_value.xml @@ -34,7 +34,15 @@ + android:id="@+id/scrollView"> + + + + From 227471c8435b0c46f18eca5d8310d9b5959e508f Mon Sep 17 00:00:00 2001 From: Nicholas Hallahan Date: Wed, 6 Jan 2016 08:29:32 -0800 Subject: [PATCH 4/9] almost there, i'm not getting unique IDs for the checkboxes, so i need to sort that out #103 --- .../openmapkit/odkcollect/tag/ODKTag.java | 46 +++++++++++++++++-- .../SelectMultipleTagValueFragment.java | 4 ++ .../tagswipe/SelectOneTagValueFragment.java | 4 +- .../redcross/openmapkit/tagswipe/TagEdit.java | 22 ++++++++- 4 files changed, 67 insertions(+), 9 deletions(-) diff --git a/app/src/main/java/org/redcross/openmapkit/odkcollect/tag/ODKTag.java b/app/src/main/java/org/redcross/openmapkit/odkcollect/tag/ODKTag.java index 71458e4..a277481 100644 --- a/app/src/main/java/org/redcross/openmapkit/odkcollect/tag/ODKTag.java +++ b/app/src/main/java/org/redcross/openmapkit/odkcollect/tag/ODKTag.java @@ -1,12 +1,15 @@ package org.redcross.openmapkit.odkcollect.tag; import android.app.Activity; +import android.widget.CheckBox; import android.widget.EditText; import android.widget.TextView; +import java.util.ArrayList; import java.util.Collection; import java.util.HashMap; import java.util.LinkedHashMap; +import java.util.List; import java.util.Map; /** @@ -17,7 +20,8 @@ public class ODKTag { private String key; private String label; private LinkedHashMap items = new LinkedHashMap<>(); - private Map radioButtonIdToODKTagItemHash = new HashMap<>(); + private Map buttonIdToODKTagItemHash = new HashMap<>(); + private List checkBoxes = new ArrayList<>(); public String getKey() { return key; @@ -47,12 +51,12 @@ public void addItem(ODKTagItem item) { items.put(item.getValue(), item); } - public void putRadioButtonIdToTagItemHash(Integer id, ODKTagItem tagItem) { - radioButtonIdToODKTagItemHash.put(id, tagItem); + public void putButtonIdToTagItemHash(Integer id, ODKTagItem tagItem) { + buttonIdToODKTagItemHash.put(id, tagItem); } - public String getTagItemValueFromRadioButtonId(Integer id) { - ODKTagItem item = radioButtonIdToODKTagItemHash.get(id); + public String getTagItemValueFromButtonId(Integer id) { + ODKTagItem item = buttonIdToODKTagItemHash.get(id); if (item != null) { return item.getValue(); } @@ -76,4 +80,36 @@ public TextView createTagValueTextView(Activity activity, String initialTagVal) } return et; } + + public void addCheckbox(CheckBox cb) { + checkBoxes.add(cb); + } + + public boolean hasCheckedTagValues() { + for (CheckBox cb : checkBoxes) { + if (cb.isChecked()) { + return true; + } + } + return false; + } + + public String getSemiColonDelimitedTagValues() { + String values = null; + boolean firstVal = true; + for (CheckBox cb : checkBoxes) { + if (cb.isChecked()) { + int id = cb.getId(); + ODKTagItem item = buttonIdToODKTagItemHash.get(id); + if (item != null) { + if (firstVal) { + values = item.getValue(); + } else { + values += ';' + item.getValue(); + } + } + } + } + return values; + } } diff --git a/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java b/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java index a1031ea..71bdd33 100644 --- a/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java +++ b/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java @@ -66,6 +66,7 @@ private void setupWidgets() { } private void setupCheckBoxes() { + tagEdit.setCheckBoxMode(true); final LinearLayout checkboxLinearLayout = (LinearLayout)rootView.findViewById(R.id.checkboxLinearLayout); final Activity activity = getActivity(); ODKTag odkTag = tagEdit.getODKTag(); @@ -99,6 +100,9 @@ private void setupCheckBoxes() { if (prevTagVal != null && value.equals(prevTagVal)) { checkBox.toggle(); } + int id = checkBox.getId(); + odkTag.putButtonIdToTagItemHash(id, item); + odkTag.addCheckbox(checkBox); checkboxLinearLayout.addView(textView); } } diff --git a/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectOneTagValueFragment.java b/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectOneTagValueFragment.java index 03cc2e3..ce8a858 100644 --- a/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectOneTagValueFragment.java +++ b/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectOneTagValueFragment.java @@ -147,8 +147,8 @@ public void onClick(View view) { if (prevTagVal != null && value.equals(prevTagVal)) { button.toggle(); } - int buttonId = button.getId(); - odkTag.putRadioButtonIdToTagItemHash(buttonId, item); + int id = button.getId(); + odkTag.putButtonIdToTagItemHash(id, item); tagValueRadioGroup.addView(textView); } if (!prevTagValInTagItems) { diff --git a/app/src/main/java/org/redcross/openmapkit/tagswipe/TagEdit.java b/app/src/main/java/org/redcross/openmapkit/tagswipe/TagEdit.java index 2612a04..6df324e 100644 --- a/app/src/main/java/org/redcross/openmapkit/tagswipe/TagEdit.java +++ b/app/src/main/java/org/redcross/openmapkit/tagswipe/TagEdit.java @@ -35,6 +35,7 @@ public class TagEdit { private String tagVal; private ODKTag odkTag; private boolean readOnly; + private boolean checkBoxMode = false; private int idx = -1; private EditText editText; private RadioGroup radioGroup; @@ -135,12 +136,27 @@ public void setEditText(EditText editText) { public void setRadioGroup(RadioGroup radioGroup) { this.radioGroup = radioGroup; } + + public void setCheckBoxMode(boolean bool) { + checkBoxMode = true; + } public ODKTag getODKTag() { return odkTag; } private void updateTagInOSMElement() { + // check boxes + if (odkTag != null && checkBoxMode) { + if (odkTag.hasCheckedTagValues()) { + tagVal = odkTag.getSemiColonDelimitedTagValues(); + osmElement.addOrEditTag(tagKey, tagVal); + } else { + osmElement.deleteTag(tagKey); + } + return; + } + // radio buttons if (radioGroup != null && odkTag != null) { LinearLayout customLL = (LinearLayout)radioGroup.getChildAt(radioGroup.getChildCount() - 1); RadioButton customRadio = (RadioButton)customLL.getChildAt(0); @@ -150,12 +166,14 @@ private void updateTagInOSMElement() { tagVal = et.getText().toString(); osmElement.addOrEditTag(tagKey, tagVal); } else if (checkedId != -1) { - tagVal = odkTag.getTagItemValueFromRadioButtonId(checkedId); + tagVal = odkTag.getTagItemValueFromButtonId(checkedId); osmElement.addOrEditTag(tagKey, tagVal); } else { osmElement.deleteTag(tagKey); } - } else if (editText != null) { + } + // edit text + else if (editText != null) { tagVal = editText.getText().toString(); osmElement.addOrEditTag(tagKey, tagVal); } From c09068efd6ce7984682c4842ab3ef15c30d70cd8 Mon Sep 17 00:00:00 2001 From: Nicholas Hallahan Date: Wed, 6 Jan 2016 09:15:39 -0800 Subject: [PATCH 5/9] semi colon delimited values working #103 --- .../java/org/redcross/openmapkit/odkcollect/tag/ODKTag.java | 1 + .../openmapkit/tagswipe/SelectMultipleTagValueFragment.java | 5 +++-- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/app/src/main/java/org/redcross/openmapkit/odkcollect/tag/ODKTag.java b/app/src/main/java/org/redcross/openmapkit/odkcollect/tag/ODKTag.java index a277481..6f38b47 100644 --- a/app/src/main/java/org/redcross/openmapkit/odkcollect/tag/ODKTag.java +++ b/app/src/main/java/org/redcross/openmapkit/odkcollect/tag/ODKTag.java @@ -103,6 +103,7 @@ public String getSemiColonDelimitedTagValues() { ODKTagItem item = buttonIdToODKTagItemHash.get(id); if (item != null) { if (firstVal) { + firstVal = false; values = item.getValue(); } else { values += ';' + item.getValue(); diff --git a/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java b/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java index 71bdd33..6dfe0ef 100644 --- a/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java +++ b/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java @@ -78,6 +78,7 @@ private void setupCheckBoxes() { String prevTagVal = tagEdit.getTagVal(); boolean prevTagValInTagItems = false; Collection odkTagItems = odkTag.getItems(); + int id = 1; for (ODKTagItem item : odkTagItems) { String label = item.getLabel(); String value = item.getValue(); @@ -100,8 +101,8 @@ private void setupCheckBoxes() { if (prevTagVal != null && value.equals(prevTagVal)) { checkBox.toggle(); } - int id = checkBox.getId(); - odkTag.putButtonIdToTagItemHash(id, item); + checkBox.setId(id); + odkTag.putButtonIdToTagItemHash(id++, item); odkTag.addCheckbox(checkBox); checkboxLinearLayout.addView(textView); } From 8f103bb85b69c502fcc3c56eb8d4b7095fdb0b61 Mon Sep 17 00:00:00 2001 From: Nicholas Hallahan Date: Wed, 6 Jan 2016 10:13:20 -0800 Subject: [PATCH 6/9] EditText checkbox working but needs to write into model --- .../SelectMultipleTagValueFragment.java | 54 +++++++++++++++++++ 1 file changed, 54 insertions(+) diff --git a/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java b/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java index 6dfe0ef..5ef940b 100644 --- a/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java +++ b/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java @@ -1,13 +1,18 @@ package org.redcross.openmapkit.tagswipe; import android.app.Activity; +import android.content.Context; import android.net.Uri; import android.os.Bundle; import android.support.v4.app.Fragment; +import android.text.Editable; +import android.text.TextWatcher; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; +import android.view.inputmethod.InputMethodManager; import android.widget.CheckBox; +import android.widget.EditText; import android.widget.LinearLayout; import android.widget.TextView; @@ -65,6 +70,7 @@ private void setupWidgets() { setupCheckBoxes(); } + @SuppressWarnings("ResourceType") private void setupCheckBoxes() { tagEdit.setCheckBoxMode(true); final LinearLayout checkboxLinearLayout = (LinearLayout)rootView.findViewById(R.id.checkboxLinearLayout); @@ -106,6 +112,54 @@ private void setupCheckBoxes() { odkTag.addCheckbox(checkBox); checkboxLinearLayout.addView(textView); } + + final CheckBox editTextCheckBox = new CheckBox(activity); + final EditText editText = new EditText(activity); + editText.setLayoutParams(new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT)); + if (!prevTagValInTagItems && prevTagVal != null) { + editText.setText(prevTagVal); + editTextCheckBox.setChecked(true); + } + editText.addTextChangedListener(new TextWatcher() { + @Override + public void beforeTextChanged(CharSequence charSequence, int i, int i1, int i2) { + } + + @Override + public void onTextChanged(CharSequence charSequence, int i, int i1, int i2) { + if (charSequence.length() > 0) { + editTextCheckBox.setChecked(true); + } else { + editTextCheckBox.setChecked(false); + } + } + + @Override + public void afterTextChanged(Editable editable) { + } + }); + editTextCheckBox.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View view) { + if (editTextCheckBox.isChecked()) { + editText.setFocusableInTouchMode(true); + editText.requestFocus(); + final InputMethodManager inputMethodManager = (InputMethodManager) activity + .getSystemService(Context.INPUT_METHOD_SERVICE); + inputMethodManager.showSoftInput(editText, InputMethodManager.SHOW_IMPLICIT); + } + } + }); + + LinearLayout customLinearLayout = new LinearLayout(activity); + customLinearLayout.setOrientation(LinearLayout.HORIZONTAL); + customLinearLayout.setLayoutParams(new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT)); + customLinearLayout.setDescendantFocusability(ViewGroup.FOCUS_BEFORE_DESCENDANTS); + customLinearLayout.setFocusableInTouchMode(true); + customLinearLayout.addView(editTextCheckBox); + customLinearLayout.addView(editText); + checkboxLinearLayout.addView(customLinearLayout); + } /** From 4a2237cffef590cb51ab802f46fd03de0bb09168 Mon Sep 17 00:00:00 2001 From: Nicholas Hallahan Date: Wed, 6 Jan 2016 12:52:55 -0800 Subject: [PATCH 7/9] writing semicolon values in xml almost working correctly #103 --- .../openmapkit/odkcollect/tag/ODKTag.java | 12 +++++++++++- .../SelectMultipleTagValueFragment.java | 2 +- .../redcross/openmapkit/tagswipe/TagEdit.java | 17 +++++++++++++++-- 3 files changed, 27 insertions(+), 4 deletions(-) diff --git a/app/src/main/java/org/redcross/openmapkit/odkcollect/tag/ODKTag.java b/app/src/main/java/org/redcross/openmapkit/odkcollect/tag/ODKTag.java index 6f38b47..1c4583e 100644 --- a/app/src/main/java/org/redcross/openmapkit/odkcollect/tag/ODKTag.java +++ b/app/src/main/java/org/redcross/openmapkit/odkcollect/tag/ODKTag.java @@ -94,7 +94,7 @@ public boolean hasCheckedTagValues() { return false; } - public String getSemiColonDelimitedTagValues() { + public String getSemiColonDelimitedTagValues(String customValues) { String values = null; boolean firstVal = true; for (CheckBox cb : checkBoxes) { @@ -111,6 +111,16 @@ public String getSemiColonDelimitedTagValues() { } } } + if (customValues != null) { + customValues = customValues.trim(); + if (customValues.length() > 0) { + if (firstVal) { + values = customValues; + } else { + values += ';' + customValues; + } + } + } return values; } } diff --git a/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java b/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java index 5ef940b..70d1b53 100644 --- a/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java +++ b/app/src/main/java/org/redcross/openmapkit/tagswipe/SelectMultipleTagValueFragment.java @@ -72,7 +72,6 @@ private void setupWidgets() { @SuppressWarnings("ResourceType") private void setupCheckBoxes() { - tagEdit.setCheckBoxMode(true); final LinearLayout checkboxLinearLayout = (LinearLayout)rootView.findViewById(R.id.checkboxLinearLayout); final Activity activity = getActivity(); ODKTag odkTag = tagEdit.getODKTag(); @@ -150,6 +149,7 @@ public void onClick(View view) { } } }); + tagEdit.setupEditCheckbox(editTextCheckBox, editText); LinearLayout customLinearLayout = new LinearLayout(activity); customLinearLayout.setOrientation(LinearLayout.HORIZONTAL); diff --git a/app/src/main/java/org/redcross/openmapkit/tagswipe/TagEdit.java b/app/src/main/java/org/redcross/openmapkit/tagswipe/TagEdit.java index 6df324e..7a241ed 100644 --- a/app/src/main/java/org/redcross/openmapkit/tagswipe/TagEdit.java +++ b/app/src/main/java/org/redcross/openmapkit/tagswipe/TagEdit.java @@ -1,5 +1,6 @@ package org.redcross.openmapkit.tagswipe; +import android.widget.CheckBox; import android.widget.EditText; import android.widget.LinearLayout; import android.widget.RadioButton; @@ -39,6 +40,12 @@ public class TagEdit { private int idx = -1; private EditText editText; private RadioGroup radioGroup; + + /** + * For CheckBox mode. + */ + private CheckBox editTextCheckBox; + private EditText checkBoxEditText; public static List buildTagEdits() { int idx = 0; @@ -137,8 +144,10 @@ public void setRadioGroup(RadioGroup radioGroup) { this.radioGroup = radioGroup; } - public void setCheckBoxMode(boolean bool) { + public void setupEditCheckbox(CheckBox cb, EditText et) { checkBoxMode = true; + editTextCheckBox = cb; + checkBoxEditText = et; } public ODKTag getODKTag() { @@ -149,7 +158,11 @@ private void updateTagInOSMElement() { // check boxes if (odkTag != null && checkBoxMode) { if (odkTag.hasCheckedTagValues()) { - tagVal = odkTag.getSemiColonDelimitedTagValues(); + if (editTextCheckBox.isChecked()) { + tagVal = odkTag.getSemiColonDelimitedTagValues(checkBoxEditText.getText().toString()); + } else { + tagVal = odkTag.getSemiColonDelimitedTagValues(null); + } osmElement.addOrEditTag(tagKey, tagVal); } else { osmElement.deleteTag(tagKey); From 8dfc51a4ef8c69b1facea8100b9f39f26232ab9d Mon Sep 17 00:00:00 2001 From: Nicholas Hallahan Date: Wed, 6 Jan 2016 13:42:33 -0800 Subject: [PATCH 8/9] v0.15 Multiple Tag Value Feature. Closes #103 --- app/build.gradle | 4 ++-- .../main/java/org/redcross/openmapkit/tagswipe/TagEdit.java | 5 +++-- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/app/build.gradle b/app/build.gradle index 8dcd39c..49e0b35 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -8,8 +8,8 @@ android { applicationId "org.redcross.openmapkit" minSdkVersion 16 targetSdkVersion 21 - versionCode 14 - versionName "0.14" + versionCode 15 + versionName "0.15" } buildTypes { release { diff --git a/app/src/main/java/org/redcross/openmapkit/tagswipe/TagEdit.java b/app/src/main/java/org/redcross/openmapkit/tagswipe/TagEdit.java index 7a241ed..f0bd81b 100644 --- a/app/src/main/java/org/redcross/openmapkit/tagswipe/TagEdit.java +++ b/app/src/main/java/org/redcross/openmapkit/tagswipe/TagEdit.java @@ -157,8 +157,9 @@ public ODKTag getODKTag() { private void updateTagInOSMElement() { // check boxes if (odkTag != null && checkBoxMode) { - if (odkTag.hasCheckedTagValues()) { - if (editTextCheckBox.isChecked()) { + boolean editTextCheckBoxChecked = editTextCheckBox.isChecked(); + if (odkTag.hasCheckedTagValues() || editTextCheckBoxChecked) { + if (editTextCheckBoxChecked) { tagVal = odkTag.getSemiColonDelimitedTagValues(checkBoxEditText.getText().toString()); } else { tagVal = odkTag.getSemiColonDelimitedTagValues(null); From f280d73d94d6bd4f5dfda58e936a63d51f4fb609 Mon Sep 17 00:00:00 2001 From: Nicholas Hallahan Date: Wed, 6 Jan 2016 13:50:41 -0800 Subject: [PATCH 9/9] Re-enabled single tag value radio button interface for master branch #105 --- .../org/redcross/openmapkit/tagswipe/TagSwipeActivity.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/app/src/main/java/org/redcross/openmapkit/tagswipe/TagSwipeActivity.java b/app/src/main/java/org/redcross/openmapkit/tagswipe/TagSwipeActivity.java index d73f6d6..62d43e0 100644 --- a/app/src/main/java/org/redcross/openmapkit/tagswipe/TagSwipeActivity.java +++ b/app/src/main/java/org/redcross/openmapkit/tagswipe/TagSwipeActivity.java @@ -178,8 +178,8 @@ public Fragment getItem(int position) { fragment = ReadOnlyTagFragment.newInstance(position); return fragment; } else if (tagEdit.isSelectOne()) { -// fragment = SelectOneTagValueFragment.newInstance(position); - fragment = SelectMultipleTagValueFragment.newInstance(position); + fragment = SelectOneTagValueFragment.newInstance(position); +// fragment = SelectMultipleTagValueFragment.newInstance(position); return fragment; } else { fragment = StringTagValueFragment.newInstance(position);