summaryrefslogtreecommitdiffstats
path: root/src/com/android/contacts/editor/ContactEditorBaseFragment.java
diff options
context:
space:
mode:
authorWalter Jang <wjang@google.com>2015-07-09 13:48:35 -0700
committerWalter Jang <wjang@google.com>2015-07-09 13:50:09 -0700
commit2241783345a24acd27c52d938943b2ca76dc7329 (patch)
tree967653943a9073374f744e70f2f1ed1b7f0b614a /src/com/android/contacts/editor/ContactEditorBaseFragment.java
parent551df3377c3f06b78dc895f04b6b14c4beea1cd0 (diff)
downloadpackages_apps_Contacts-2241783345a24acd27c52d938943b2ca76dc7329.tar.gz
packages_apps_Contacts-2241783345a24acd27c52d938943b2ca76dc7329.tar.bz2
packages_apps_Contacts-2241783345a24acd27c52d938943b2ca76dc7329.zip
Allow split of aggregate contact composed of >1 read-only contacts
Bug 22382957 Change-Id: I33f22a5ba9c55fe722601b54cecc59a173d6940b
Diffstat (limited to 'src/com/android/contacts/editor/ContactEditorBaseFragment.java')
-rw-r--r--src/com/android/contacts/editor/ContactEditorBaseFragment.java12
1 files changed, 9 insertions, 3 deletions
diff --git a/src/com/android/contacts/editor/ContactEditorBaseFragment.java b/src/com/android/contacts/editor/ContactEditorBaseFragment.java
index 2935ad5a7..32c3d3784 100644
--- a/src/com/android/contacts/editor/ContactEditorBaseFragment.java
+++ b/src/com/android/contacts/editor/ContactEditorBaseFragment.java
@@ -770,9 +770,15 @@ abstract public class ContactEditorBaseFragment extends Fragment implements
deleteMenu.setVisible(false);
} else if (isEdit(mAction)) {
HelpUtils.prepareHelpMenuItem(mContext, helpMenu, R.string.help_url_people_edit);
- // Split only if there is more than one raw (non-user profile) contact and doing so
- // won't result in an empty contact
- splitMenu.setVisible(mState.size() > 1 && !isEditingUserProfile() && !mHasNewContact);
+ // Split only if there is more than one raw contact, it is not a user-profile, and
+ // splitting won't result in an empty contact. For the empty contact case, we only guard
+ // against this when there is a single read-only contact in the aggregate. If the user
+ // has joined >1 read-only contacts together, we allow them to split it,
+ // even if they have never added their own information and splitting will create a
+ // name only contact.
+ final boolean isSingleReadOnlyContact = mHasNewContact && mState.size() == 2;
+ splitMenu.setVisible(mState.size() > 1 && !isEditingUserProfile()
+ && !isSingleReadOnlyContact);
// Cannot join a user profile
joinMenu.setVisible(!isEditingUserProfile());
deleteMenu.setVisible(!mDisableDeleteMenuOption);