diff options
Diffstat (limited to 'main/src')
| -rw-r--r-- | main/src/cgeo/geocaching/CacheDetailActivity.java | 57 | ||||
| -rw-r--r-- | main/src/cgeo/geocaching/ui/EditorDialog.java | 59 |
2 files changed, 97 insertions, 19 deletions
diff --git a/main/src/cgeo/geocaching/CacheDetailActivity.java b/main/src/cgeo/geocaching/CacheDetailActivity.java index fec3758..60b5bec 100644 --- a/main/src/cgeo/geocaching/CacheDetailActivity.java +++ b/main/src/cgeo/geocaching/CacheDetailActivity.java @@ -18,6 +18,7 @@ import cgeo.geocaching.network.HtmlImage; import cgeo.geocaching.network.Parameters; import cgeo.geocaching.ui.CacheDetailsCreator; import cgeo.geocaching.ui.DecryptTextClickListener; +import cgeo.geocaching.ui.EditorDialog; import cgeo.geocaching.ui.Formatter; import cgeo.geocaching.ui.LoggingUI; import cgeo.geocaching.utils.BaseUtils; @@ -166,7 +167,7 @@ public class CacheDetailActivity extends AbstractActivity { /** * A {@link List} of all available pages. - * + * * TODO Move to adapter */ private final List<Page> pageOrder = new ArrayList<Page>(); @@ -1892,28 +1893,37 @@ public class CacheDetailActivity extends AbstractActivity { } // cache personal note - if (StringUtils.isNotBlank(cache.getPersonalNote())) { - view.findViewById(R.id.personalnote_box).setVisibility(View.VISIBLE); - - TextView personalNoteText = (TextView) view.findViewById(R.id.personalnote); - personalNoteText.setVisibility(View.VISIBLE); - personalNoteText.setText(cache.getPersonalNote(), TextView.BufferType.SPANNABLE); - personalNoteText.setMovementMethod(LinkMovementMethod.getInstance()); - registerForContextMenu(personalNoteText); - } - else { - view.findViewById(R.id.personalnote_box).setVisibility(View.GONE); - } + final TextView personalNoteView = (TextView) view.findViewById(R.id.personalnote); + setPersonalNote(personalNoteView); + personalNoteView.setMovementMethod(LinkMovementMethod.getInstance()); + registerForContextMenu(personalNoteView); + final Button personalNoteEdit = (Button) view.findViewById(R.id.edit_personalnote); + personalNoteEdit.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + EditorDialog editor = new EditorDialog(CacheDetailActivity.this, personalNoteView.getText()); + editor.setOnEditorUpdate(new EditorDialog.EditorUpdate() { + @Override + public void update(CharSequence editorText) { + cache.setPersonalNote(editorText.toString()); + setPersonalNote(personalNoteView); + app.saveCache(cache, EnumSet.of(SaveFlag.SAVE_DB)); + } + }); + editor.show(); + } + }); // cache hint and spoiler images + final View hintBoxView = view.findViewById(R.id.hint_box); if (StringUtils.isNotBlank(cache.getHint()) || CollectionUtils.isNotEmpty(cache.getSpoilers())) { - view.findViewById(R.id.hint_box).setVisibility(View.VISIBLE); + hintBoxView.setVisibility(View.VISIBLE); } else { - view.findViewById(R.id.hint_box).setVisibility(View.GONE); + hintBoxView.setVisibility(View.GONE); } + final TextView hintView = ((TextView) view.findViewById(R.id.hint)); if (StringUtils.isNotBlank(cache.getHint())) { - TextView hintView = ((TextView) view.findViewById(R.id.hint)); if (BaseUtils.containsHtml(cache.getHint())) { hintView.setText(Html.fromHtml(cache.getHint(), new HtmlImage(cache.getGeocode(), false, cache.getListId(), false), null), TextView.BufferType.SPANNABLE); hintView.setText(CryptUtils.rot13((Spannable) hintView.getText())); @@ -1926,14 +1936,13 @@ public class CacheDetailActivity extends AbstractActivity { hintView.setOnClickListener(new DecryptTextClickListener()); registerForContextMenu(hintView); } else { - TextView hintView = ((TextView) view.findViewById(R.id.hint)); hintView.setVisibility(View.GONE); hintView.setClickable(false); hintView.setOnClickListener(null); } + final TextView spoilerlinkView = ((TextView) view.findViewById(R.id.hint_spoilerlink)); if (CollectionUtils.isNotEmpty(cache.getSpoilers())) { - TextView spoilerlinkView = ((TextView) view.findViewById(R.id.hint_spoilerlink)); spoilerlinkView.setVisibility(View.VISIBLE); spoilerlinkView.setClickable(true); spoilerlinkView.setOnClickListener(new View.OnClickListener() { @@ -1948,7 +1957,6 @@ public class CacheDetailActivity extends AbstractActivity { } }); } else { - TextView spoilerlinkView = ((TextView) view.findViewById(R.id.hint_spoilerlink)); spoilerlinkView.setVisibility(View.GONE); spoilerlinkView.setClickable(true); spoilerlinkView.setOnClickListener(null); @@ -1957,6 +1965,17 @@ public class CacheDetailActivity extends AbstractActivity { return view; } + private void setPersonalNote(final TextView personalNoteView) { + final String personalNote = cache.getPersonalNote(); + personalNoteView.setText(personalNote, TextView.BufferType.SPANNABLE); + if (StringUtils.isNotBlank(personalNote)) { + personalNoteView.setVisibility(View.VISIBLE); + } + else { + personalNoteView.setVisibility(View.GONE); + } + } + private void loadLongDescription() { Button showDesc = (Button) view.findViewById(R.id.show_description); showDesc.setVisibility(View.GONE); diff --git a/main/src/cgeo/geocaching/ui/EditorDialog.java b/main/src/cgeo/geocaching/ui/EditorDialog.java new file mode 100644 index 0000000..50b3e27 --- /dev/null +++ b/main/src/cgeo/geocaching/ui/EditorDialog.java @@ -0,0 +1,59 @@ +package cgeo.geocaching.ui; + +import cgeo.geocaching.CacheDetailActivity; +import cgeo.geocaching.R; + +import android.app.Dialog; +import android.os.Bundle; +import android.view.View; +import android.view.ViewGroup.LayoutParams; +import android.view.Window; +import android.widget.Button; +import android.widget.EditText; + +public class EditorDialog extends Dialog { + + private CharSequence editorText; + private EditorUpdate editorUpdate; + + public EditorDialog(CacheDetailActivity cacheDetailActivity, CharSequence editable) { + super(cacheDetailActivity); + this.editorText = editable; + } + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + + requestWindowFeature(Window.FEATURE_NO_TITLE); + setContentView(R.layout.editor); + + final EditText editText = (EditText) findViewById(R.id.editorEditText); + editText.setText(editorText); + + final Button buttonSave = (Button) findViewById(R.id.editorSave); + buttonSave.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + editorUpdate.update(editText.getEditableText()); + EditorDialog.this.hide(); + } + }); + } + + public interface EditorUpdate { + public void update(CharSequence editorText); + } + + public void setOnEditorUpdate(EditorUpdate editorUpdate) { + this.editorUpdate = editorUpdate; + + } + + @Override + public void show() { + super.show(); + getWindow().setLayout(LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT); + } + +} |
