diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..39fb081 --- /dev/null +++ b/.gitignore @@ -0,0 +1,9 @@ +*.iml +.gradle +/local.properties +/.idea/workspace.xml +/.idea/libraries +.DS_Store +/build +/captures +.externalNativeBuild diff --git a/.idea/compiler.xml b/.idea/compiler.xml new file mode 100644 index 0000000..96cc43e --- /dev/null +++ b/.idea/compiler.xml @@ -0,0 +1,22 @@ + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/.idea/copyright/profiles_settings.xml b/.idea/copyright/profiles_settings.xml new file mode 100644 index 0000000..e7bedf3 --- /dev/null +++ b/.idea/copyright/profiles_settings.xml @@ -0,0 +1,3 @@ + + + \ No newline at end of file diff --git a/.idea/dictionaries/hendi.xml b/.idea/dictionaries/hendi.xml new file mode 100644 index 0000000..6d23e5e --- /dev/null +++ b/.idea/dictionaries/hendi.xml @@ -0,0 +1,7 @@ + + + + hendiware + + + \ No newline at end of file diff --git a/.idea/gradle.xml b/.idea/gradle.xml new file mode 100644 index 0000000..7ac24c7 --- /dev/null +++ b/.idea/gradle.xml @@ -0,0 +1,18 @@ + + + + + + \ No newline at end of file diff --git a/.idea/misc.xml b/.idea/misc.xml new file mode 100644 index 0000000..5d19981 --- /dev/null +++ b/.idea/misc.xml @@ -0,0 +1,46 @@ + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/.idea/modules.xml b/.idea/modules.xml new file mode 100644 index 0000000..25385f9 --- /dev/null +++ b/.idea/modules.xml @@ -0,0 +1,9 @@ + + + + + + + + + \ No newline at end of file diff --git a/.idea/runConfigurations.xml b/.idea/runConfigurations.xml new file mode 100644 index 0000000..7f68460 --- /dev/null +++ b/.idea/runConfigurations.xml @@ -0,0 +1,12 @@ + + + + + + \ No newline at end of file diff --git a/app/.gitignore b/app/.gitignore new file mode 100644 index 0000000..796b96d --- /dev/null +++ b/app/.gitignore @@ -0,0 +1 @@ +/build diff --git a/app/build.gradle b/app/build.gradle new file mode 100644 index 0000000..49b8175 --- /dev/null +++ b/app/build.gradle @@ -0,0 +1,38 @@ +apply plugin: 'com.android.application' + +android { + compileSdkVersion 24 + buildToolsVersion "24.0.3" + defaultConfig { + applicationId "com.hendiware.hendienger" + minSdkVersion 15 + targetSdkVersion 24 + versionCode 1 + versionName "1.0" + testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" + } + buildTypes { + release { + minifyEnabled false + proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' + } + } +} + +dependencies { + compile fileTree(include: ['*.jar'], dir: 'libs') + androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', { + exclude group: 'com.android.support', module: 'support-annotations' + }) + compile 'com.android.support:appcompat-v7:24.2.1' + testCompile 'junit:junit:4.12' + compile 'com.android.support:design:24.2.1' + compile 'com.hendiware.utils:futils:1.6.91' + compile 'com.jakewharton:butterknife:8.4.0' + annotationProcessor 'com.jakewharton:butterknife-compiler:8.4.0' + compile 'com.squareup.retrofit2:retrofit:2.1.0' + compile 'com.squareup.retrofit2:converter-gson:2.1.0' + + +} +apply plugin: 'com.jakewharton.butterknife' \ No newline at end of file diff --git a/app/proguard-rules.pro b/app/proguard-rules.pro new file mode 100644 index 0000000..c129186 --- /dev/null +++ b/app/proguard-rules.pro @@ -0,0 +1,17 @@ +# Add project specific ProGuard rules here. +# By default, the flags in this file are appended to flags specified +# in /Volumes/Data/AndroidSdk/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 *; +#} diff --git a/app/src/androidTest/java/com/hendiware/hendienger/ExampleInstrumentedTest.java b/app/src/androidTest/java/com/hendiware/hendienger/ExampleInstrumentedTest.java new file mode 100644 index 0000000..6f3a801 --- /dev/null +++ b/app/src/androidTest/java/com/hendiware/hendienger/ExampleInstrumentedTest.java @@ -0,0 +1,26 @@ +package com.hendiware.hendienger; + +import android.content.Context; +import android.support.test.InstrumentationRegistry; +import android.support.test.runner.AndroidJUnit4; + +import org.junit.Test; +import org.junit.runner.RunWith; + +import static org.junit.Assert.*; + +/** + * Instrumentation test, which will execute on an Android device. + * + * @see Testing documentation + */ +@RunWith(AndroidJUnit4.class) +public class ExampleInstrumentedTest { + @Test + public void useAppContext() throws Exception { + // Context of the app under test. + Context appContext = InstrumentationRegistry.getTargetContext(); + + assertEquals("com.hendiware.hendienger", appContext.getPackageName()); + } +} diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml new file mode 100644 index 0000000..67b99d1 --- /dev/null +++ b/app/src/main/AndroidManifest.xml @@ -0,0 +1,32 @@ + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/java/com/hendiware/hendienger/LoginActivity.java b/app/src/main/java/com/hendiware/hendienger/LoginActivity.java new file mode 100644 index 0000000..db2ec8b --- /dev/null +++ b/app/src/main/java/com/hendiware/hendienger/LoginActivity.java @@ -0,0 +1,130 @@ +package com.hendiware.hendienger; + +import android.content.Intent; +import android.os.Bundle; +import android.support.v7.app.AppCompatActivity; +import android.util.Log; +import android.view.View; +import android.widget.Button; +import android.widget.EditText; +import android.widget.ImageView; +import android.widget.LinearLayout; +import android.widget.ProgressBar; +import android.widget.RelativeLayout; +import android.widget.TextView; +import android.widget.Toast; + +import com.fourhcode.forhutils.FUtilsValidation; +import com.hendiware.hendienger.models.MainResponse; +import com.hendiware.hendienger.models.User; +import com.hendiware.hendienger.webservices.WebService; + +import butterknife.BindView; +import butterknife.ButterKnife; +import butterknife.OnClick; +import retrofit2.Call; +import retrofit2.Callback; +import retrofit2.Response; + +public class LoginActivity extends AppCompatActivity { + private final String TAG = "LoginActivity"; + + @BindView(R.id.img_header_logo) + ImageView imgHeaderLogo; + @BindView(R.id.tv_login) + TextView tvLogin; + @BindView(R.id.et_email) + EditText etEmail; + @BindView(R.id.et_password) + EditText etPassword; + @BindView(R.id.lnlt_inputs_container) + LinearLayout lnltInputsContainer; + @BindView(R.id.tv_dont_have_account) + TextView tvDontHaveAccount; + @BindView(R.id.btn_login) + Button btnLogin; + @BindView(R.id.rllt_body) + RelativeLayout rlltBody; + @BindView(R.id.prgs_loading) + ProgressBar prgsLoading; + @BindView(R.id.rllt_loading) + RelativeLayout rlltLoading; + @BindView(R.id.activity_login) + RelativeLayout activityLogin; + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setContentView(R.layout.activity_login); + ButterKnife.bind(this); + } + + @OnClick({R.id.tv_dont_have_account, R.id.btn_login}) + public void onClick(View view) { + switch (view.getId()) { + case R.id.tv_dont_have_account: + Intent intent = new Intent(this, RegisterActivity.class); + intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP); + startActivity(intent); + // override default transation of activity + this.overridePendingTransition(R.anim.enter_from_left, R.anim.exit_out_right); + + break; + case R.id.btn_login: + + if (!FUtilsValidation.isEmpty(etEmail, getString(R.string.enter_email)) + && FUtilsValidation.isValidEmail(etEmail, getString(R.string.enter_valid_email)) + && !FUtilsValidation.isEmpty(etPassword, getString(R.string.enter_password)) + ) { + setLoadingMode(); + // create new user + User user = new User(); + user.email = etEmail.getText().toString(); + user.password = etPassword.getText().toString(); + // login User using Retrofit + WebService.getInstance().getApi().loginUser(user).enqueue(new Callback() { + @Override + public void onResponse(Call call, Response response) { + // check for status value comming from server (response of login-user.php file status) + if (response.body().status == 2) { + Toast.makeText(LoginActivity.this, response.body().message, Toast.LENGTH_SHORT).show(); + + } else if (response.body().status == 1) { + Toast.makeText(LoginActivity.this, response.body().message, Toast.LENGTH_SHORT).show(); + Intent goToMain = new Intent(LoginActivity.this, MainActivity.class); + startActivity(goToMain); + finish(); + + } else { + Toast.makeText(LoginActivity.this, response.body().message, Toast.LENGTH_SHORT).show(); + } + setNormalMode(); + } + + @Override + public void onFailure(Call call, Throwable t) { + // print error message in logcat + Log.e(TAG, t.getLocalizedMessage()); + + } + }); + + + } + break; + + } + } + + // set loading layout visible and hide body layout + private void setLoadingMode() { + rlltLoading.setVisibility(View.VISIBLE); + rlltBody.setVisibility(View.GONE); + } + + // set body layout visible and hide loading layout + private void setNormalMode() { + rlltLoading.setVisibility(View.GONE); + rlltBody.setVisibility(View.VISIBLE); + } +} diff --git a/app/src/main/java/com/hendiware/hendienger/MainActivity.java b/app/src/main/java/com/hendiware/hendienger/MainActivity.java new file mode 100644 index 0000000..e620701 --- /dev/null +++ b/app/src/main/java/com/hendiware/hendienger/MainActivity.java @@ -0,0 +1,19 @@ +package com.hendiware.hendienger; + +import android.os.Bundle; +import android.support.v7.app.AppCompatActivity; +import android.support.v7.widget.Toolbar; + +public class MainActivity extends AppCompatActivity { + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setContentView(R.layout.activity_main); + Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); + setSupportActionBar(toolbar); + + + } + +} diff --git a/app/src/main/java/com/hendiware/hendienger/RegisterActivity.java b/app/src/main/java/com/hendiware/hendienger/RegisterActivity.java new file mode 100644 index 0000000..520c401 --- /dev/null +++ b/app/src/main/java/com/hendiware/hendienger/RegisterActivity.java @@ -0,0 +1,132 @@ +package com.hendiware.hendienger; + +import android.content.Intent; +import android.os.Bundle; +import android.support.v7.app.AppCompatActivity; +import android.util.Log; +import android.view.View; +import android.widget.Button; +import android.widget.EditText; +import android.widget.ImageView; +import android.widget.LinearLayout; +import android.widget.ProgressBar; +import android.widget.RelativeLayout; +import android.widget.TextView; +import android.widget.Toast; + +import com.fourhcode.forhutils.FUtilsValidation; +import com.hendiware.hendienger.models.MainResponse; +import com.hendiware.hendienger.models.User; +import com.hendiware.hendienger.webservices.WebService; + +import butterknife.BindView; +import butterknife.ButterKnife; +import butterknife.OnClick; +import retrofit2.Call; +import retrofit2.Callback; +import retrofit2.Response; + +public class RegisterActivity extends AppCompatActivity { + private final String TAG = "RegisterActivity"; + @BindView(R.id.img_header_logo) + ImageView imgHeaderLogo; + @BindView(R.id.tv_login) + TextView tvLogin; + @BindView(R.id.et_username) + EditText etUsername; + @BindView(R.id.et_email) + EditText etEmail; + @BindView(R.id.et_password) + EditText etPassword; + @BindView(R.id.et_repeat_password) + EditText etRepeatPassword; + @BindView(R.id.lnlt_inputs_container) + LinearLayout lnltInputsContainer; + @BindView(R.id.tv_already_have_account) + TextView tvAlreadyHaveAccount; + @BindView(R.id.btn_signup) + Button btnSignup; + @BindView(R.id.rllt_body) + RelativeLayout rlltBody; + @BindView(R.id.prgs_loading) + ProgressBar prgsLoading; + @BindView(R.id.rllt_loading) + RelativeLayout rlltLoading; + @BindView(R.id.activity_login) + RelativeLayout activityLogin; + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setContentView(R.layout.activity_register); + ButterKnife.bind(this); + + + } + + @OnClick({R.id.tv_already_have_account, R.id.btn_signup}) + public void onClick(View view) { + switch (view.getId()) { + case R.id.tv_already_have_account: + Intent intent = new Intent(this, LoginActivity.class); + intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP); + startActivity(intent); + this.overridePendingTransition(R.anim.enter_from_right, R.anim.exit_out_left); + + break; + case R.id.btn_signup: + if (!FUtilsValidation.isEmpty(etUsername, getString(R.string.enter_username)) + && !FUtilsValidation.isEmpty(etEmail, getString(R.string.enter_email)) + && FUtilsValidation.isValidEmail(etEmail, getString(R.string.enter_valid_email)) + && !FUtilsValidation.isEmpty(etPassword, getString(R.string.enter_password)) + && !FUtilsValidation.isEmpty(etRepeatPassword, getString(R.string.enter_password_again)) + && FUtilsValidation.isPasswordEqual(etPassword, etRepeatPassword, getString(R.string.password_isnt_equal)) + ) { + setLoadingMode(); + // create new user object and set data from editTexts + User user = new User(); + user.username = etUsername.getText().toString(); + user.email = etEmail.getText().toString(); + user.password = etPassword.getText().toString(); + // register user with retorfit + WebService.getInstance().getApi().registerUser(user).enqueue(new Callback() { + @Override + public void onResponse(Call call, Response response) { + if (response.body().status == 2) { + Toast.makeText(RegisterActivity.this, response.body().message, Toast.LENGTH_SHORT).show(); + } else if (response.body().status == 1) { + Toast.makeText(RegisterActivity.this, response.body().message, Toast.LENGTH_SHORT).show(); + Intent goToMain = new Intent(RegisterActivity.this, MainActivity.class); + startActivity(goToMain); + finish(); + } else { + Toast.makeText(RegisterActivity.this, response.body().message, Toast.LENGTH_SHORT).show(); + } + setNormalMode(); + } + + @Override + public void onFailure(Call call, Throwable t) { + Log.e(TAG, t.getLocalizedMessage()); + + } + }); + + + } + break; + } + } + + // set loading layout visible and hide body layout + private void setLoadingMode() { + rlltLoading.setVisibility(View.VISIBLE); + rlltBody.setVisibility(View.GONE); + } + + // set body layout visible and hide loading layout + private void setNormalMode() { + rlltLoading.setVisibility(View.GONE); + rlltBody.setVisibility(View.VISIBLE); + } +} diff --git a/app/src/main/java/com/hendiware/hendienger/SplashActivity.java b/app/src/main/java/com/hendiware/hendienger/SplashActivity.java new file mode 100644 index 0000000..63aeaf1 --- /dev/null +++ b/app/src/main/java/com/hendiware/hendienger/SplashActivity.java @@ -0,0 +1,17 @@ +package com.hendiware.hendienger; + +import android.content.Intent; +import android.os.Bundle; +import android.support.v7.app.AppCompatActivity; + +public class SplashActivity extends AppCompatActivity { + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setContentView(R.layout.activity_splash); + Intent intent = new Intent(this, LoginActivity.class); + startActivity(intent); + finish(); + } +} diff --git a/app/src/main/java/com/hendiware/hendienger/models/MainResponse.java b/app/src/main/java/com/hendiware/hendienger/models/MainResponse.java new file mode 100644 index 0000000..fc6ebb0 --- /dev/null +++ b/app/src/main/java/com/hendiware/hendienger/models/MainResponse.java @@ -0,0 +1,15 @@ +package com.hendiware.hendienger.models; + +import com.google.gson.annotations.SerializedName; + +/** + * Created by hendi on 12/5/16. + */ + +public class MainResponse { + + @SerializedName("status") + public int status; + @SerializedName("message") + public String message; +} diff --git a/app/src/main/java/com/hendiware/hendienger/models/User.java b/app/src/main/java/com/hendiware/hendienger/models/User.java new file mode 100644 index 0000000..7708836 --- /dev/null +++ b/app/src/main/java/com/hendiware/hendienger/models/User.java @@ -0,0 +1,17 @@ +package com.hendiware.hendienger.models; + +import com.google.gson.annotations.SerializedName; + +/** + * hendiware 12 2016 + */ + +public class User { + + @SerializedName("username") + public String username; + @SerializedName("password") + public String password; + @SerializedName("email") + public String email; +} diff --git a/app/src/main/java/com/hendiware/hendienger/webservices/API.java b/app/src/main/java/com/hendiware/hendienger/webservices/API.java new file mode 100644 index 0000000..0e99843 --- /dev/null +++ b/app/src/main/java/com/hendiware/hendienger/webservices/API.java @@ -0,0 +1,22 @@ +package com.hendiware.hendienger.webservices; + +import com.hendiware.hendienger.models.MainResponse; +import com.hendiware.hendienger.models.User; + +import retrofit2.Call; +import retrofit2.http.Body; +import retrofit2.http.POST; + +/** + * hendiware on 2016/12 . + */ + +public interface API { + @POST("login-user.php") + Call loginUser(@Body User user); + + @POST("register-user.php") + Call registerUser(@Body User user); + +} + diff --git a/app/src/main/java/com/hendiware/hendienger/webservices/Urls.java b/app/src/main/java/com/hendiware/hendienger/webservices/Urls.java new file mode 100644 index 0000000..e854f1b --- /dev/null +++ b/app/src/main/java/com/hendiware/hendienger/webservices/Urls.java @@ -0,0 +1,8 @@ +package com.hendiware.hendienger.webservices; + +/** + * hendiware 2016 + */ +public class Urls { + public static final String MAIN_URL = "http://developerhendy.16mb.com/hendienger/"; +} diff --git a/app/src/main/java/com/hendiware/hendienger/webservices/WebService.java b/app/src/main/java/com/hendiware/hendienger/webservices/WebService.java new file mode 100644 index 0000000..8d93631 --- /dev/null +++ b/app/src/main/java/com/hendiware/hendienger/webservices/WebService.java @@ -0,0 +1,36 @@ +package com.hendiware.hendienger.webservices; + +import okhttp3.OkHttpClient; +import retrofit2.Retrofit; +import retrofit2.converter.gson.GsonConverterFactory; + +/** + * hendiware 2016 + */ + +public class WebService { + private static WebService instance; + private API api; + + public WebService() { + + OkHttpClient client = new OkHttpClient.Builder().build(); + Retrofit retrofit = new Retrofit.Builder().client(client) + .addConverterFactory(GsonConverterFactory.create()) + .baseUrl(Urls.MAIN_URL) + .build(); + + api = retrofit.create(API.class); + } + + public static WebService getInstance() { + if (instance == null) { + instance = new WebService(); + } + return instance; + } + + public API getApi() { + return api; + } +} diff --git a/app/src/main/res/anim/enter_from_left.xml b/app/src/main/res/anim/enter_from_left.xml new file mode 100644 index 0000000..12ca6b2 --- /dev/null +++ b/app/src/main/res/anim/enter_from_left.xml @@ -0,0 +1,10 @@ + + + + + + \ No newline at end of file diff --git a/app/src/main/res/anim/enter_from_right.xml b/app/src/main/res/anim/enter_from_right.xml new file mode 100644 index 0000000..a15f46c --- /dev/null +++ b/app/src/main/res/anim/enter_from_right.xml @@ -0,0 +1,10 @@ + + + + + + \ No newline at end of file diff --git a/app/src/main/res/anim/exit_out_left.xml b/app/src/main/res/anim/exit_out_left.xml new file mode 100644 index 0000000..b013611 --- /dev/null +++ b/app/src/main/res/anim/exit_out_left.xml @@ -0,0 +1,10 @@ + + + + + + \ No newline at end of file diff --git a/app/src/main/res/anim/exit_out_right.xml b/app/src/main/res/anim/exit_out_right.xml new file mode 100644 index 0000000..824c4d8 --- /dev/null +++ b/app/src/main/res/anim/exit_out_right.xml @@ -0,0 +1,10 @@ + + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable-hdpi/ic_email_white_24dp.png b/app/src/main/res/drawable-hdpi/ic_email_white_24dp.png new file mode 100644 index 0000000..ddafc1b Binary files /dev/null and b/app/src/main/res/drawable-hdpi/ic_email_white_24dp.png differ diff --git a/app/src/main/res/drawable-hdpi/ic_h_logo.png b/app/src/main/res/drawable-hdpi/ic_h_logo.png new file mode 100644 index 0000000..5090358 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/ic_h_logo.png differ diff --git a/app/src/main/res/drawable-hdpi/ic_lock_white_24dp.png b/app/src/main/res/drawable-hdpi/ic_lock_white_24dp.png new file mode 100644 index 0000000..61d7c5b Binary files /dev/null and b/app/src/main/res/drawable-hdpi/ic_lock_white_24dp.png differ diff --git a/app/src/main/res/drawable-hdpi/ic_logo.png b/app/src/main/res/drawable-hdpi/ic_logo.png new file mode 100644 index 0000000..d4075a1 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/ic_logo.png differ diff --git a/app/src/main/res/drawable-hdpi/ic_person_white_24dp.png b/app/src/main/res/drawable-hdpi/ic_person_white_24dp.png new file mode 100644 index 0000000..91b99f0 Binary files /dev/null and b/app/src/main/res/drawable-hdpi/ic_person_white_24dp.png differ diff --git a/app/src/main/res/drawable-mdpi/ic_email_white_24dp.png b/app/src/main/res/drawable-mdpi/ic_email_white_24dp.png new file mode 100644 index 0000000..8be30c7 Binary files /dev/null and b/app/src/main/res/drawable-mdpi/ic_email_white_24dp.png differ diff --git a/app/src/main/res/drawable-mdpi/ic_h_logo.png b/app/src/main/res/drawable-mdpi/ic_h_logo.png new file mode 100644 index 0000000..b031a4c Binary files /dev/null and b/app/src/main/res/drawable-mdpi/ic_h_logo.png differ diff --git a/app/src/main/res/drawable-mdpi/ic_lock_white_24dp.png b/app/src/main/res/drawable-mdpi/ic_lock_white_24dp.png new file mode 100644 index 0000000..0d786c9 Binary files /dev/null and b/app/src/main/res/drawable-mdpi/ic_lock_white_24dp.png differ diff --git a/app/src/main/res/drawable-mdpi/ic_logo.png b/app/src/main/res/drawable-mdpi/ic_logo.png new file mode 100644 index 0000000..be3f238 Binary files /dev/null and b/app/src/main/res/drawable-mdpi/ic_logo.png differ diff --git a/app/src/main/res/drawable-mdpi/ic_person_white_24dp.png b/app/src/main/res/drawable-mdpi/ic_person_white_24dp.png new file mode 100644 index 0000000..9f75a86 Binary files /dev/null and b/app/src/main/res/drawable-mdpi/ic_person_white_24dp.png differ diff --git a/app/src/main/res/drawable-xhdpi/ic_email_white_24dp.png b/app/src/main/res/drawable-xhdpi/ic_email_white_24dp.png new file mode 100644 index 0000000..784b8b2 Binary files /dev/null and b/app/src/main/res/drawable-xhdpi/ic_email_white_24dp.png differ diff --git a/app/src/main/res/drawable-xhdpi/ic_h_logo.png b/app/src/main/res/drawable-xhdpi/ic_h_logo.png new file mode 100644 index 0000000..b12d610 Binary files /dev/null and b/app/src/main/res/drawable-xhdpi/ic_h_logo.png differ diff --git a/app/src/main/res/drawable-xhdpi/ic_lock_white_24dp.png b/app/src/main/res/drawable-xhdpi/ic_lock_white_24dp.png new file mode 100644 index 0000000..1a583ac Binary files /dev/null and b/app/src/main/res/drawable-xhdpi/ic_lock_white_24dp.png differ diff --git a/app/src/main/res/drawable-xhdpi/ic_logo.png b/app/src/main/res/drawable-xhdpi/ic_logo.png new file mode 100644 index 0000000..1f4409d Binary files /dev/null and b/app/src/main/res/drawable-xhdpi/ic_logo.png differ diff --git a/app/src/main/res/drawable-xhdpi/ic_person_white_24dp.png b/app/src/main/res/drawable-xhdpi/ic_person_white_24dp.png new file mode 100644 index 0000000..27b1a75 Binary files /dev/null and b/app/src/main/res/drawable-xhdpi/ic_person_white_24dp.png differ diff --git a/app/src/main/res/drawable-xxhdpi/ic_email_white_24dp.png b/app/src/main/res/drawable-xxhdpi/ic_email_white_24dp.png new file mode 100644 index 0000000..657abea Binary files /dev/null and b/app/src/main/res/drawable-xxhdpi/ic_email_white_24dp.png differ diff --git a/app/src/main/res/drawable-xxhdpi/ic_h_logo.png b/app/src/main/res/drawable-xxhdpi/ic_h_logo.png new file mode 100644 index 0000000..090d079 Binary files /dev/null and b/app/src/main/res/drawable-xxhdpi/ic_h_logo.png differ diff --git a/app/src/main/res/drawable-xxhdpi/ic_lock_white_24dp.png b/app/src/main/res/drawable-xxhdpi/ic_lock_white_24dp.png new file mode 100644 index 0000000..e8d77d3 Binary files /dev/null and b/app/src/main/res/drawable-xxhdpi/ic_lock_white_24dp.png differ diff --git a/app/src/main/res/drawable-xxhdpi/ic_logo.png b/app/src/main/res/drawable-xxhdpi/ic_logo.png new file mode 100644 index 0000000..8925794 Binary files /dev/null and b/app/src/main/res/drawable-xxhdpi/ic_logo.png differ diff --git a/app/src/main/res/drawable-xxhdpi/ic_person_white_24dp.png b/app/src/main/res/drawable-xxhdpi/ic_person_white_24dp.png new file mode 100644 index 0000000..3cefb2f Binary files /dev/null and b/app/src/main/res/drawable-xxhdpi/ic_person_white_24dp.png differ diff --git a/app/src/main/res/drawable-xxxhdpi/ic_email_white_24dp.png b/app/src/main/res/drawable-xxxhdpi/ic_email_white_24dp.png new file mode 100644 index 0000000..916c05e Binary files /dev/null and b/app/src/main/res/drawable-xxxhdpi/ic_email_white_24dp.png differ diff --git a/app/src/main/res/drawable-xxxhdpi/ic_h_logo.png b/app/src/main/res/drawable-xxxhdpi/ic_h_logo.png new file mode 100644 index 0000000..f460a6e Binary files /dev/null and b/app/src/main/res/drawable-xxxhdpi/ic_h_logo.png differ diff --git a/app/src/main/res/drawable-xxxhdpi/ic_lock_white_24dp.png b/app/src/main/res/drawable-xxxhdpi/ic_lock_white_24dp.png new file mode 100644 index 0000000..94bc21c Binary files /dev/null and b/app/src/main/res/drawable-xxxhdpi/ic_lock_white_24dp.png differ diff --git a/app/src/main/res/drawable-xxxhdpi/ic_logo.png b/app/src/main/res/drawable-xxxhdpi/ic_logo.png new file mode 100644 index 0000000..cbac016 Binary files /dev/null and b/app/src/main/res/drawable-xxxhdpi/ic_logo.png differ diff --git a/app/src/main/res/drawable-xxxhdpi/ic_person_white_24dp.png b/app/src/main/res/drawable-xxxhdpi/ic_person_white_24dp.png new file mode 100644 index 0000000..4e5bf18 Binary files /dev/null and b/app/src/main/res/drawable-xxxhdpi/ic_person_white_24dp.png differ diff --git a/app/src/main/res/drawable/bg.png b/app/src/main/res/drawable/bg.png new file mode 100644 index 0000000..0fd3ca5 Binary files /dev/null and b/app/src/main/res/drawable/bg.png differ diff --git a/app/src/main/res/drawable/btn_login_bg.xml b/app/src/main/res/drawable/btn_login_bg.xml new file mode 100644 index 0000000..51a654c --- /dev/null +++ b/app/src/main/res/drawable/btn_login_bg.xml @@ -0,0 +1,16 @@ + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/splash_background.xml b/app/src/main/res/drawable/splash_background.xml new file mode 100644 index 0000000..71657a8 --- /dev/null +++ b/app/src/main/res/drawable/splash_background.xml @@ -0,0 +1,12 @@ + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/activity_login.xml b/app/src/main/res/layout/activity_login.xml new file mode 100644 index 0000000..c298c18 --- /dev/null +++ b/app/src/main/res/layout/activity_login.xml @@ -0,0 +1,122 @@ + + + + + + + + + + + + + + + + + + + +