diff options
author | Dake Gu <dake@google.com> | 2015-10-27 22:23:56 +0000 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2015-10-27 22:23:56 +0000 |
commit | 01b04c446982a468c7d18e0883bb124c93ebcba1 (patch) | |
tree | 0300c427ad61202fb39c4f9fbe66a7dc578c27a0 | |
parent | 193f0c9d8feec4914aace962cc5c2e11dd5b6609 (diff) | |
parent | 58ccc4ace24b9c29de49c3f672454a3c50599327 (diff) | |
download | android_development-01b04c446982a468c7d18e0883bb124c93ebcba1.tar.gz android_development-01b04c446982a468c7d18e0883bb124c93ebcba1.tar.bz2 android_development-01b04c446982a468c7d18e0883bb124c93ebcba1.zip |
Merge "GuidedStep: More example of editing" into mnc-ub-dev
2 files changed, 156 insertions, 22 deletions
diff --git a/samples/SupportLeanbackDemos/src/com/example/android/leanback/GuidedStepActivity.java b/samples/SupportLeanbackDemos/src/com/example/android/leanback/GuidedStepActivity.java index 63149b444..7dda7ffaa 100644 --- a/samples/SupportLeanbackDemos/src/com/example/android/leanback/GuidedStepActivity.java +++ b/samples/SupportLeanbackDemos/src/com/example/android/leanback/GuidedStepActivity.java @@ -27,6 +27,7 @@ import android.support.v17.leanback.app.GuidedStepFragment; import android.support.v17.leanback.widget.GuidedAction; import android.support.v17.leanback.widget.GuidanceStylist; import android.support.v17.leanback.widget.GuidanceStylist.Guidance; +import android.text.InputType; import android.text.TextUtils; import android.util.Log; import android.view.ViewGroup; @@ -44,7 +45,8 @@ public class GuidedStepActivity extends Activity { private static final int FIRST_NAME = 3; private static final int LAST_NAME = 4; - private static final int PAYMENT = 5; + private static final int PASSWORD = 5; + private static final int PAYMENT = 6; private static final int OPTION_CHECK_SET_ID = 10; private static final int DEFAULT_OPTION = 0; @@ -109,6 +111,31 @@ public class GuidedStepActivity extends Activity { .build()); } + private static void addEditableAction(List<GuidedAction> actions, long id, String title, + String editTitle, int editInputType, String desc, String editDesc) { + actions.add(new GuidedAction.Builder() + .id(id) + .title(title) + .editTitle(editTitle) + .editInputType(editInputType) + .description(desc) + .editDescription(editDesc) + .editable(true) + .build()); + } + + private static void addEditableDescriptionAction(List<GuidedAction> actions, long id, + String title, String desc, String editDescription, int descriptionEditInputType) { + actions.add(new GuidedAction.Builder() + .id(id) + .title(title) + .description(desc) + .editDescription(editDescription) + .descriptionEditInputType(descriptionEditInputType) + .descriptionEditable(true) + .build()); + } + private static void addCheckedAction(List<GuidedAction> actions, int iconResId, Context context, String title, String desc) { actions.add(new GuidedAction.Builder() @@ -171,8 +198,12 @@ public class GuidedStepActivity extends Activity { public void onCreateActions(List<GuidedAction> actions, Bundle savedInstanceState) { addEditableAction(actions, FIRST_NAME, "Pat", "Your first name"); addEditableAction(actions, LAST_NAME, "Smith", "Your last name"); - addEditableAction(actions, PAYMENT, "Payment", "", "Input credit card number"); + addEditableAction(actions, PAYMENT, "Payment", "", InputType.TYPE_CLASS_NUMBER, + "Input credit card number", "Input credit card number"); + addEditableDescriptionAction(actions, PASSWORD, "Password", "", "", + InputType.TYPE_CLASS_TEXT | InputType.TYPE_TEXT_VARIATION_PASSWORD); addAction(actions, CONTINUE, "Continue", "Continue"); + actions.get(actions.size() - 1).setEnabled(false); } @Override @@ -184,16 +215,52 @@ public class GuidedStepActivity extends Activity { } @Override - public void onGuidedActionEdited(GuidedAction action) { - CharSequence editTitle = action.getEditTitle(); - if (TextUtils.isDigitsOnly(editTitle) && editTitle.length() == 16) { - editTitle = editTitle.subSequence(editTitle.length() - 4, editTitle.length()); - action.setDescription("Visa XXXX-XXXX-XXXX-"+editTitle); - } else if (editTitle.length() == 0){ - action.setDescription("Input credit card number"); - } else { - action.setDescription("Error credit card number"); + public long onGuidedActionEditedAndProceed(GuidedAction action) { + if (action.getId() == PAYMENT) { + CharSequence editTitle = action.getEditTitle(); + if (TextUtils.isDigitsOnly(editTitle) && editTitle.length() == 16) { + editTitle = editTitle.subSequence(editTitle.length() - 4, editTitle.length()); + action.setDescription("Visa XXXX-XXXX-XXXX-"+editTitle); + updateContinue(isPasswordValid()); + return GuidedAction.ACTION_ID_NEXT; + } else if (editTitle.length() == 0){ + action.setDescription("Input credit card number"); + updateContinue(false); + return GuidedAction.ACTION_ID_CURRENT; + } else { + action.setDescription("Error credit card number"); + updateContinue(false); + return GuidedAction.ACTION_ID_CURRENT; + } + } else if (action.getId() == PASSWORD) { + CharSequence password = action.getEditDescription(); + if (password.length() > 0) { + if (isPaymentValid()) { + updateContinue(true); + return GuidedAction.ACTION_ID_NEXT; + } else { + updateContinue(false); + return GuidedAction.ACTION_ID_CURRENT; + } + } else { + updateContinue(false); + return GuidedAction.ACTION_ID_CURRENT; + } } + return GuidedAction.ACTION_ID_NEXT; + } + + boolean isPaymentValid() { + return findActionById(PAYMENT).getDescription().subSequence(0, 4).toString().equals("Visa"); + } + + boolean isPasswordValid() { + return findActionById(PASSWORD).getEditDescription().length() > 0; + } + + void updateContinue(boolean enabled) { + findActionById(CONTINUE).setEnabled(enabled); + notifyActionChanged(findActionPositionById(CONTINUE)); } } diff --git a/samples/SupportLeanbackDemos/src/com/example/android/leanback/GuidedStepSupportActivity.java b/samples/SupportLeanbackDemos/src/com/example/android/leanback/GuidedStepSupportActivity.java index 432c6c0f0..1fb7cfafa 100644 --- a/samples/SupportLeanbackDemos/src/com/example/android/leanback/GuidedStepSupportActivity.java +++ b/samples/SupportLeanbackDemos/src/com/example/android/leanback/GuidedStepSupportActivity.java @@ -29,6 +29,7 @@ import android.support.v17.leanback.app.GuidedStepSupportFragment; import android.support.v17.leanback.widget.GuidedAction; import android.support.v17.leanback.widget.GuidanceStylist; import android.support.v17.leanback.widget.GuidanceStylist.Guidance; +import android.text.InputType; import android.text.TextUtils; import android.util.Log; import android.view.ViewGroup; @@ -46,7 +47,8 @@ public class GuidedStepSupportActivity extends FragmentActivity { private static final int FIRST_NAME = 3; private static final int LAST_NAME = 4; - private static final int PAYMENT = 5; + private static final int PASSWORD = 5; + private static final int PAYMENT = 6; private static final int OPTION_CHECK_SET_ID = 10; private static final int DEFAULT_OPTION = 0; @@ -111,6 +113,31 @@ public class GuidedStepSupportActivity extends FragmentActivity { .build()); } + private static void addEditableAction(List<GuidedAction> actions, long id, String title, + String editTitle, int editInputType, String desc, String editDesc) { + actions.add(new GuidedAction.Builder() + .id(id) + .title(title) + .editTitle(editTitle) + .editInputType(editInputType) + .description(desc) + .editDescription(editDesc) + .editable(true) + .build()); + } + + private static void addEditableDescriptionAction(List<GuidedAction> actions, long id, + String title, String desc, String editDescription, int descriptionEditInputType) { + actions.add(new GuidedAction.Builder() + .id(id) + .title(title) + .description(desc) + .editDescription(editDescription) + .descriptionEditInputType(descriptionEditInputType) + .descriptionEditable(true) + .build()); + } + private static void addCheckedAction(List<GuidedAction> actions, int iconResId, Context context, String title, String desc) { actions.add(new GuidedAction.Builder() @@ -173,8 +200,12 @@ public class GuidedStepSupportActivity extends FragmentActivity { public void onCreateActions(List<GuidedAction> actions, Bundle savedInstanceState) { addEditableAction(actions, FIRST_NAME, "Pat", "Your first name"); addEditableAction(actions, LAST_NAME, "Smith", "Your last name"); - addEditableAction(actions, PAYMENT, "Payment", "", "Input credit card number"); + addEditableAction(actions, PAYMENT, "Payment", "", InputType.TYPE_CLASS_NUMBER, + "Input credit card number", "Input credit card number"); + addEditableDescriptionAction(actions, PASSWORD, "Password", "", "", + InputType.TYPE_CLASS_TEXT | InputType.TYPE_TEXT_VARIATION_PASSWORD); addAction(actions, CONTINUE, "Continue", "Continue"); + actions.get(actions.size() - 1).setEnabled(false); } @Override @@ -186,16 +217,52 @@ public class GuidedStepSupportActivity extends FragmentActivity { } @Override - public void onGuidedActionEdited(GuidedAction action) { - CharSequence editTitle = action.getEditTitle(); - if (TextUtils.isDigitsOnly(editTitle) && editTitle.length() == 16) { - editTitle = editTitle.subSequence(editTitle.length() - 4, editTitle.length()); - action.setDescription("Visa XXXX-XXXX-XXXX-"+editTitle); - } else if (editTitle.length() == 0){ - action.setDescription("Input credit card number"); - } else { - action.setDescription("Error credit card number"); + public long onGuidedActionEditedAndProceed(GuidedAction action) { + if (action.getId() == PAYMENT) { + CharSequence editTitle = action.getEditTitle(); + if (TextUtils.isDigitsOnly(editTitle) && editTitle.length() == 16) { + editTitle = editTitle.subSequence(editTitle.length() - 4, editTitle.length()); + action.setDescription("Visa XXXX-XXXX-XXXX-"+editTitle); + updateContinue(isPasswordValid()); + return GuidedAction.ACTION_ID_NEXT; + } else if (editTitle.length() == 0){ + action.setDescription("Input credit card number"); + updateContinue(false); + return GuidedAction.ACTION_ID_CURRENT; + } else { + action.setDescription("Error credit card number"); + updateContinue(false); + return GuidedAction.ACTION_ID_CURRENT; + } + } else if (action.getId() == PASSWORD) { + CharSequence password = action.getEditDescription(); + if (password.length() > 0) { + if (isPaymentValid()) { + updateContinue(true); + return GuidedAction.ACTION_ID_NEXT; + } else { + updateContinue(false); + return GuidedAction.ACTION_ID_CURRENT; + } + } else { + updateContinue(false); + return GuidedAction.ACTION_ID_CURRENT; + } } + return GuidedAction.ACTION_ID_NEXT; + } + + boolean isPaymentValid() { + return findActionById(PAYMENT).getDescription().subSequence(0, 4).toString().equals("Visa"); + } + + boolean isPasswordValid() { + return findActionById(PASSWORD).getEditDescription().length() > 0; + } + + void updateContinue(boolean enabled) { + findActionById(CONTINUE).setEnabled(enabled); + notifyActionChanged(findActionPositionById(CONTINUE)); } } |