1 /*
2  * Copyright (C) 2014 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 package com.android.tv.settings.form;
18 
19 import android.content.Intent;
20 import android.os.Bundle;
21 import android.os.Parcel;
22 import android.os.Parcelable;
23 
24 import java.util.ArrayList;
25 import java.util.List;
26 
27 /**
28  * Implements a FormPage. This is a form page that can be used by MultiPagedForm
29  * to create fragments
30  */
31 public class FormPage implements Parcelable {
32 
33     public static final String DATA_KEY_SUMMARY_STRING =
34             "com.android.tv.settings.form.FormPage.summaryString";
35 
36     public static final String DATA_KEY_SECONDARY_STRING =
37             "com.android.tv.settings.form.FormPage.secondaryString";
38 
39     enum Type {
40         MULTIPLE_CHOICE, TEXT_INPUT, PASSWORD_INPUT, INTENT
41     }
42 
43     public final static Parcelable.Creator<FormPage> CREATOR = new Parcelable.Creator<FormPage>() {
44 
45         @Override
46         public FormPage createFromParcel(Parcel parcel) {
47             return new FormPage(parcel);
48         }
49 
50         @Override
51         public FormPage[] newArray(int size) {
52             return new FormPage[size];
53         }
54     };
55 
56     /**
57      * Create a form page resulting in a password input field.
58      *
59      * @param title the title of this form page. Should be unique for this
60      *            Activity.
61      * @return an incomplete form page suitable for use in MultiPagedForm.
62      */
createPasswordInputForm(String title)63     public static FormPage createPasswordInputForm(String title) {
64         return new FormPage(title, Type.PASSWORD_INPUT, null, null);
65     }
66 
67     /**
68      * Create a form page resulting in a text input field.
69      *
70      * @param title the title of this form page. Should be unique for this
71      *            Activity.
72      * @return an incomplete form page suitable for use in MultiPagedForm.
73      */
createTextInputForm(String title)74     public static FormPage createTextInputForm(String title) {
75         return new FormPage(title, Type.TEXT_INPUT, null, null);
76     }
77 
78     /**
79      * Create a form page resulting in a list of choices.
80      *
81      * @param title the title of this form page. Should be unique for this
82      *            Activity.
83      * @param formChoices the choices for this form page.
84      * @return an incomplete form page suitable for use in MultiPagedForm.
85      */
createMultipleChoiceForm(String title, ArrayList<String> formChoices)86     public static FormPage createMultipleChoiceForm(String title, ArrayList<String> formChoices) {
87         return new FormPage(title, Type.MULTIPLE_CHOICE, formChoices, null);
88     }
89 
90     /**
91      * Create a form page which launches an intent to get its results.
92      *
93      * @param title the title of this form page. Should be unique for this
94      *            Activity.
95      * @param formIntent the intent to launch for this form page. This intent
96      *            should return the form page's results via the result intent's
97      *            extras bundle. This bundle must contain the
98      *            DATA_KEY_SUMMARY_STRING key as this key is used to display the
99      *            results of the intent to the user.
100      * @return an incomplete form page suitable for use in MultiPagedForm.
101      */
createIntentForm(String title, Intent formIntent)102     public static FormPage createIntentForm(String title, Intent formIntent) {
103         return new FormPage(title, Type.INTENT, null, formIntent);
104     }
105 
106     private final String mPageTitle;
107     private final Type mFormType;
108     private final ArrayList<String> mFormChoices;
109     private final Intent mFormIntent;
110     private Bundle mFormData;
111     private String mError;
112     private String mErrorIconUri;
113     private boolean mCompleted;
114 
FormPage(String pageTitle, Type formType, ArrayList<String> formChoices, Intent formIntent)115     public FormPage(String pageTitle, Type formType, ArrayList<String> formChoices,
116             Intent formIntent) {
117         mPageTitle = pageTitle;
118         mFormType = formType;
119         mFormChoices = formChoices;
120         mFormIntent = formIntent;
121         mFormData = null;
122         mError = null;
123         mErrorIconUri = null;
124         mCompleted = false;
125     }
126 
FormPage(Parcel in)127     public FormPage(Parcel in) {
128         mPageTitle = in.readString();
129         mFormType = Type.valueOf(in.readString());
130         mFormChoices = new ArrayList<>();
131         in.readStringList(mFormChoices);
132         mFormIntent = in.readParcelable(null);
133         mFormData = in.readParcelable(null);
134         mError = in.readString();
135         mErrorIconUri = in.readString();
136         mCompleted = in.readByte() == 1;
137     }
138 
139     @Override
describeContents()140     public int describeContents() {
141         return 0;
142     }
143 
144     @Override
writeToParcel(Parcel out, int flags)145     public void writeToParcel(Parcel out, int flags) {
146         out.writeString(mPageTitle);
147         out.writeString(mFormType.name());
148         out.writeStringList(mFormChoices);
149         out.writeParcelable(mFormIntent, 0);
150         out.writeParcelable(mFormData, 0);
151         out.writeString(mError);
152         out.writeString(mErrorIconUri);
153         out.writeByte((byte) (mCompleted ? 1 : 0));
154     }
155 
156     @Override
toString()157     public String toString() {
158         StringBuilder sb = new StringBuilder();
159         sb.append("PageTitle: " + mPageTitle + "\n");
160         sb.append("FormType: " + mFormType.name() + "\n");
161         sb.append("FormChoices: " + mFormChoices + "\n");
162         sb.append("FormIntent: " + mFormIntent + "\n");
163         sb.append("FormData: " + mFormData + "\n");
164         sb.append("FormError: " + mError + "\n");
165         sb.append("FormErrorIconUri: " + mErrorIconUri + "\n");
166         sb.append("FormCompleted: " + mCompleted + "\n");
167         return sb.toString();
168     }
169 
getTitle()170     public String getTitle() {
171         return mPageTitle;
172     }
173 
getData()174     public Bundle getData() {
175         return mFormData;
176     }
177 
getDataSummary()178     public String getDataSummary() {
179         return (mFormData != null && mFormData.containsKey(DATA_KEY_SUMMARY_STRING)) ? mFormData
180                 .getString(DATA_KEY_SUMMARY_STRING) : "";
181     }
182 
getDataSecondary()183     public String getDataSecondary() {
184         return (mFormData != null && mFormData.containsKey(DATA_KEY_SECONDARY_STRING))
185                 ? mFormData.getString(DATA_KEY_SECONDARY_STRING)
186                 : "";
187     }
188 
clearData()189     public void clearData() {
190         mFormData = null;
191     }
192 
getError()193     public String getError() {
194         return mError;
195     }
196 
getErrorIconUri()197     public String getErrorIconUri() {
198         return mErrorIconUri;
199     }
200 
complete(Bundle data)201     public void complete(Bundle data) {
202         mFormData = data;
203         mCompleted = true;
204     }
205 
setError(String error, String errorIconUri)206     public void setError(String error, String errorIconUri) {
207         mError = error;
208         mErrorIconUri = errorIconUri;
209         mCompleted = false;
210     }
211 
getChoices()212     public List<String> getChoices() {
213         return mFormChoices;
214     }
215 
getType()216     Type getType() {
217         return mFormType;
218     }
219 
getIntent()220     Intent getIntent() {
221         return mFormIntent;
222     }
223 
isComplete()224     boolean isComplete() {
225         return mCompleted;
226     }
227 }
228