diff options
| author | Joachim Wilke <git@joachim-wilke.de> | 2012-06-01 14:18:43 +0200 |
|---|---|---|
| committer | Joachim Wilke <git@joachim-wilke.de> | 2012-07-06 17:38:21 +0200 |
| commit | 2ab1a677b17e79eed9ef389742e100280edc6b9a (patch) | |
| tree | a659673cff5f5e427ff9d81020ac978f95f68d2e /main/src/cgeo/geocaching/CacheDetailActivity.java | |
| parent | d1d1cb75b4e51d86e6bb0df910864b0687e1b1b5 (diff) | |
| download | cgeo-2ab1a677b17e79eed9ef389742e100280edc6b9a.zip cgeo-2ab1a677b17e79eed9ef389742e100280edc6b9a.tar.gz cgeo-2ab1a677b17e79eed9ef389742e100280edc6b9a.tar.bz2 | |
Issue #409: Edit "Personal Cache Note" and copy from it
https://github.com/cgeo/c-geo-opensource/issues/issue/409
Diffstat (limited to 'main/src/cgeo/geocaching/CacheDetailActivity.java')
| -rw-r--r-- | main/src/cgeo/geocaching/CacheDetailActivity.java | 33 |
1 files changed, 21 insertions, 12 deletions
diff --git a/main/src/cgeo/geocaching/CacheDetailActivity.java b/main/src/cgeo/geocaching/CacheDetailActivity.java index 93566c2..993e6a0 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; @@ -1896,18 +1897,26 @@ public class CacheDetailActivity extends AbstractActivity { } // cache personal note - if (StringUtils.isNotBlank(cache.getPersonalNote())) { - ((LinearLayout) 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 { - ((LinearLayout) view.findViewById(R.id.personalnote_box)).setVisibility(View.GONE); - } + final TextView personalNoteText = (TextView) view.findViewById(R.id.personalnote); + personalNoteText.setText(cache.getPersonalNote(), TextView.BufferType.SPANNABLE); + personalNoteText.setMovementMethod(LinkMovementMethod.getInstance()); + registerForContextMenu(personalNoteText); + 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, personalNoteText.getText()); + editor.setOnEditorUpdate(new EditorDialog.EditorUpdate() { + @Override + public void update(CharSequence editorText) { + personalNoteText.setText(editorText); + cache.setPersonalNote(editorText.toString()); + app.saveCache(cache, EnumSet.of(SaveFlag.SAVE_DB)); + } + }); + editor.show(); + } + }); // cache hint and spoiler images if (StringUtils.isNotBlank(cache.getHint()) || CollectionUtils.isNotEmpty(cache.getSpoilers())) { |
