summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDake Gu <dake@google.com>2015-10-27 22:23:56 +0000
committerAndroid (Google) Code Review <android-gerrit@google.com>2015-10-27 22:23:56 +0000
commit01b04c446982a468c7d18e0883bb124c93ebcba1 (patch)
tree0300c427ad61202fb39c4f9fbe66a7dc578c27a0
parent193f0c9d8feec4914aace962cc5c2e11dd5b6609 (diff)
parent58ccc4ace24b9c29de49c3f672454a3c50599327 (diff)
downloadandroid_development-01b04c446982a468c7d18e0883bb124c93ebcba1.tar.gz
android_development-01b04c446982a468c7d18e0883bb124c93ebcba1.tar.bz2
android_development-01b04c446982a468c7d18e0883bb124c93ebcba1.zip
Merge "GuidedStep: More example of editing" into mnc-ub-dev
-rw-r--r--samples/SupportLeanbackDemos/src/com/example/android/leanback/GuidedStepActivity.java89
-rw-r--r--samples/SupportLeanbackDemos/src/com/example/android/leanback/GuidedStepSupportActivity.java89
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));
}
}