sipp11
10 years ago
commit
0666007e12
32 changed files with 1019 additions and 0 deletions
@ -0,0 +1,8 @@
|
||||
.gradle |
||||
/local.properties |
||||
/.idea/workspace.xml |
||||
/.idea/libraries |
||||
.DS_Store |
||||
/build |
||||
|
||||
.idea/* |
@ -0,0 +1,3 @@
|
||||
## Session Try Out |
||||
|
||||
Try working on a session on Android; hopefully I could get it done. |
@ -0,0 +1,19 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?> |
||||
<module external.linked.project.path="$MODULE_DIR$" external.root.project.path="$MODULE_DIR$" external.system.id="GRADLE" external.system.module.group="" external.system.module.version="unspecified" type="JAVA_MODULE" version="4"> |
||||
<component name="FacetManager"> |
||||
<facet type="java-gradle" name="Java-Gradle"> |
||||
<configuration> |
||||
<option name="BUILD_FOLDER_PATH" value="$MODULE_DIR$/build" /> |
||||
</configuration> |
||||
</facet> |
||||
</component> |
||||
<component name="NewModuleRootManager" inherit-compiler-output="true"> |
||||
<exclude-output /> |
||||
<content url="file://$MODULE_DIR$"> |
||||
<excludeFolder url="file://$MODULE_DIR$/.gradle" /> |
||||
</content> |
||||
<orderEntry type="inheritedJdk" /> |
||||
<orderEntry type="sourceFolder" forTests="false" /> |
||||
</component> |
||||
</module> |
||||
|
@ -0,0 +1,89 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?> |
||||
<module external.linked.project.path="$MODULE_DIR$" external.root.project.path="$MODULE_DIR$/.." external.system.id="GRADLE" external.system.module.group="SessionSkeleton" external.system.module.version="unspecified" type="JAVA_MODULE" version="4"> |
||||
<component name="FacetManager"> |
||||
<facet type="android-gradle" name="Android-Gradle"> |
||||
<configuration> |
||||
<option name="GRADLE_PROJECT_PATH" value=":app" /> |
||||
</configuration> |
||||
</facet> |
||||
<facet type="android" name="Android"> |
||||
<configuration> |
||||
<option name="SELECTED_BUILD_VARIANT" value="debug" /> |
||||
<option name="ASSEMBLE_TASK_NAME" value="assembleDebug" /> |
||||
<option name="COMPILE_JAVA_TASK_NAME" value="compileDebugJava" /> |
||||
<option name="ASSEMBLE_TEST_TASK_NAME" value="assembleDebugTest" /> |
||||
<option name="SOURCE_GEN_TASK_NAME" value="generateDebugSources" /> |
||||
<option name="TEST_SOURCE_GEN_TASK_NAME" value="generateDebugTestSources" /> |
||||
<option name="ALLOW_USER_CONFIGURATION" value="false" /> |
||||
<option name="MANIFEST_FILE_RELATIVE_PATH" value="/src/main/AndroidManifest.xml" /> |
||||
<option name="RES_FOLDER_RELATIVE_PATH" value="/src/main/res" /> |
||||
<option name="RES_FOLDERS_RELATIVE_PATH" value="file://$MODULE_DIR$/src/main/res" /> |
||||
<option name="ASSETS_FOLDER_RELATIVE_PATH" value="/src/main/assets" /> |
||||
</configuration> |
||||
</facet> |
||||
</component> |
||||
<component name="NewModuleRootManager" inherit-compiler-output="false"> |
||||
<output url="file://$MODULE_DIR$/build/intermediates/classes/debug" /> |
||||
<exclude-output /> |
||||
<content url="file://$MODULE_DIR$"> |
||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/r/debug" isTestSource="false" generated="true" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/aidl/debug" isTestSource="false" generated="true" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/buildConfig/debug" isTestSource="false" generated="true" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/rs/debug" isTestSource="false" generated="true" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/res/rs/debug" type="java-resource" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/r/test/debug" isTestSource="true" generated="true" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/aidl/test/debug" isTestSource="true" generated="true" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/buildConfig/test/debug" isTestSource="true" generated="true" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/rs/test/debug" isTestSource="true" generated="true" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/res/rs/test/debug" type="java-test-resource" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/res" type="java-resource" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/resources" type="java-resource" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/assets" type="java-resource" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/aidl" isTestSource="false" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/java" isTestSource="false" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/jni" isTestSource="false" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/rs" isTestSource="false" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/main/res" type="java-resource" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/main/resources" type="java-resource" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/main/assets" type="java-resource" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/main/aidl" isTestSource="false" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/main/java" isTestSource="false" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/main/jni" isTestSource="false" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/main/rs" isTestSource="false" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/res" type="java-test-resource" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/resources" type="java-test-resource" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/assets" type="java-test-resource" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/aidl" isTestSource="true" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/java" isTestSource="true" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/jni" isTestSource="true" /> |
||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/rs" isTestSource="true" /> |
||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/assets" /> |
||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/bundles" /> |
||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/classes" /> |
||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/coverage-instrumented-classes" /> |
||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/dependency-cache" /> |
||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/dex" /> |
||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/dex-cache" /> |
||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/incremental" /> |
||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/jacoco" /> |
||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/javaResources" /> |
||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/libs" /> |
||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/lint" /> |
||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/manifests" /> |
||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/ndk" /> |
||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/pre-dexed" /> |
||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/proguard" /> |
||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/res" /> |
||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/rs" /> |
||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/symbols" /> |
||||
<excludeFolder url="file://$MODULE_DIR$/build/outputs" /> |
||||
</content> |
||||
<orderEntry type="jdk" jdkName="Android API 21 Platform" jdkType="Android SDK" /> |
||||
<orderEntry type="sourceFolder" forTests="false" /> |
||||
<orderEntry type="library" exported="" name="support-annotations-21.0.0" level="project" /> |
||||
<orderEntry type="library" exported="" name="support-v4-21.0.0" level="project" /> |
||||
<orderEntry type="library" exported="" name="play-services-6.1.11" level="project" /> |
||||
<orderEntry type="library" exported="" name="appcompat-v7-21.0.0" level="project" /> |
||||
</component> |
||||
</module> |
||||
|
@ -0,0 +1,26 @@
|
||||
apply plugin: 'com.android.application' |
||||
|
||||
android { |
||||
compileSdkVersion 21 |
||||
buildToolsVersion "21.0.2" |
||||
|
||||
defaultConfig { |
||||
applicationId "co.zzyzx.session.skel" |
||||
minSdkVersion 15 |
||||
targetSdkVersion 21 |
||||
versionCode 1 |
||||
versionName "1.0" |
||||
} |
||||
buildTypes { |
||||
release { |
||||
runProguard false |
||||
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' |
||||
} |
||||
} |
||||
} |
||||
|
||||
dependencies { |
||||
compile fileTree(dir: 'libs', include: ['*.jar']) |
||||
compile 'com.google.android.gms:play-services:6.1.11' |
||||
compile 'com.android.support:appcompat-v7:21.0.0' |
||||
} |
@ -0,0 +1,17 @@
|
||||
# Add project specific ProGuard rules here. |
||||
# By default, the flags in this file are appended to flags specified |
||||
# in /usr/local/Cellar/android-sdk/23.0.2/tools/proguard/proguard-android.txt |
||||
# You can edit the include path and order by changing the proguardFiles |
||||
# directive in build.gradle. |
||||
# |
||||
# For more details, see |
||||
# http://developer.android.com/guide/developing/tools/proguard.html |
||||
|
||||
# Add any project specific keep options here: |
||||
|
||||
# If your project uses WebView with JS, uncomment the following |
||||
# and specify the fully qualified class name to the JavaScript interface |
||||
# class: |
||||
#-keepclassmembers class fqcn.of.javascript.interface.for.webview { |
||||
# public *; |
||||
#} |
@ -0,0 +1,13 @@
|
||||
package co.zzyzx.session.skel; |
||||
|
||||
import android.app.Application; |
||||
import android.test.ApplicationTestCase; |
||||
|
||||
/** |
||||
* <a href="http://d.android.com/tools/testing/testing_android.html">Testing Fundamentals</a> |
||||
*/ |
||||
public class ApplicationTest extends ApplicationTestCase<Application> { |
||||
public ApplicationTest() { |
||||
super(Application.class); |
||||
} |
||||
} |
@ -0,0 +1,31 @@
|
||||
<?xml version="1.0" encoding="utf-8"?> |
||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android" |
||||
package="co.zzyzx.session.skel" > |
||||
|
||||
<application |
||||
android:allowBackup="true" |
||||
android:icon="@drawable/ic_launcher" |
||||
android:label="@string/app_name" |
||||
android:theme="@style/AppTheme" |
||||
android:name="co.zzyzx.session.skel.App" > |
||||
<activity |
||||
android:name=".LoginActivity" |
||||
android:label="@string/app_name" |
||||
android:windowSoftInputMode="adjustResize|stateVisible" > |
||||
</activity> |
||||
<activity |
||||
android:name=".MainActivity" |
||||
android:label="@string/title_activity_main" > |
||||
<intent-filter> |
||||
<action android:name="android.intent.action.MAIN" /> |
||||
<category android:name="android.intent.category.LAUNCHER" /> |
||||
</intent-filter> |
||||
</activity> |
||||
</application> |
||||
|
||||
<!-- To auto-complete the email text field in the login form with the user's emails --> |
||||
<uses-permission android:name="android.permission.GET_ACCOUNTS" /> |
||||
<uses-permission android:name="android.permission.READ_PROFILE" /> |
||||
<uses-permission android:name="android.permission.READ_CONTACTS" /> |
||||
|
||||
</manifest> |
@ -0,0 +1,21 @@
|
||||
package co.zzyzx.session.skel; |
||||
|
||||
import android.app.Application; |
||||
|
||||
/** |
||||
* Created by sipp11 on 11/21/14. |
||||
*/ |
||||
public class App extends Application { |
||||
private static App singleton; |
||||
public String sessionToken = ""; |
||||
|
||||
public static App getInstance() { |
||||
return singleton; |
||||
} |
||||
|
||||
@Override |
||||
public void onCreate() { |
||||
super.onCreate(); |
||||
singleton = this; |
||||
} |
||||
} |
@ -0,0 +1,307 @@
|
||||
package co.zzyzx.session.skel; |
||||
|
||||
import android.animation.Animator; |
||||
import android.animation.AnimatorListenerAdapter; |
||||
import android.annotation.TargetApi; |
||||
import android.app.Activity; |
||||
import android.app.LoaderManager.LoaderCallbacks; |
||||
import android.content.ContentResolver; |
||||
import android.content.CursorLoader; |
||||
import android.content.Loader; |
||||
import android.database.Cursor; |
||||
import android.net.Uri; |
||||
import android.os.AsyncTask; |
||||
|
||||
import android.os.Build; |
||||
import android.os.Bundle; |
||||
import android.provider.ContactsContract; |
||||
import android.text.TextUtils; |
||||
import android.view.KeyEvent; |
||||
import android.view.View; |
||||
import android.view.View.OnClickListener; |
||||
import android.view.inputmethod.EditorInfo; |
||||
import android.widget.ArrayAdapter; |
||||
import android.widget.AutoCompleteTextView; |
||||
import android.widget.Button; |
||||
import android.widget.EditText; |
||||
import android.widget.TextView; |
||||
import java.util.ArrayList; |
||||
import java.util.List; |
||||
|
||||
|
||||
/** |
||||
* A login screen that offers login via email/password. |
||||
|
||||
*/ |
||||
public class LoginActivity extends Activity implements LoaderCallbacks<Cursor>{ |
||||
private App app; |
||||
/** |
||||
* A dummy authentication store containing known user names and passwords. |
||||
* TODO: remove after connecting to a real authentication system. |
||||
*/ |
||||
private static final String[] DUMMY_CREDENTIALS = new String[]{ |
||||
"foo@example.com:hello", "bar@example.com:world" |
||||
}; |
||||
/** |
||||
* Keep track of the login task to ensure we can cancel it if requested. |
||||
*/ |
||||
private UserLoginTask mAuthTask = null; |
||||
|
||||
// UI references.
|
||||
private AutoCompleteTextView mEmailView; |
||||
private EditText mPasswordView; |
||||
private View mProgressView; |
||||
private View mLoginFormView; |
||||
|
||||
@Override |
||||
protected void onCreate(Bundle savedInstanceState) { |
||||
super.onCreate(savedInstanceState); |
||||
app = App.getInstance(); |
||||
setContentView(R.layout.activity_login); |
||||
|
||||
// Set up the login form.
|
||||
mEmailView = (AutoCompleteTextView) findViewById(R.id.email); |
||||
populateAutoComplete(); |
||||
|
||||
mPasswordView = (EditText) findViewById(R.id.password); |
||||
mPasswordView.setOnEditorActionListener(new TextView.OnEditorActionListener() { |
||||
@Override |
||||
public boolean onEditorAction(TextView textView, int id, KeyEvent keyEvent) { |
||||
if (id == R.id.login || id == EditorInfo.IME_NULL) { |
||||
attemptLogin(); |
||||
return true; |
||||
} |
||||
return false; |
||||
} |
||||
}); |
||||
|
||||
Button mEmailSignInButton = (Button) findViewById(R.id.email_sign_in_button); |
||||
mEmailSignInButton.setOnClickListener(new OnClickListener() { |
||||
@Override |
||||
public void onClick(View view) { |
||||
attemptLogin(); |
||||
} |
||||
}); |
||||
|
||||
mLoginFormView = findViewById(R.id.login_form); |
||||
mProgressView = findViewById(R.id.login_progress); |
||||
} |
||||
|
||||
private void populateAutoComplete() { |
||||
getLoaderManager().initLoader(0, null, this); |
||||
} |
||||
|
||||
|
||||
/** |
||||
* Attempts to sign in or register the account specified by the login form. |
||||
* If there are form errors (invalid email, missing fields, etc.), the |
||||
* errors are presented and no actual login attempt is made. |
||||
*/ |
||||
public void attemptLogin() { |
||||
if (mAuthTask != null) { |
||||
return; |
||||
} |
||||
|
||||
// Reset errors.
|
||||
mEmailView.setError(null); |
||||
mPasswordView.setError(null); |
||||
|
||||
// Store values at the time of the login attempt.
|
||||
String email = mEmailView.getText().toString(); |
||||
String password = mPasswordView.getText().toString(); |
||||
|
||||
boolean cancel = false; |
||||
View focusView = null; |
||||
|
||||
|
||||
// Check for a valid password, if the user entered one.
|
||||
if (!TextUtils.isEmpty(password) && !isPasswordValid(password)) { |
||||
mPasswordView.setError(getString(R.string.error_invalid_password)); |
||||
focusView = mPasswordView; |
||||
cancel = true; |
||||
} |
||||
|
||||
// Check for a valid email address.
|
||||
if (TextUtils.isEmpty(email)) { |
||||
mEmailView.setError(getString(R.string.error_field_required)); |
||||
focusView = mEmailView; |
||||
cancel = true; |
||||
} else if (!isEmailValid(email)) { |
||||
mEmailView.setError(getString(R.string.error_invalid_email)); |
||||
focusView = mEmailView; |
||||
cancel = true; |
||||
} |
||||
|
||||
if (cancel) { |
||||
// There was an error; don't attempt login and focus the first
|
||||
// form field with an error.
|
||||
focusView.requestFocus(); |
||||
} else { |
||||
// Show a progress spinner, and kick off a background task to
|
||||
// perform the user login attempt.
|
||||
showProgress(true); |
||||
mAuthTask = new UserLoginTask(email, password); |
||||
mAuthTask.execute((Void) null); |
||||
} |
||||
} |
||||
private boolean isEmailValid(String email) { |
||||
//TODO: Replace this with your own logic
|
||||
return email.contains("@"); |
||||
} |
||||
|
||||
private boolean isPasswordValid(String password) { |
||||
//TODO: Replace this with your own logic
|
||||
return password.length() > 4; |
||||
} |
||||
|
||||
/** |
||||
* Shows the progress UI and hides the login form. |
||||
*/ |
||||
@TargetApi(Build.VERSION_CODES.HONEYCOMB_MR2) |
||||
public void showProgress(final boolean show) { |
||||
// On Honeycomb MR2 we have the ViewPropertyAnimator APIs, which allow
|
||||
// for very easy animations. If available, use these APIs to fade-in
|
||||
// the progress spinner.
|
||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB_MR2) { |
||||
int shortAnimTime = getResources().getInteger(android.R.integer.config_shortAnimTime); |
||||
|
||||
mLoginFormView.setVisibility(show ? View.GONE : View.VISIBLE); |
||||
mLoginFormView.animate().setDuration(shortAnimTime).alpha( |
||||
show ? 0 : 1).setListener(new AnimatorListenerAdapter() { |
||||
@Override |
||||
public void onAnimationEnd(Animator animation) { |
||||
mLoginFormView.setVisibility(show ? View.GONE : View.VISIBLE); |
||||
} |
||||
}); |
||||
|
||||
mProgressView.setVisibility(show ? View.VISIBLE : View.GONE); |
||||
mProgressView.animate().setDuration(shortAnimTime).alpha( |
||||
show ? 1 : 0).setListener(new AnimatorListenerAdapter() { |
||||
@Override |
||||
public void onAnimationEnd(Animator animation) { |
||||
mProgressView.setVisibility(show ? View.VISIBLE : View.GONE); |
||||
} |
||||
}); |
||||
} else { |
||||
// The ViewPropertyAnimator APIs are not available, so simply show
|
||||
// and hide the relevant UI components.
|
||||
mProgressView.setVisibility(show ? View.VISIBLE : View.GONE); |
||||
mLoginFormView.setVisibility(show ? View.GONE : View.VISIBLE); |
||||
} |
||||
} |
||||
|
||||
@Override |
||||
public Loader<Cursor> onCreateLoader(int i, Bundle bundle) { |
||||
return new CursorLoader(this, |
||||
// Retrieve data rows for the device user's 'profile' contact.
|
||||
Uri.withAppendedPath(ContactsContract.Profile.CONTENT_URI, |
||||
ContactsContract.Contacts.Data.CONTENT_DIRECTORY), ProfileQuery.PROJECTION, |
||||
|
||||
// Select only email addresses.
|
||||
ContactsContract.Contacts.Data.MIMETYPE + |
||||
" = ?", new String[]{ContactsContract.CommonDataKinds.Email |
||||
.CONTENT_ITEM_TYPE}, |
||||
|
||||
// Show primary email addresses first. Note that there won't be
|
||||
// a primary email address if the user hasn't specified one.
|
||||
ContactsContract.Contacts.Data.IS_PRIMARY + " DESC"); |
||||
} |
||||
|
||||
@Override |
||||
public void onLoadFinished(Loader<Cursor> cursorLoader, Cursor cursor) { |
||||
List<String> emails = new ArrayList<String>(); |
||||
cursor.moveToFirst(); |
||||
while (!cursor.isAfterLast()) { |
||||
emails.add(cursor.getString(ProfileQuery.ADDRESS)); |
||||
cursor.moveToNext(); |
||||
} |
||||
|
||||
addEmailsToAutoComplete(emails); |
||||
} |
||||
|
||||
@Override |
||||
public void onLoaderReset(Loader<Cursor> cursorLoader) { |
||||
|
||||
} |
||||
|
||||
private interface ProfileQuery { |
||||
String[] PROJECTION = { |
||||
ContactsContract.CommonDataKinds.Email.ADDRESS, |
||||
ContactsContract.CommonDataKinds.Email.IS_PRIMARY, |
||||
}; |
||||
|
||||
int ADDRESS = 0; |
||||
int IS_PRIMARY = 1; |
||||
} |
||||
|
||||
|
||||
private void addEmailsToAutoComplete(List<String> emailAddressCollection) { |
||||
//Create adapter to tell the AutoCompleteTextView what to show in its dropdown list.
|
||||
ArrayAdapter<String> adapter = |
||||
new ArrayAdapter<String>(LoginActivity.this, |
||||
android.R.layout.simple_dropdown_item_1line, emailAddressCollection); |
||||
|
||||
mEmailView.setAdapter(adapter); |
||||
} |
||||
|
||||
/** |
||||
* Represents an asynchronous login/registration task used to authenticate |
||||
* the user. |
||||
*/ |
||||
public class UserLoginTask extends AsyncTask<Void, Void, Boolean> { |
||||
|
||||
private final String mEmail; |
||||
private final String mPassword; |
||||
|
||||
UserLoginTask(String email, String password) { |
||||
mEmail = email; |
||||
mPassword = password; |
||||
} |
||||
|
||||
@Override |
||||
protected Boolean doInBackground(Void... params) { |
||||
// TODO: attempt authentication against a network service.
|
||||
|
||||
try { |
||||
// Simulate network access.
|
||||
Thread.sleep(2000); |
||||
} catch (InterruptedException e) { |
||||
return false; |
||||
} |
||||
|
||||
for (String credential : DUMMY_CREDENTIALS) { |
||||
String[] pieces = credential.split(":"); |
||||
if (pieces[0].equals(mEmail)) { |
||||
// Account exists, return true if the password matches.
|
||||
return pieces[1].equals(mPassword); |
||||
} |
||||
} |
||||
|
||||
// TODO: register the new account here.
|
||||
return true; |
||||
} |
||||
|
||||
@Override |
||||
protected void onPostExecute(final Boolean success) { |
||||
mAuthTask = null; |
||||
showProgress(false); |
||||
|
||||
if (success) { |
||||
app.sessionToken = "ok"; |
||||
finish(); |
||||
} else { |
||||
mPasswordView.setError(getString(R.string.error_incorrect_password)); |
||||
mPasswordView.requestFocus(); |
||||
} |
||||
} |
||||
|
||||
@Override |
||||
protected void onCancelled() { |
||||
mAuthTask = null; |
||||
showProgress(false); |
||||
} |
||||
} |
||||
} |
||||
|
||||
|
||||
|
@ -0,0 +1,46 @@
|
||||
package co.zzyzx.session.skel; |
||||
|
||||
import android.app.Activity; |
||||
import android.content.Intent; |
||||
import android.os.Bundle; |
||||
import android.view.Menu; |
||||
import android.view.MenuItem; |
||||
|
||||
|
||||
public class MainActivity extends Activity { |
||||
private App app; |
||||
|
||||
@Override |
||||
protected void onCreate(Bundle savedInstanceState) { |
||||
super.onCreate(savedInstanceState); |
||||
setContentView(R.layout.activity_main); |
||||
app = App.getInstance(); |
||||
|
||||
// opening up login
|
||||
if (app.sessionToken.isEmpty()) { |
||||
Intent intent = new Intent(this, LoginActivity.class); |
||||
startActivity(intent); |
||||
} |
||||
|
||||
} |
||||
|
||||
|
||||
@Override |
||||
public boolean onCreateOptionsMenu(Menu menu) { |
||||
// Inflate the menu; this adds items to the action bar if it is present.
|
||||
getMenuInflater().inflate(R.menu.main, menu); |
||||
return true; |
||||
} |
||||
|
||||
@Override |
||||
public boolean onOptionsItemSelected(MenuItem item) { |
||||
// Handle action bar item clicks here. The action bar will
|
||||
// automatically handle clicks on the Home/Up button, so long
|
||||
// as you specify a parent activity in AndroidManifest.xml.
|
||||
int id = item.getItemId(); |
||||
if (id == R.id.action_settings) { |
||||
return true; |
||||
} |
||||
return super.onOptionsItemSelected(item); |
||||
} |
||||
} |
After Width: | Height: | Size: 9.2 KiB |
After Width: | Height: | Size: 5.1 KiB |
After Width: | Height: | Size: 14 KiB |
After Width: | Height: | Size: 19 KiB |
@ -0,0 +1,70 @@
|
||||
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" |
||||
xmlns:tools="http://schemas.android.com/tools" |
||||
android:layout_width="match_parent" |
||||
android:layout_height="match_parent" |
||||
android:gravity="center_horizontal" |
||||
android:orientation="vertical" |
||||
android:paddingBottom="@dimen/activity_vertical_margin" |
||||
android:paddingLeft="@dimen/activity_horizontal_margin" |
||||
android:paddingRight="@dimen/activity_horizontal_margin" |
||||
android:paddingTop="@dimen/activity_vertical_margin" |
||||
tools:context=".LoginActivity"> |
||||
|
||||
<!-- Login progress --> |
||||
<ProgressBar |
||||
android:id="@+id/login_progress" |
||||
style="?android:attr/progressBarStyleLarge" |
||||
android:layout_width="wrap_content" |
||||
android:layout_height="wrap_content" |
||||
android:layout_marginBottom="8dp" |
||||
android:visibility="gone"/> |
||||
|
||||
<ScrollView |
||||
android:id="@+id/login_form" |
||||
android:layout_width="match_parent" |
||||
android:layout_height="match_parent" |
||||
> |
||||
|
||||
<LinearLayout |
||||
android:id="@+id/email_login_form" |
||||
android:layout_width="match_parent" |
||||
android:layout_height="wrap_content" |
||||
android:orientation="vertical"> |
||||
|
||||
<AutoCompleteTextView |
||||
android:id="@+id/email" |
||||
android:layout_width="match_parent" |
||||
android:layout_height="wrap_content" |
||||
android:hint="@string/prompt_email" |
||||
android:inputType="textEmailAddress" |
||||
android:maxLines="1" |
||||
android:singleLine="true"/> |
||||
|
||||
<EditText |
||||
android:id="@+id/password" |
||||
android:layout_width="match_parent" |
||||
android:layout_height="wrap_content" |
||||
android:hint="@string/prompt_password" |
||||
android:imeActionId="@+id/login" |
||||
android:imeActionLabel="@string/action_sign_in_short" |
||||
android:imeOptions="actionUnspecified" |
||||
android:inputType="textPassword" |
||||
android:maxLines="1" |
||||
android:singleLine="true"/> |
||||
|
||||
<Button |
||||
android:id="@+id/email_sign_in_button" |
||||
style="?android:textAppearanceSmall" |
||||
android:layout_width="match_parent" |
||||
android:layout_height="wrap_content" |
||||
android:layout_marginTop="16dp" |
||||
android:text="@string/action_sign_in" |
||||
android:textStyle="bold"/> |
||||
|
||||
</LinearLayout> |
||||
</ScrollView> |
||||
|
||||
</LinearLayout> |
||||
|
||||
|
||||
|
@ -0,0 +1,16 @@
|
||||
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" |
||||
xmlns:tools="http://schemas.android.com/tools" |
||||
android:layout_width="match_parent" |
||||
android:layout_height="match_parent" |
||||
android:paddingLeft="@dimen/activity_horizontal_margin" |
||||
android:paddingRight="@dimen/activity_horizontal_margin" |
||||
android:paddingTop="@dimen/activity_vertical_margin" |
||||
android:paddingBottom="@dimen/activity_vertical_margin" |
||||
tools:context="co.zzyzx.session.skel.MainActivity"> |
||||
|
||||
<TextView |
||||
android:text="@string/hello_world" |
||||
android:layout_width="wrap_content" |
||||
android:layout_height="wrap_content" /> |
||||
|
||||
</RelativeLayout> |
@ -0,0 +1,8 @@
|
||||
<menu xmlns:android="http://schemas.android.com/apk/res/android" |
||||
xmlns:tools="http://schemas.android.com/tools" |
||||
tools:context="co.zzyzx.session.skel.MainActivity" > |
||||
<item android:id="@+id/action_settings" |
||||
android:title="@string/action_settings" |
||||
android:orderInCategory="100" |
||||
android:showAsAction="never" /> |
||||
</menu> |
@ -0,0 +1,5 @@
|
||||
<?xml version="1.0" encoding="utf-8"?> |
||||
<resources> |
||||
<style name="AppTheme" parent="android:Theme.Material.Light"> |
||||
</style> |
||||
</resources> |
@ -0,0 +1,6 @@
|
||||
<resources> |
||||
<!-- Example customization of dimensions originally defined in res/values/dimens.xml |
||||
(such as screen margins) for screens with more than 820dp of available width. This |
||||
would include 7" and 10" devices in landscape (~960dp and ~1280dp respectively). --> |
||||
<dimen name="activity_horizontal_margin">64dp</dimen> |
||||
</resources> |
@ -0,0 +1,5 @@
|
||||
<resources> |
||||
<!-- Default screen margins, per the Android Design guidelines. --> |
||||
<dimen name="activity_horizontal_margin">16dp</dimen> |
||||
<dimen name="activity_vertical_margin">16dp</dimen> |
||||
</resources> |
@ -0,0 +1,9 @@
|
||||
<?xml version="1.0" encoding="utf-8"?> |
||||
<resources> |
||||
|
||||
<string name="app_name">SessionSkeleton</string> |
||||
<string name="title_activity_main">MainActivity</string> |
||||
<string name="hello_world">Hello world!</string> |
||||
<string name="action_settings">Settings</string> |
||||
|
||||
</resources> |
@ -0,0 +1,13 @@
|
||||
<resources> |
||||
|
||||
<!-- Strings related to login --> |
||||
<string name="prompt_email">Email</string> |
||||
<string name="prompt_password">Password (optional)</string> |
||||
<string name="action_sign_in">Sign in or register</string> |
||||
<string name="action_sign_in_short">Sign in</string> |
||||
|
||||
<string name="error_invalid_email">This email address is invalid</string> |
||||
<string name="error_invalid_password">This password is too short</string> |
||||
<string name="error_incorrect_password">This password is incorrect</string> |
||||
<string name="error_field_required">This field is required</string> |
||||
</resources> |
@ -0,0 +1,8 @@
|
||||
<resources> |
||||
|
||||
<!-- Base application theme. --> |
||||
<style name="AppTheme" parent="android:Theme.Holo.Light.DarkActionBar"> |
||||
<!-- Customize your theme here. --> |
||||
</style> |
||||
|
||||
</resources> |
@ -0,0 +1,19 @@
|
||||
// Top-level build file where you can add configuration options common to all sub-projects/modules. |
||||
|
||||
buildscript { |
||||
repositories { |
||||
jcenter() |
||||
} |
||||
dependencies { |
||||
classpath 'com.android.tools.build:gradle:0.12.2' |
||||
|
||||
// NOTE: Do not place your application dependencies here; they belong |
||||
// in the individual module build.gradle files |
||||
} |
||||
} |
||||
|
||||
allprojects { |
||||
repositories { |
||||
jcenter() |
||||
} |
||||
} |
@ -0,0 +1,18 @@
|
||||
# Project-wide Gradle settings. |
||||
|
||||
# IDE (e.g. Android Studio) users: |
||||
# Settings specified in this file will override any Gradle settings |
||||
# configured through the IDE. |
||||
|
||||
# For more details on how to configure your build environment visit |
||||
# http://www.gradle.org/docs/current/userguide/build_environment.html |
||||
|
||||
# Specifies the JVM arguments used for the daemon process. |
||||
# The setting is particularly useful for tweaking memory settings. |
||||
# Default value: -Xmx10248m -XX:MaxPermSize=256m |
||||
# org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8 |
||||
|
||||
# When configured, Gradle will run in incubating parallel mode. |
||||
# This option should only be used with decoupled projects. More details, visit |
||||
# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects |
||||
# org.gradle.parallel=true |
Binary file not shown.
@ -0,0 +1,6 @@
|
||||
#Wed Apr 10 15:27:10 PDT 2013 |
||||
distributionBase=GRADLE_USER_HOME |
||||
distributionPath=wrapper/dists |
||||
zipStoreBase=GRADLE_USER_HOME |
||||
zipStorePath=wrapper/dists |
||||
distributionUrl=http\://services.gradle.org/distributions/gradle-1.12-all.zip |
@ -0,0 +1,164 @@
|
||||
#!/usr/bin/env bash |
||||
|
||||
############################################################################## |
||||
## |
||||
## Gradle start up script for UN*X |
||||
## |
||||
############################################################################## |
||||
|
||||
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. |
||||
DEFAULT_JVM_OPTS="" |
||||
|
||||
APP_NAME="Gradle" |
||||
APP_BASE_NAME=`basename "$0"` |
||||
|
||||
# Use the maximum available, or set MAX_FD != -1 to use that value. |
||||
MAX_FD="maximum" |
||||
|
||||
warn ( ) { |
||||
echo "$*" |
||||
} |
||||
|
||||
die ( ) { |
||||
echo |
||||
echo "$*" |
||||
echo |
||||
exit 1 |
||||
} |
||||
|
||||
# OS specific support (must be 'true' or 'false'). |
||||
cygwin=false |
||||
msys=false |
||||
darwin=false |
||||
case "`uname`" in |
||||
CYGWIN* ) |
||||
cygwin=true |
||||
;; |
||||
Darwin* ) |
||||
darwin=true |
||||
;; |
||||
MINGW* ) |
||||
msys=true |
||||
;; |
||||
esac |
||||
|
||||
# For Cygwin, ensure paths are in UNIX format before anything is touched. |
||||
if $cygwin ; then |
||||
[ -n "$JAVA_HOME" ] && JAVA_HOME=`cygpath --unix "$JAVA_HOME"` |
||||
fi |
||||
|
||||
# Attempt to set APP_HOME |
||||
# Resolve links: $0 may be a link |
||||
PRG="$0" |
||||
# Need this for relative symlinks. |
||||
while [ -h "$PRG" ] ; do |
||||
ls=`ls -ld "$PRG"` |
||||
link=`expr "$ls" : '.*-> \(.*\)$'` |
||||
if expr "$link" : '/.*' > /dev/null; then |
||||
PRG="$link" |
||||
else |
||||
PRG=`dirname "$PRG"`"/$link" |
||||
fi |
||||
done |
||||
SAVED="`pwd`" |
||||
cd "`dirname \"$PRG\"`/" >&- |
||||
APP_HOME="`pwd -P`" |
||||
cd "$SAVED" >&- |
||||
|
||||
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar |
||||
|
||||
# Determine the Java command to use to start the JVM. |
||||
if [ -n "$JAVA_HOME" ] ; then |
||||
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then |
||||
# IBM's JDK on AIX uses strange locations for the executables |
||||
JAVACMD="$JAVA_HOME/jre/sh/java" |
||||
else |
||||
JAVACMD="$JAVA_HOME/bin/java" |
||||
fi |
||||
if [ ! -x "$JAVACMD" ] ; then |
||||
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME |
||||
|
||||
Please set the JAVA_HOME variable in your environment to match the |
||||
location of your Java installation." |
||||
fi |
||||
else |
||||
JAVACMD="java" |
||||
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. |
||||
|
||||
Please set the JAVA_HOME variable in your environment to match the |
||||
location of your Java installation." |
||||
fi |
||||
|
||||
# Increase the maximum file descriptors if we can. |
||||
if [ "$cygwin" = "false" -a "$darwin" = "false" ] ; then |
||||
MAX_FD_LIMIT=`ulimit -H -n` |
||||
if [ $? -eq 0 ] ; then |
||||
if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then |
||||
MAX_FD="$MAX_FD_LIMIT" |
||||
fi |
||||
ulimit -n $MAX_FD |
||||
if [ $? -ne 0 ] ; then |
||||
warn "Could not set maximum file descriptor limit: $MAX_FD" |
||||
fi |
||||
else |
||||
warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT" |
||||
fi |
||||
fi |
||||
|
||||
# For Darwin, add options to specify how the application appears in the dock |
||||
if $darwin; then |
||||
GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" |
||||
fi |
||||
|
||||
# For Cygwin, switch paths to Windows format before running java |
||||
if $cygwin ; then |
||||
APP_HOME=`cygpath --path --mixed "$APP_HOME"` |
||||
CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` |
||||
|
||||
# We build the pattern for arguments to be converted via cygpath |
||||
ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` |
||||
SEP="" |
||||
for dir in $ROOTDIRSRAW ; do |
||||
ROOTDIRS="$ROOTDIRS$SEP$dir" |
||||
SEP="|" |
||||
done |
||||
OURCYGPATTERN="(^($ROOTDIRS))" |
||||
# Add a user-defined pattern to the cygpath arguments |
||||
if [ "$GRADLE_CYGPATTERN" != "" ] ; then |
||||
OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)" |
||||
fi |
||||
# Now convert the arguments - kludge to limit ourselves to /bin/sh |
||||
i=0 |
||||
for arg in "$@" ; do |
||||
CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -` |
||||
CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option |
||||
|
||||
if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition |
||||
eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"` |
||||
else |
||||
eval `echo args$i`="\"$arg\"" |
||||
fi |
||||
i=$((i+1)) |
||||
done |
||||
case $i in |
||||
(0) set -- ;; |
||||
(1) set -- "$args0" ;; |
||||
(2) set -- "$args0" "$args1" ;; |
||||
(3) set -- "$args0" "$args1" "$args2" ;; |
||||
(4) set -- "$args0" "$args1" "$args2" "$args3" ;; |
||||
(5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; |
||||
(6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; |
||||
(7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; |
||||
(8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; |
||||
(9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; |
||||
esac |
||||
fi |
||||
|
||||
# Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules |
||||
function splitJvmOpts() { |
||||
JVM_OPTS=("$@") |
||||
} |
||||
eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS |
||||
JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME" |
||||
|
||||
exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@" |
@ -0,0 +1,90 @@
|
||||
@if "%DEBUG%" == "" @echo off |
||||
@rem ########################################################################## |
||||
@rem |
||||
@rem Gradle startup script for Windows |
||||
@rem |
||||
@rem ########################################################################## |
||||
|
||||
@rem Set local scope for the variables with windows NT shell |
||||
if "%OS%"=="Windows_NT" setlocal |
||||
|
||||
@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. |
||||
set DEFAULT_JVM_OPTS= |
||||
|
||||
set DIRNAME=%~dp0 |
||||
if "%DIRNAME%" == "" set DIRNAME=. |
||||
set APP_BASE_NAME=%~n0 |
||||
set APP_HOME=%DIRNAME% |
||||
|
||||
@rem Find java.exe |
||||
if defined JAVA_HOME goto findJavaFromJavaHome |
||||
|
||||
set JAVA_EXE=java.exe |
||||
%JAVA_EXE% -version >NUL 2>&1 |
||||
if "%ERRORLEVEL%" == "0" goto init |
||||
|
||||
echo. |
||||
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. |
||||
echo. |
||||
echo Please set the JAVA_HOME variable in your environment to match the |
||||
echo location of your Java installation. |
||||
|
||||
goto fail |
||||
|
||||
:findJavaFromJavaHome |
||||
set JAVA_HOME=%JAVA_HOME:"=% |
||||
set JAVA_EXE=%JAVA_HOME%/bin/java.exe |
||||
|
||||
if exist "%JAVA_EXE%" goto init |
||||
|
||||
echo. |
||||
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% |
||||
echo. |
||||
echo Please set the JAVA_HOME variable in your environment to match the |
||||
echo location of your Java installation. |
||||
|
||||
goto fail |
||||
|
||||
:init |
||||
@rem Get command-line arguments, handling Windowz variants |
||||
|
||||
if not "%OS%" == "Windows_NT" goto win9xME_args |
||||
if "%@eval[2+2]" == "4" goto 4NT_args |
||||
|
||||
:win9xME_args |
||||
@rem Slurp the command line arguments. |
||||
set CMD_LINE_ARGS= |
||||
set _SKIP=2 |
||||
|
||||
:win9xME_args_slurp |
||||
if "x%~1" == "x" goto execute |
||||
|
||||
set CMD_LINE_ARGS=%* |
||||
goto execute |
||||
|
||||
:4NT_args |
||||
@rem Get arguments from the 4NT Shell from JP Software |
||||
set CMD_LINE_ARGS=%$ |
||||
|
||||
:execute |
||||
@rem Setup the command line |
||||
|
||||
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar |
||||
|
||||
@rem Execute Gradle |
||||
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS% |
||||
|
||||
:end |
||||
@rem End local scope for the variables with windows NT shell |
||||
if "%ERRORLEVEL%"=="0" goto mainEnd |
||||
|
||||
:fail |
||||
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of |
||||
rem the _cmd.exe /c_ return code! |
||||
if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 |
||||
exit /b 1 |
||||
|
||||
:mainEnd |
||||
if "%OS%"=="Windows_NT" endlocal |
||||
|
||||
:omega |
Loading…
Reference in new issue