Commit dd839264ec899599e22785fea1567bf6dad20cf8
1 parent
efe94d64
All done
Showing
47 changed files
with
1579 additions
and
0 deletions
Show diff stats
@@ -0,0 +1,22 @@ | @@ -0,0 +1,22 @@ | ||
1 | +<?xml version="1.0" encoding="UTF-8"?> | ||
2 | +<project version="4"> | ||
3 | + <component name="CompilerConfiguration"> | ||
4 | + <resourceExtensions /> | ||
5 | + <wildcardResourcePatterns> | ||
6 | + <entry name="!?*.java" /> | ||
7 | + <entry name="!?*.form" /> | ||
8 | + <entry name="!?*.class" /> | ||
9 | + <entry name="!?*.groovy" /> | ||
10 | + <entry name="!?*.scala" /> | ||
11 | + <entry name="!?*.flex" /> | ||
12 | + <entry name="!?*.kt" /> | ||
13 | + <entry name="!?*.clj" /> | ||
14 | + <entry name="!?*.aj" /> | ||
15 | + </wildcardResourcePatterns> | ||
16 | + <annotationProcessing> | ||
17 | + <profile default="true" name="Default" enabled="false"> | ||
18 | + <processorPath useClasspath="true" /> | ||
19 | + </profile> | ||
20 | + </annotationProcessing> | ||
21 | + </component> | ||
22 | +</project> | ||
0 | \ No newline at end of file | 23 | \ No newline at end of file |
@@ -0,0 +1,19 @@ | @@ -0,0 +1,19 @@ | ||
1 | +<?xml version="1.0" encoding="UTF-8"?> | ||
2 | +<project version="4"> | ||
3 | + <component name="GradleSettings"> | ||
4 | + <option name="linkedExternalProjectsSettings"> | ||
5 | + <GradleProjectSettings> | ||
6 | + <option name="distributionType" value="LOCAL" /> | ||
7 | + <option name="externalProjectPath" value="$PROJECT_DIR$" /> | ||
8 | + <option name="gradleHome" value="C:\Program Files\Android\Android Studio\gradle\gradle-2.14.1" /> | ||
9 | + <option name="modules"> | ||
10 | + <set> | ||
11 | + <option value="$PROJECT_DIR$" /> | ||
12 | + <option value="$PROJECT_DIR$/app" /> | ||
13 | + </set> | ||
14 | + </option> | ||
15 | + <option name="resolveModulePerSourceSet" value="false" /> | ||
16 | + </GradleProjectSettings> | ||
17 | + </option> | ||
18 | + </component> | ||
19 | +</project> | ||
0 | \ No newline at end of file | 20 | \ No newline at end of file |
@@ -0,0 +1,46 @@ | @@ -0,0 +1,46 @@ | ||
1 | +<?xml version="1.0" encoding="UTF-8"?> | ||
2 | +<project version="4"> | ||
3 | + <component name="EntryPointsManager"> | ||
4 | + <entry_points version="2.0" /> | ||
5 | + </component> | ||
6 | + <component name="NullableNotNullManager"> | ||
7 | + <option name="myDefaultNullable" value="android.support.annotation.Nullable" /> | ||
8 | + <option name="myDefaultNotNull" value="android.support.annotation.NonNull" /> | ||
9 | + <option name="myNullables"> | ||
10 | + <value> | ||
11 | + <list size="4"> | ||
12 | + <item index="0" class="java.lang.String" itemvalue="org.jetbrains.annotations.Nullable" /> | ||
13 | + <item index="1" class="java.lang.String" itemvalue="javax.annotation.Nullable" /> | ||
14 | + <item index="2" class="java.lang.String" itemvalue="edu.umd.cs.findbugs.annotations.Nullable" /> | ||
15 | + <item index="3" class="java.lang.String" itemvalue="android.support.annotation.Nullable" /> | ||
16 | + </list> | ||
17 | + </value> | ||
18 | + </option> | ||
19 | + <option name="myNotNulls"> | ||
20 | + <value> | ||
21 | + <list size="4"> | ||
22 | + <item index="0" class="java.lang.String" itemvalue="org.jetbrains.annotations.NotNull" /> | ||
23 | + <item index="1" class="java.lang.String" itemvalue="javax.annotation.Nonnull" /> | ||
24 | + <item index="2" class="java.lang.String" itemvalue="edu.umd.cs.findbugs.annotations.NonNull" /> | ||
25 | + <item index="3" class="java.lang.String" itemvalue="android.support.annotation.NonNull" /> | ||
26 | + </list> | ||
27 | + </value> | ||
28 | + </option> | ||
29 | + </component> | ||
30 | + <component name="ProjectLevelVcsManager" settingsEditedManually="false"> | ||
31 | + <OptionsSetting value="true" id="Add" /> | ||
32 | + <OptionsSetting value="true" id="Remove" /> | ||
33 | + <OptionsSetting value="true" id="Checkout" /> | ||
34 | + <OptionsSetting value="true" id="Update" /> | ||
35 | + <OptionsSetting value="true" id="Status" /> | ||
36 | + <OptionsSetting value="true" id="Edit" /> | ||
37 | + <ConfirmationsSetting value="0" id="Add" /> | ||
38 | + <ConfirmationsSetting value="0" id="Remove" /> | ||
39 | + </component> | ||
40 | + <component name="ProjectRootManager" version="2" languageLevel="JDK_1_7" default="true" assert-keyword="true" jdk-15="true" project-jdk-name="1.8" project-jdk-type="JavaSDK"> | ||
41 | + <output url="file://$PROJECT_DIR$/build/classes" /> | ||
42 | + </component> | ||
43 | + <component name="ProjectType"> | ||
44 | + <option name="id" value="Android" /> | ||
45 | + </component> | ||
46 | +</project> | ||
0 | \ No newline at end of file | 47 | \ No newline at end of file |
@@ -0,0 +1,9 @@ | @@ -0,0 +1,9 @@ | ||
1 | +<?xml version="1.0" encoding="UTF-8"?> | ||
2 | +<project version="4"> | ||
3 | + <component name="ProjectModuleManager"> | ||
4 | + <modules> | ||
5 | + <module fileurl="file://$PROJECT_DIR$/Etunicorn.iml" filepath="$PROJECT_DIR$/Etunicorn.iml" /> | ||
6 | + <module fileurl="file://$PROJECT_DIR$/app/app.iml" filepath="$PROJECT_DIR$/app/app.iml" /> | ||
7 | + </modules> | ||
8 | + </component> | ||
9 | +</project> | ||
0 | \ No newline at end of file | 10 | \ No newline at end of file |
@@ -0,0 +1,12 @@ | @@ -0,0 +1,12 @@ | ||
1 | +<?xml version="1.0" encoding="UTF-8"?> | ||
2 | +<project version="4"> | ||
3 | + <component name="RunConfigurationProducerService"> | ||
4 | + <option name="ignoredProducers"> | ||
5 | + <set> | ||
6 | + <option value="org.jetbrains.plugins.gradle.execution.test.runner.AllInPackageGradleConfigurationProducer" /> | ||
7 | + <option value="org.jetbrains.plugins.gradle.execution.test.runner.TestClassGradleConfigurationProducer" /> | ||
8 | + <option value="org.jetbrains.plugins.gradle.execution.test.runner.TestMethodGradleConfigurationProducer" /> | ||
9 | + </set> | ||
10 | + </option> | ||
11 | + </component> | ||
12 | +</project> | ||
0 | \ No newline at end of file | 13 | \ No newline at end of file |
@@ -0,0 +1 @@ | @@ -0,0 +1 @@ | ||
1 | +/build |
@@ -0,0 +1,33 @@ | @@ -0,0 +1,33 @@ | ||
1 | +apply plugin: 'com.android.application' | ||
2 | + | ||
3 | +android { | ||
4 | + compileSdkVersion 24 | ||
5 | + buildToolsVersion "24.0.2" | ||
6 | + defaultConfig { | ||
7 | + applicationId "net.plil.clubinfo.etunicorn" | ||
8 | + minSdkVersion 21 | ||
9 | + targetSdkVersion 24 | ||
10 | + versionCode 1 | ||
11 | + versionName "1.0" | ||
12 | + testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" | ||
13 | + } | ||
14 | + buildTypes { | ||
15 | + release { | ||
16 | + minifyEnabled false | ||
17 | + proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' | ||
18 | + } | ||
19 | + } | ||
20 | +} | ||
21 | + | ||
22 | +dependencies { | ||
23 | + compile fileTree(dir: 'libs', include: ['*.jar']) | ||
24 | + androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', { | ||
25 | + exclude group: 'com.android.support', module: 'support-annotations' | ||
26 | + }) | ||
27 | + compile 'com.android.support:appcompat-v7:24.2.1' | ||
28 | + compile 'com.android.support:design:24.2.1' | ||
29 | + compile 'com.android.volley:volley:1.0.0' | ||
30 | + compile 'com.google.code.gson:gson:2.4' | ||
31 | + compile 'com.android.support:support-v4:24.2.1' | ||
32 | + testCompile 'junit:junit:4.12' | ||
33 | +} |
@@ -0,0 +1,17 @@ | @@ -0,0 +1,17 @@ | ||
1 | +# Add project specific ProGuard rules here. | ||
2 | +# By default, the flags in this file are appended to flags specified | ||
3 | +# in C:\Users\badet\AppData\Local\Android\Sdk/tools/proguard/proguard-android.txt | ||
4 | +# You can edit the include path and order by changing the proguardFiles | ||
5 | +# directive in build.gradle. | ||
6 | +# | ||
7 | +# For more details, see | ||
8 | +# http://developer.android.com/guide/developing/tools/proguard.html | ||
9 | + | ||
10 | +# Add any project specific keep options here: | ||
11 | + | ||
12 | +# If your project uses WebView with JS, uncomment the following | ||
13 | +# and specify the fully qualified class name to the JavaScript interface | ||
14 | +# class: | ||
15 | +#-keepclassmembers class fqcn.of.javascript.interface.for.webview { | ||
16 | +# public *; | ||
17 | +#} |
app/src/androidTest/java/net/plil/clubinfo/etunicorn/ExampleInstrumentedTest.java
0 → 100644
@@ -0,0 +1,26 @@ | @@ -0,0 +1,26 @@ | ||
1 | +package net.plil.clubinfo.etunicorn; | ||
2 | + | ||
3 | +import android.content.Context; | ||
4 | +import android.support.test.InstrumentationRegistry; | ||
5 | +import android.support.test.runner.AndroidJUnit4; | ||
6 | + | ||
7 | +import org.junit.Test; | ||
8 | +import org.junit.runner.RunWith; | ||
9 | + | ||
10 | +import static org.junit.Assert.*; | ||
11 | + | ||
12 | +/** | ||
13 | + * Instrumentation test, which will execute on an Android device. | ||
14 | + * | ||
15 | + * @see <a href="http://d.android.com/tools/testing">Testing documentation</a> | ||
16 | + */ | ||
17 | +@RunWith(AndroidJUnit4.class) | ||
18 | +public class ExampleInstrumentedTest { | ||
19 | + @Test | ||
20 | + public void useAppContext() throws Exception { | ||
21 | + // Context of the app under test. | ||
22 | + Context appContext = InstrumentationRegistry.getTargetContext(); | ||
23 | + | ||
24 | + assertEquals("net.plil.clubinfo.etunicorn", appContext.getPackageName()); | ||
25 | + } | ||
26 | +} |
@@ -0,0 +1,43 @@ | @@ -0,0 +1,43 @@ | ||
1 | +<?xml version="1.0" encoding="utf-8"?> | ||
2 | +<manifest xmlns:android="http://schemas.android.com/apk/res/android" | ||
3 | + package="net.plil.clubinfo.etunicorn"> | ||
4 | + | ||
5 | + <uses-permission android:name="android.permission.INTERNET" /> | ||
6 | + <uses-permission android:name="android.permission.NFC" /> | ||
7 | + <uses-feature android:name="android.hardware.nfc" android:required="true" /> | ||
8 | + | ||
9 | + | ||
10 | + <application | ||
11 | + android:allowBackup="true" | ||
12 | + android:icon="@mipmap/ic_launcher" | ||
13 | + android:label="@string/app_name" | ||
14 | + android:supportsRtl="true" | ||
15 | + android:theme="@style/AppTheme"> | ||
16 | + <activity | ||
17 | + android:name=".app.LoginActivity" | ||
18 | + android:label="@string/app_name"> | ||
19 | + <intent-filter> | ||
20 | + <action android:name="android.intent.action.MAIN" /> | ||
21 | + | ||
22 | + <category android:name="android.intent.category.LAUNCHER" /> | ||
23 | + </intent-filter> | ||
24 | + </activity> | ||
25 | + | ||
26 | + <activity | ||
27 | + android:name=".app.MainActivity" | ||
28 | + android:label="@string/title_activity_main" | ||
29 | + android:theme="@style/AppTheme.NoActionBar" > | ||
30 | + <meta-data android:name="android.nfc.action.TECH_DISCOVERED" | ||
31 | + android:resource="@xml/tech" /> | ||
32 | + <intent-filter> | ||
33 | + <action android:name="android.nfc.action.NDEF_DISCOVERED"/> | ||
34 | + <category android:name="android.intent.category.DEFAULT"/> | ||
35 | + </intent-filter> | ||
36 | + <intent-filter> | ||
37 | + <action android:name="android.nfc.action.TECH_DISCOVERED"/> | ||
38 | + <category android:name="android.intent.category.DEFAULT"/> | ||
39 | + </intent-filter> | ||
40 | + </activity> | ||
41 | + </application> | ||
42 | + | ||
43 | +</manifest> | ||
0 | \ No newline at end of file | 44 | \ No newline at end of file |
app/src/main/java/net/plil/clubinfo/etunicorn/app/Crediter.java
0 → 100644
@@ -0,0 +1,108 @@ | @@ -0,0 +1,108 @@ | ||
1 | +package net.plil.clubinfo.etunicorn.app; | ||
2 | + | ||
3 | +import android.content.Context; | ||
4 | +import android.content.Intent; | ||
5 | +import android.net.Uri; | ||
6 | +import android.nfc.NdefMessage; | ||
7 | +import android.nfc.NfcAdapter; | ||
8 | +import android.nfc.NfcEvent; | ||
9 | +import android.os.Bundle; | ||
10 | +import android.os.Parcelable; | ||
11 | +import android.support.design.widget.Snackbar; | ||
12 | +import android.support.v4.app.Fragment; | ||
13 | +import android.view.LayoutInflater; | ||
14 | +import android.view.View; | ||
15 | +import android.view.ViewGroup; | ||
16 | +import android.widget.Toast; | ||
17 | + | ||
18 | +import net.plil.clubinfo.etunicorn.R; | ||
19 | + | ||
20 | +/** | ||
21 | + * A simple {@link Fragment} subclass. | ||
22 | + * Activities that contain this fragment must implement the | ||
23 | + * {@link Crediter.OnFragmentInteractionListener} interface | ||
24 | + * to handle interaction events. | ||
25 | + * Use the {@link Crediter#newInstance} factory method to | ||
26 | + * create an instance of this fragment. | ||
27 | + */ | ||
28 | +public class Crediter extends Fragment { | ||
29 | + NfcAdapter mNfcAdapter; | ||
30 | + | ||
31 | + | ||
32 | + | ||
33 | + private OnFragmentInteractionListener mListener; | ||
34 | + | ||
35 | + public Crediter() { | ||
36 | + // Required empty public constructor | ||
37 | + } | ||
38 | + | ||
39 | + /** | ||
40 | + * Use this factory method to create a new instance of | ||
41 | + * this fragment using the provided parameters. | ||
42 | + * | ||
43 | + * @return A new instance of fragment Crediter. | ||
44 | + */ | ||
45 | + public static Crediter newInstance(String param1, String param2) { | ||
46 | + Crediter fragment = new Crediter(); | ||
47 | + return fragment; | ||
48 | + } | ||
49 | + | ||
50 | + @Override | ||
51 | + public void onCreate(Bundle savedInstanceState) { | ||
52 | + super.onCreate(savedInstanceState); | ||
53 | + mNfcAdapter = NfcAdapter.getDefaultAdapter(getContext()); | ||
54 | + if (mNfcAdapter == null) { | ||
55 | + Toast.makeText(getActivity(), "NFC is not available", Toast.LENGTH_LONG).show(); | ||
56 | + return; | ||
57 | + } | ||
58 | + if (!mNfcAdapter.isEnabled()){ | ||
59 | + Toast.makeText(getActivity(), "NFC is not enabled, please turn it on", Toast.LENGTH_LONG).show(); | ||
60 | + } | ||
61 | + | ||
62 | + } | ||
63 | + | ||
64 | + @Override | ||
65 | + public View onCreateView(LayoutInflater inflater, ViewGroup container, | ||
66 | + Bundle savedInstanceState) { | ||
67 | + // Inflate the layout for this fragment | ||
68 | + return inflater.inflate(R.layout.fragment_crediter, container, false); | ||
69 | + } | ||
70 | + | ||
71 | + | ||
72 | + @Override | ||
73 | + public void onAttach(Context context) { | ||
74 | + super.onAttach(context); | ||
75 | + if (context instanceof OnFragmentInteractionListener) { | ||
76 | + mListener = (OnFragmentInteractionListener) context; | ||
77 | + } else { | ||
78 | + throw new RuntimeException(context.toString() | ||
79 | + + " must implement OnFragmentInteractionListener"); | ||
80 | + } | ||
81 | + } | ||
82 | + | ||
83 | + @Override | ||
84 | + public void onDetach() { | ||
85 | + super.onDetach(); | ||
86 | + mListener = null; | ||
87 | + } | ||
88 | + | ||
89 | + public void processNFC(){ | ||
90 | + Toast.makeText(getContext(), "HELLO NFC", Toast.LENGTH_LONG).show(); | ||
91 | + } | ||
92 | + | ||
93 | + | ||
94 | + /** | ||
95 | + * This interface must be implemented by activities that contain this | ||
96 | + * fragment to allow an interaction in this fragment to be communicated | ||
97 | + * to the activity and potentially other fragments contained in that | ||
98 | + * activity. | ||
99 | + * <p> | ||
100 | + * See the Android Training lesson <a href= | ||
101 | + * "http://developer.android.com/training/basics/fragments/communicating.html" | ||
102 | + * >Communicating with Other Fragments</a> for more information. | ||
103 | + */ | ||
104 | + public interface OnFragmentInteractionListener { | ||
105 | + // TODO: Update argument type and name | ||
106 | + void onFragmentInteraction(Uri uri); | ||
107 | + } | ||
108 | +} |
app/src/main/java/net/plil/clubinfo/etunicorn/app/Debiter.java
0 → 100644
@@ -0,0 +1,109 @@ | @@ -0,0 +1,109 @@ | ||
1 | +package net.plil.clubinfo.etunicorn.app; | ||
2 | + | ||
3 | +import android.content.Context; | ||
4 | +import android.net.Uri; | ||
5 | +import android.os.Bundle; | ||
6 | +import android.support.v4.app.Fragment; | ||
7 | +import android.view.LayoutInflater; | ||
8 | +import android.view.View; | ||
9 | +import android.view.ViewGroup; | ||
10 | + | ||
11 | +import net.plil.clubinfo.etunicorn.R; | ||
12 | + | ||
13 | +/** | ||
14 | + * A simple {@link Fragment} subclass. | ||
15 | + * Activities that contain this fragment must implement the | ||
16 | + * {@link Debiter.OnFragmentInteractionListener} interface | ||
17 | + * to handle interaction events. | ||
18 | + * Use the {@link Debiter#newInstance} factory method to | ||
19 | + * create an instance of this fragment. | ||
20 | + */ | ||
21 | +public class Debiter extends Fragment { | ||
22 | + // TODO: Rename parameter arguments, choose names that match | ||
23 | + // the fragment initialization parameters, e.g. ARG_ITEM_NUMBER | ||
24 | + private static final String ARG_PARAM1 = "param1"; | ||
25 | + private static final String ARG_PARAM2 = "param2"; | ||
26 | + | ||
27 | + // TODO: Rename and change types of parameters | ||
28 | + private String mParam1; | ||
29 | + private String mParam2; | ||
30 | + | ||
31 | + private OnFragmentInteractionListener mListener; | ||
32 | + | ||
33 | + public Debiter() { | ||
34 | + // Required empty public constructor | ||
35 | + } | ||
36 | + | ||
37 | + /** | ||
38 | + * Use this factory method to create a new instance of | ||
39 | + * this fragment using the provided parameters. | ||
40 | + * | ||
41 | + * @param param1 Parameter 1. | ||
42 | + * @param param2 Parameter 2. | ||
43 | + * @return A new instance of fragment Debiter. | ||
44 | + */ | ||
45 | + // TODO: Rename and change types and number of parameters | ||
46 | + public static Debiter newInstance(String param1, String param2) { | ||
47 | + Debiter fragment = new Debiter(); | ||
48 | + Bundle args = new Bundle(); | ||
49 | + args.putString(ARG_PARAM1, param1); | ||
50 | + args.putString(ARG_PARAM2, param2); | ||
51 | + fragment.setArguments(args); | ||
52 | + return fragment; | ||
53 | + } | ||
54 | + | ||
55 | + @Override | ||
56 | + public void onCreate(Bundle savedInstanceState) { | ||
57 | + super.onCreate(savedInstanceState); | ||
58 | + if (getArguments() != null) { | ||
59 | + mParam1 = getArguments().getString(ARG_PARAM1); | ||
60 | + mParam2 = getArguments().getString(ARG_PARAM2); | ||
61 | + } | ||
62 | + } | ||
63 | + | ||
64 | + @Override | ||
65 | + public View onCreateView(LayoutInflater inflater, ViewGroup container, | ||
66 | + Bundle savedInstanceState) { | ||
67 | + // Inflate the layout for this fragment | ||
68 | + return inflater.inflate(R.layout.fragment_debiter, container, false); | ||
69 | + } | ||
70 | + | ||
71 | + // TODO: Rename method, update argument and hook method into UI event | ||
72 | + public void onButtonPressed(Uri uri) { | ||
73 | + if (mListener != null) { | ||
74 | + mListener.onFragmentInteraction(uri); | ||
75 | + } | ||
76 | + } | ||
77 | + | ||
78 | + @Override | ||
79 | + public void onAttach(Context context) { | ||
80 | + super.onAttach(context); | ||
81 | + if (context instanceof OnFragmentInteractionListener) { | ||
82 | + mListener = (OnFragmentInteractionListener) context; | ||
83 | + } else { | ||
84 | + throw new RuntimeException(context.toString() | ||
85 | + + " must implement OnFragmentInteractionListener"); | ||
86 | + } | ||
87 | + } | ||
88 | + | ||
89 | + @Override | ||
90 | + public void onDetach() { | ||
91 | + super.onDetach(); | ||
92 | + mListener = null; | ||
93 | + } | ||
94 | + | ||
95 | + /** | ||
96 | + * This interface must be implemented by activities that contain this | ||
97 | + * fragment to allow an interaction in this fragment to be communicated | ||
98 | + * to the activity and potentially other fragments contained in that | ||
99 | + * activity. | ||
100 | + * <p> | ||
101 | + * See the Android Training lesson <a href= | ||
102 | + * "http://developer.android.com/training/basics/fragments/communicating.html" | ||
103 | + * >Communicating with Other Fragments</a> for more information. | ||
104 | + */ | ||
105 | + public interface OnFragmentInteractionListener { | ||
106 | + // TODO: Update argument type and name | ||
107 | + void onFragmentInteraction(Uri uri); | ||
108 | + } | ||
109 | +} |
app/src/main/java/net/plil/clubinfo/etunicorn/app/LoginActivity.java
0 → 100644
@@ -0,0 +1,197 @@ | @@ -0,0 +1,197 @@ | ||
1 | +package net.plil.clubinfo.etunicorn.app; | ||
2 | + | ||
3 | +import android.animation.Animator; | ||
4 | +import android.animation.AnimatorListenerAdapter; | ||
5 | +import android.annotation.TargetApi; | ||
6 | +import android.app.DownloadManager; | ||
7 | +import android.content.Intent; | ||
8 | +import android.content.pm.PackageManager; | ||
9 | +import android.support.annotation.NonNull; | ||
10 | +import android.support.design.widget.Snackbar; | ||
11 | +import android.support.v7.app.AppCompatActivity; | ||
12 | +import android.app.LoaderManager.LoaderCallbacks; | ||
13 | + | ||
14 | +import android.content.CursorLoader; | ||
15 | +import android.content.Loader; | ||
16 | +import android.database.Cursor; | ||
17 | +import android.net.Uri; | ||
18 | +import android.os.AsyncTask; | ||
19 | + | ||
20 | +import android.os.Build; | ||
21 | +import android.os.Bundle; | ||
22 | +import android.provider.ContactsContract; | ||
23 | +import android.text.TextUtils; | ||
24 | +import android.view.KeyEvent; | ||
25 | +import android.view.View; | ||
26 | +import android.view.View.OnClickListener; | ||
27 | +import android.view.inputmethod.EditorInfo; | ||
28 | +import android.widget.ArrayAdapter; | ||
29 | +import android.widget.Button; | ||
30 | +import android.widget.EditText; | ||
31 | +import android.widget.TextView; | ||
32 | +import android.widget.Toast; | ||
33 | + | ||
34 | +import com.android.volley.Request; | ||
35 | +import com.android.volley.RequestQueue; | ||
36 | +import com.android.volley.Response; | ||
37 | +import com.android.volley.VolleyError; | ||
38 | +import com.android.volley.toolbox.JsonObjectRequest; | ||
39 | +import com.google.gson.Gson; | ||
40 | + | ||
41 | +import net.plil.clubinfo.etunicorn.R; | ||
42 | +import net.plil.clubinfo.etunicorn.data.Personne; | ||
43 | +import net.plil.clubinfo.etunicorn.utils.VolleyUtils; | ||
44 | + | ||
45 | +import org.json.JSONException; | ||
46 | +import org.json.JSONObject; | ||
47 | + | ||
48 | +import java.util.ArrayList; | ||
49 | +import java.util.List; | ||
50 | + | ||
51 | +import static android.Manifest.permission.READ_CONTACTS; | ||
52 | + | ||
53 | +/** | ||
54 | + * A login screen that offers login via email/password. | ||
55 | + */ | ||
56 | +public class LoginActivity extends AppCompatActivity { | ||
57 | + | ||
58 | + /** | ||
59 | + * Id to identity READ_CONTACTS permission request. | ||
60 | + */ | ||
61 | + private static final int REQUEST_READ_CONTACTS = 0; | ||
62 | + | ||
63 | + /** | ||
64 | + * Keep track of the login task to ensure we can cancel it if requested. | ||
65 | + */ | ||
66 | + | ||
67 | + // UI references. | ||
68 | + private EditText mUsernameView; | ||
69 | + private EditText mPasswordView; | ||
70 | + private View mProgressView; | ||
71 | + private View mLoginFormView; | ||
72 | + | ||
73 | + @Override | ||
74 | + protected void onCreate(Bundle savedInstanceState) { | ||
75 | + super.onCreate(savedInstanceState); | ||
76 | + setContentView(R.layout.activity_login); | ||
77 | + // Set up the login form. | ||
78 | + mUsernameView = (EditText) findViewById(R.id.username); | ||
79 | + | ||
80 | + mPasswordView = (EditText) findViewById(R.id.password); | ||
81 | + mPasswordView.setOnEditorActionListener(new TextView.OnEditorActionListener() { | ||
82 | + @Override | ||
83 | + public boolean onEditorAction(TextView textView, int id, KeyEvent keyEvent) { | ||
84 | + if (id == R.id.login || id == EditorInfo.IME_NULL) { | ||
85 | + attemptLogin(); | ||
86 | + return true; | ||
87 | + } | ||
88 | + return false; | ||
89 | + } | ||
90 | + }); | ||
91 | + | ||
92 | + Button mEmailSignInButton = (Button) findViewById(R.id.email_sign_in_button); | ||
93 | + mEmailSignInButton.setOnClickListener(new OnClickListener() { | ||
94 | + @Override | ||
95 | + public void onClick(View view) { | ||
96 | + attemptLogin(); | ||
97 | + } | ||
98 | + }); | ||
99 | + | ||
100 | + mLoginFormView = findViewById(R.id.login_form); | ||
101 | + mProgressView = findViewById(R.id.login_progress); | ||
102 | + } | ||
103 | + | ||
104 | + | ||
105 | + /** | ||
106 | + * Attempts to sign in or register the account specified by the login form. | ||
107 | + * If there are form errors (invalid email, missing fields, etc.), the | ||
108 | + * errors are presented and no actual login attempt is made. | ||
109 | + */ | ||
110 | + private void attemptLogin() { | ||
111 | + | ||
112 | + // Reset errors. | ||
113 | + mUsernameView.setError(null); | ||
114 | + mPasswordView.setError(null); | ||
115 | + | ||
116 | + // Store values at the time of the login attempt. | ||
117 | + String email = mUsernameView.getText().toString(); | ||
118 | + String username = mPasswordView.getText().toString(); | ||
119 | + | ||
120 | + | ||
121 | + showProgress(true); | ||
122 | + tryLogin(email, username); | ||
123 | + } | ||
124 | + | ||
125 | + /** | ||
126 | + * Shows the progress UI and hides the login form. | ||
127 | + */ | ||
128 | + @TargetApi(Build.VERSION_CODES.HONEYCOMB_MR2) | ||
129 | + private void showProgress(final boolean show) { | ||
130 | + // On Honeycomb MR2 we have the ViewPropertyAnimator APIs, which allow | ||
131 | + // for very easy animations. If available, use these APIs to fade-in | ||
132 | + // the progress spinner. | ||
133 | + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB_MR2) { | ||
134 | + int shortAnimTime = getResources().getInteger(android.R.integer.config_shortAnimTime); | ||
135 | + | ||
136 | + mLoginFormView.setVisibility(show ? View.GONE : View.VISIBLE); | ||
137 | + mLoginFormView.animate().setDuration(shortAnimTime).alpha( | ||
138 | + show ? 0 : 1).setListener(new AnimatorListenerAdapter() { | ||
139 | + @Override | ||
140 | + public void onAnimationEnd(Animator animation) { | ||
141 | + mLoginFormView.setVisibility(show ? View.GONE : View.VISIBLE); | ||
142 | + } | ||
143 | + }); | ||
144 | + | ||
145 | + mProgressView.setVisibility(show ? View.VISIBLE : View.GONE); | ||
146 | + mProgressView.animate().setDuration(shortAnimTime).alpha( | ||
147 | + show ? 1 : 0).setListener(new AnimatorListenerAdapter() { | ||
148 | + @Override | ||
149 | + public void onAnimationEnd(Animator animation) { | ||
150 | + mProgressView.setVisibility(show ? View.VISIBLE : View.GONE); | ||
151 | + } | ||
152 | + }); | ||
153 | + } else { | ||
154 | + // The ViewPropertyAnimator APIs are not available, so simply show | ||
155 | + // and hide the relevant UI components. | ||
156 | + mProgressView.setVisibility(show ? View.VISIBLE : View.GONE); | ||
157 | + mLoginFormView.setVisibility(show ? View.GONE : View.VISIBLE); | ||
158 | + } | ||
159 | + } | ||
160 | + | ||
161 | + /** | ||
162 | + * You need a polytech Lille Account | ||
163 | + * | ||
164 | + * @param username The username of the person | ||
165 | + * @param password The password of the person | ||
166 | + */ | ||
167 | + private void tryLogin (String username, String password){ | ||
168 | + JsonObjectRequest jsonObjectRequest = new JsonObjectRequest(Request.Method.POST, VolleyUtils.baseUri + "/login?login=" + username + "&password=" + password , null, new Response.Listener<JSONObject>() { | ||
169 | + @Override | ||
170 | + public void onResponse(JSONObject response) { | ||
171 | + showProgress(false); | ||
172 | + try { | ||
173 | + Personne p = new Gson().fromJson(response.getJSONObject("").toString(), Personne.class); | ||
174 | + Intent intent = new Intent(getApplicationContext(), MainActivity.class); | ||
175 | + startActivity(intent); | ||
176 | + } catch (JSONException e) { | ||
177 | + e.printStackTrace(); | ||
178 | + } | ||
179 | + } | ||
180 | + }, new Response.ErrorListener() { | ||
181 | + @Override | ||
182 | + public void onErrorResponse(VolleyError error) { | ||
183 | + showProgress(false); | ||
184 | + Toast.makeText(getApplicationContext(), error.getMessage(), Toast.LENGTH_SHORT).show(); | ||
185 | + | ||
186 | + //TODO remove this line | ||
187 | + Intent intent = new Intent(getApplicationContext(), MainActivity.class); | ||
188 | + startActivity(intent); | ||
189 | + // END | ||
190 | + } | ||
191 | + } | ||
192 | + ); | ||
193 | + | ||
194 | + VolleyUtils.getInstance(getApplicationContext()).addToRequestQueue(jsonObjectRequest); | ||
195 | + } | ||
196 | +} | ||
197 | + |
app/src/main/java/net/plil/clubinfo/etunicorn/app/MainActivity.java
0 → 100644
@@ -0,0 +1,212 @@ | @@ -0,0 +1,212 @@ | ||
1 | +package net.plil.clubinfo.etunicorn.app; | ||
2 | + | ||
3 | +import android.app.PendingIntent; | ||
4 | +import android.content.Intent; | ||
5 | +import android.nfc.NdefMessage; | ||
6 | +import android.nfc.NfcAdapter; | ||
7 | +import android.nfc.Tag; | ||
8 | +import android.os.Parcelable; | ||
9 | +import android.support.design.widget.TabLayout; | ||
10 | +import android.support.design.widget.FloatingActionButton; | ||
11 | +import android.support.design.widget.Snackbar; | ||
12 | +import android.support.v7.app.AppCompatActivity; | ||
13 | +import android.support.v7.widget.Toolbar; | ||
14 | + | ||
15 | +import android.support.v4.app.Fragment; | ||
16 | +import android.support.v4.app.FragmentManager; | ||
17 | +import android.support.v4.app.FragmentPagerAdapter; | ||
18 | +import android.support.v4.view.ViewPager; | ||
19 | +import android.os.Bundle; | ||
20 | +import android.view.LayoutInflater; | ||
21 | +import android.view.Menu; | ||
22 | +import android.view.MenuItem; | ||
23 | +import android.view.View; | ||
24 | +import android.view.ViewGroup; | ||
25 | + | ||
26 | +import android.widget.TextView; | ||
27 | +import android.widget.Toast; | ||
28 | + | ||
29 | +import net.plil.clubinfo.etunicorn.R; | ||
30 | + | ||
31 | +import java.util.List; | ||
32 | + | ||
33 | +public class MainActivity extends AppCompatActivity { | ||
34 | + | ||
35 | + /** | ||
36 | + * The {@link android.support.v4.view.PagerAdapter} that will provide | ||
37 | + * fragments for each of the sections. We use a | ||
38 | + * {@link FragmentPagerAdapter} derivative, which will keep every | ||
39 | + * loaded fragment in memory. If this becomes too memory intensive, it | ||
40 | + * may be best to switch to a | ||
41 | + * {@link android.support.v4.app.FragmentStatePagerAdapter}. | ||
42 | + */ | ||
43 | + private SectionsPagerAdapter mSectionsPagerAdapter; | ||
44 | + | ||
45 | + /** | ||
46 | + * The {@link ViewPager} that will host the section contents. | ||
47 | + */ | ||
48 | + private ViewPager mViewPager; | ||
49 | + | ||
50 | + | ||
51 | + NfcAdapter mAdapter; | ||
52 | + PendingIntent mPendingIntent; | ||
53 | + | ||
54 | + @Override | ||
55 | + protected void onCreate(Bundle savedInstanceState) { | ||
56 | + super.onCreate(savedInstanceState); | ||
57 | + setContentView(R.layout.activity_main); | ||
58 | + | ||
59 | + Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); | ||
60 | + setSupportActionBar(toolbar); | ||
61 | + // Create the adapter that will return a fragment for each of the three | ||
62 | + // primary sections of the activity. | ||
63 | + mSectionsPagerAdapter = new SectionsPagerAdapter(getSupportFragmentManager()); | ||
64 | + | ||
65 | + // Set up the ViewPager with the sections adapter. | ||
66 | + mViewPager = (ViewPager) findViewById(R.id.container); | ||
67 | + mViewPager.setAdapter(mSectionsPagerAdapter); | ||
68 | + | ||
69 | + TabLayout tabLayout = (TabLayout) findViewById(R.id.tabs); | ||
70 | + tabLayout.setupWithViewPager(mViewPager); | ||
71 | + | ||
72 | + | ||
73 | + mAdapter = NfcAdapter.getDefaultAdapter(this); | ||
74 | + if (mAdapter == null) { | ||
75 | + //nfc not support your device. | ||
76 | + return; | ||
77 | + } | ||
78 | + mPendingIntent = PendingIntent.getActivity(this, 0, new Intent(this, | ||
79 | + getClass()).addFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP), 0); | ||
80 | + | ||
81 | + } | ||
82 | + | ||
83 | + | ||
84 | + @Override | ||
85 | + public boolean onCreateOptionsMenu(Menu menu) { | ||
86 | + // Inflate the menu; this adds items to the action bar if it is present. | ||
87 | + getMenuInflater().inflate(R.menu.menu_main, menu); | ||
88 | + return true; | ||
89 | + } | ||
90 | + | ||
91 | + @Override | ||
92 | + public boolean onOptionsItemSelected(MenuItem item) { | ||
93 | + // Handle action bar item clicks here. The action bar will | ||
94 | + // automatically handle clicks on the Home/Up button, so long | ||
95 | + // as you specify a parent activity in AndroidManifest.xml. | ||
96 | + int id = item.getItemId(); | ||
97 | + | ||
98 | + //noinspection SimplifiableIfStatement | ||
99 | + if (id == R.id.action_settings) { | ||
100 | + return true; | ||
101 | + } | ||
102 | + | ||
103 | + return super.onOptionsItemSelected(item); | ||
104 | + } | ||
105 | + | ||
106 | + @Override | ||
107 | + protected void onNewIntent(Intent intent) { | ||
108 | + super.onNewIntent(intent); | ||
109 | + Toast.makeText(getBaseContext(), mViewPager.getCurrentItem()+" NFC WORKING", Toast.LENGTH_LONG).show(); | ||
110 | + Toast.makeText(getBaseContext(), intent.getParcelableExtra(NfcAdapter.EXTRA_TAG) + "", Toast.LENGTH_LONG).show(); | ||
111 | + | ||
112 | + } | ||
113 | + | ||
114 | + @Override | ||
115 | + public void onResume(){ | ||
116 | + super.onResume(); | ||
117 | + mAdapter.enableForegroundDispatch(this, mPendingIntent, null, null); | ||
118 | + } | ||
119 | + | ||
120 | + @Override | ||
121 | + public void onPause(){ | ||
122 | + super.onPause(); | ||
123 | + if (mAdapter != null) { | ||
124 | + mAdapter.disableForegroundDispatch(this); | ||
125 | + } | ||
126 | + } | ||
127 | + | ||
128 | + /** | ||
129 | + * A placeholder fragment containing a simple view. | ||
130 | + */ | ||
131 | + public static class PlaceholderFragment extends Fragment { | ||
132 | + /** | ||
133 | + * The fragment argument representing the section number for this | ||
134 | + * fragment. | ||
135 | + */ | ||
136 | + private static final String ARG_SECTION_NUMBER = "section_number"; | ||
137 | + | ||
138 | + public PlaceholderFragment() { | ||
139 | + } | ||
140 | + | ||
141 | + /** | ||
142 | + * Returns a new instance of this fragment for the given section | ||
143 | + * number. | ||
144 | + */ | ||
145 | + public static PlaceholderFragment newInstance(int sectionNumber) { | ||
146 | + PlaceholderFragment fragment = new PlaceholderFragment(); | ||
147 | + Bundle args = new Bundle(); | ||
148 | + args.putInt(ARG_SECTION_NUMBER, sectionNumber); | ||
149 | + fragment.setArguments(args); | ||
150 | + return fragment; | ||
151 | + } | ||
152 | + | ||
153 | + @Override | ||
154 | + public View onCreateView(LayoutInflater inflater, ViewGroup container, | ||
155 | + Bundle savedInstanceState) { | ||
156 | + View rootView; | ||
157 | + if (getArguments().getInt(ARG_SECTION_NUMBER) == Action.DEBITER.getValue()) | ||
158 | + rootView = inflater.inflate(R.layout.fragment_debiter, container, false); | ||
159 | + else if (getArguments().getInt(ARG_SECTION_NUMBER) == Action.CREDITER.getValue()) | ||
160 | + rootView = inflater.inflate(R.layout.fragment_crediter, container, false); | ||
161 | + else | ||
162 | + rootView = inflater.inflate(R.layout.fragment_main, container, false); | ||
163 | + return rootView; | ||
164 | + } | ||
165 | + } | ||
166 | + | ||
167 | + /** | ||
168 | + * A {@link FragmentPagerAdapter} that returns a fragment corresponding to | ||
169 | + * one of the sections/tabs/pages. | ||
170 | + */ | ||
171 | + public class SectionsPagerAdapter extends FragmentPagerAdapter { | ||
172 | + | ||
173 | + public SectionsPagerAdapter(FragmentManager fm) { | ||
174 | + super(fm); | ||
175 | + } | ||
176 | + | ||
177 | + @Override | ||
178 | + public Fragment getItem(int position) { | ||
179 | + // getItem is called to instantiate the fragment for the given page. | ||
180 | + // Return a PlaceholderFragment (defined as a static inner class below). | ||
181 | + return PlaceholderFragment.newInstance(position + 1); | ||
182 | + } | ||
183 | + | ||
184 | + @Override | ||
185 | + public int getCount() { | ||
186 | + // Show 3 total pages. | ||
187 | + return 3; | ||
188 | + } | ||
189 | + | ||
190 | + @Override | ||
191 | + public CharSequence getPageTitle(int position) { | ||
192 | + if(position == Action.DEBITER.getValue()) | ||
193 | + return "Debiter"; | ||
194 | + else if (position == Action.CREDITER.getValue()) | ||
195 | + return "Crediter"; | ||
196 | + return null; | ||
197 | + } | ||
198 | + } | ||
199 | + | ||
200 | + private enum Action { | ||
201 | + DEBITER(0), CREDITER(1); | ||
202 | + | ||
203 | + private final int value; | ||
204 | + Action(int value) { | ||
205 | + this.value = value; | ||
206 | + } | ||
207 | + | ||
208 | + public int getValue() { | ||
209 | + return value; | ||
210 | + } | ||
211 | + } | ||
212 | +} |
app/src/main/java/net/plil/clubinfo/etunicorn/data/Personne.java
0 → 100644
@@ -0,0 +1,55 @@ | @@ -0,0 +1,55 @@ | ||
1 | +package net.plil.clubinfo.etunicorn.data; | ||
2 | + | ||
3 | + | ||
4 | +import java.sql.Date; | ||
5 | + | ||
6 | +public class Personne { | ||
7 | + private int idPersonne; | ||
8 | + private int idCarte; | ||
9 | + private Date naissance; | ||
10 | + private int solde = 0; | ||
11 | + private String loginPoly; | ||
12 | + | ||
13 | + public Personne() { | ||
14 | + } | ||
15 | + | ||
16 | + public int getIdPersonne() { | ||
17 | + return idPersonne; | ||
18 | + } | ||
19 | + | ||
20 | + public void setIdPersonne(int idPersonne) { | ||
21 | + this.idPersonne = idPersonne; | ||
22 | + } | ||
23 | + | ||
24 | + public int getIdCarte() { | ||
25 | + return idCarte; | ||
26 | + } | ||
27 | + | ||
28 | + public void setIdCarte(int idCarte) { | ||
29 | + this.idCarte = idCarte; | ||
30 | + } | ||
31 | + | ||
32 | + public Date getNaissance() { | ||
33 | + return naissance; | ||
34 | + } | ||
35 | + | ||
36 | + public void setNaissance(Date naissance) { | ||
37 | + this.naissance = naissance; | ||
38 | + } | ||
39 | + | ||
40 | + public int getSolde() { | ||
41 | + return solde; | ||
42 | + } | ||
43 | + | ||
44 | + public void setSolde(int solde) { | ||
45 | + this.solde = solde; | ||
46 | + } | ||
47 | + | ||
48 | + public String getLoginPoly() { | ||
49 | + return loginPoly; | ||
50 | + } | ||
51 | + | ||
52 | + public void setLoginPoly(String loginPoly) { | ||
53 | + this.loginPoly = loginPoly; | ||
54 | + } | ||
55 | +} |
app/src/main/java/net/plil/clubinfo/etunicorn/utils/VolleyUtils.java
0 → 100644
@@ -0,0 +1,73 @@ | @@ -0,0 +1,73 @@ | ||
1 | +package net.plil.clubinfo.etunicorn.utils; | ||
2 | + | ||
3 | +import android.content.Context; | ||
4 | +import android.graphics.Bitmap; | ||
5 | +import android.util.LruCache; | ||
6 | + | ||
7 | +import com.android.volley.Request; | ||
8 | +import com.android.volley.RequestQueue; | ||
9 | +import com.android.volley.toolbox.ImageLoader; | ||
10 | +import com.android.volley.toolbox.Volley; | ||
11 | + | ||
12 | +/** | ||
13 | + * Created by badetitou on 28/01/2017. | ||
14 | + */ | ||
15 | + | ||
16 | +public class VolleyUtils { | ||
17 | + | ||
18 | + private static final String uri = "https://etunicorn.plil.net/"; | ||
19 | + private static final String version = "v1"; | ||
20 | + | ||
21 | + public static final String baseUri = VolleyUtils.uri + VolleyUtils.version + "/"; | ||
22 | + | ||
23 | + private static VolleyUtils mInstance; | ||
24 | + private RequestQueue mRequestQueue; | ||
25 | + private ImageLoader mImageLoader; | ||
26 | + private static Context mCtx; | ||
27 | + | ||
28 | + private VolleyUtils(Context context) { | ||
29 | + mCtx = context; | ||
30 | + mRequestQueue = getRequestQueue(); | ||
31 | + | ||
32 | + mImageLoader = new ImageLoader(mRequestQueue, | ||
33 | + new ImageLoader.ImageCache() { | ||
34 | + private final LruCache<String, Bitmap> | ||
35 | + cache = new LruCache<String, Bitmap>(20); | ||
36 | + | ||
37 | + @Override | ||
38 | + public Bitmap getBitmap(String url) { | ||
39 | + return cache.get(url); | ||
40 | + } | ||
41 | + | ||
42 | + @Override | ||
43 | + public void putBitmap(String url, Bitmap bitmap) { | ||
44 | + cache.put(url, bitmap); | ||
45 | + } | ||
46 | + }); | ||
47 | + } | ||
48 | + | ||
49 | + public static synchronized VolleyUtils getInstance(Context context) { | ||
50 | + if (mInstance == null) { | ||
51 | + mInstance = new VolleyUtils(context); | ||
52 | + } | ||
53 | + return mInstance; | ||
54 | + } | ||
55 | + | ||
56 | + public RequestQueue getRequestQueue() { | ||
57 | + if (mRequestQueue == null) { | ||
58 | + // getApplicationContext() is key, it keeps you from leaking the | ||
59 | + // Activity or BroadcastReceiver if someone passes one in. | ||
60 | + mRequestQueue = Volley.newRequestQueue(mCtx.getApplicationContext()); | ||
61 | + } | ||
62 | + return mRequestQueue; | ||
63 | + } | ||
64 | + | ||
65 | + public <T> void addToRequestQueue(Request<T> req) { | ||
66 | + getRequestQueue().add(req); | ||
67 | + } | ||
68 | + | ||
69 | + public ImageLoader getImageLoader() { | ||
70 | + return mImageLoader; | ||
71 | + } | ||
72 | +} | ||
73 | + |
@@ -0,0 +1,76 @@ | @@ -0,0 +1,76 @@ | ||
1 | +<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||
2 | + xmlns:tools="http://schemas.android.com/tools" | ||
3 | + android:layout_width="match_parent" | ||
4 | + android:layout_height="match_parent" | ||
5 | + android:gravity="center_horizontal" | ||
6 | + android:orientation="vertical" | ||
7 | + android:paddingBottom="@dimen/activity_vertical_margin" | ||
8 | + android:paddingLeft="@dimen/activity_horizontal_margin" | ||
9 | + android:paddingRight="@dimen/activity_horizontal_margin" | ||
10 | + android:paddingTop="@dimen/activity_vertical_margin" | ||
11 | + tools:context="net.plil.clubinfo.etunicorn.app.LoginActivity"> | ||
12 | + | ||
13 | + <!-- Login progress --> | ||
14 | + <ProgressBar | ||
15 | + android:id="@+id/login_progress" | ||
16 | + style="?android:attr/progressBarStyleLarge" | ||
17 | + android:layout_width="wrap_content" | ||
18 | + android:layout_height="wrap_content" | ||
19 | + android:layout_marginBottom="8dp" | ||
20 | + android:visibility="gone" /> | ||
21 | + | ||
22 | + <ScrollView | ||
23 | + android:id="@+id/login_form" | ||
24 | + android:layout_width="match_parent" | ||
25 | + android:layout_height="match_parent"> | ||
26 | + | ||
27 | + <LinearLayout | ||
28 | + android:id="@+id/email_login_form" | ||
29 | + android:layout_width="match_parent" | ||
30 | + android:layout_height="wrap_content" | ||
31 | + android:orientation="vertical"> | ||
32 | + | ||
33 | + <android.support.design.widget.TextInputLayout | ||
34 | + android:layout_width="match_parent" | ||
35 | + android:layout_height="wrap_content"> | ||
36 | + | ||
37 | + <EditText | ||
38 | + android:id="@+id/username" | ||
39 | + android:layout_width="match_parent" | ||
40 | + android:layout_height="wrap_content" | ||
41 | + android:hint="@string/prompt_username" | ||
42 | + android:inputType="none" | ||
43 | + android:maxLines="1" | ||
44 | + android:singleLine="true" /> | ||
45 | + | ||
46 | + </android.support.design.widget.TextInputLayout> | ||
47 | + | ||
48 | + <android.support.design.widget.TextInputLayout | ||
49 | + android:layout_width="match_parent" | ||
50 | + android:layout_height="wrap_content"> | ||
51 | + | ||
52 | + <EditText | ||
53 | + android:id="@+id/password" | ||
54 | + android:layout_width="match_parent" | ||
55 | + android:layout_height="wrap_content" | ||
56 | + android:hint="@string/prompt_password" | ||
57 | + android:imeActionId="@+id/login" | ||
58 | + android:imeActionLabel="@string/action_sign_in_short" | ||
59 | + android:imeOptions="actionUnspecified" | ||
60 | + android:inputType="textPassword" | ||
61 | + android:maxLines="1" | ||
62 | + android:singleLine="true" /> | ||
63 | + </android.support.design.widget.TextInputLayout> | ||
64 | + | ||
65 | + <Button | ||
66 | + android:id="@+id/email_sign_in_button" | ||
67 | + style="?android:textAppearanceSmall" | ||
68 | + android:layout_width="match_parent" | ||
69 | + android:layout_height="wrap_content" | ||
70 | + android:layout_marginTop="16dp" | ||
71 | + android:text="@string/action_sign_in_short" | ||
72 | + android:textStyle="bold" /> | ||
73 | + | ||
74 | + </LinearLayout> | ||
75 | + </ScrollView> | ||
76 | +</LinearLayout> |
@@ -0,0 +1,42 @@ | @@ -0,0 +1,42 @@ | ||
1 | +<?xml version="1.0" encoding="utf-8"?> | ||
2 | +<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||
3 | + xmlns:app="http://schemas.android.com/apk/res-auto" | ||
4 | + xmlns:tools="http://schemas.android.com/tools" | ||
5 | + android:id="@+id/main_content" | ||
6 | + android:layout_width="match_parent" | ||
7 | + android:layout_height="match_parent" | ||
8 | + android:fitsSystemWindows="true" | ||
9 | + tools:context="net.plil.clubinfo.etunicorn.app.MainActivity"> | ||
10 | + | ||
11 | + <android.support.design.widget.AppBarLayout | ||
12 | + android:id="@+id/appbar" | ||
13 | + android:layout_width="match_parent" | ||
14 | + android:layout_height="wrap_content" | ||
15 | + android:paddingTop="@dimen/appbar_padding_top" | ||
16 | + android:theme="@style/AppTheme.AppBarOverlay"> | ||
17 | + | ||
18 | + <android.support.v7.widget.Toolbar | ||
19 | + android:id="@+id/toolbar" | ||
20 | + android:layout_width="match_parent" | ||
21 | + android:layout_height="?attr/actionBarSize" | ||
22 | + android:background="?attr/colorPrimary" | ||
23 | + app:layout_scrollFlags="scroll|enterAlways" | ||
24 | + app:popupTheme="@style/AppTheme.PopupOverlay"> | ||
25 | + | ||
26 | + </android.support.v7.widget.Toolbar> | ||
27 | + | ||
28 | + <android.support.design.widget.TabLayout | ||
29 | + android:id="@+id/tabs" | ||
30 | + android:layout_width="match_parent" | ||
31 | + android:layout_height="wrap_content" /> | ||
32 | + | ||
33 | + </android.support.design.widget.AppBarLayout> | ||
34 | + | ||
35 | + <android.support.v4.view.ViewPager | ||
36 | + android:id="@+id/container" | ||
37 | + android:layout_width="match_parent" | ||
38 | + android:layout_height="match_parent" | ||
39 | + app:layout_behavior="@string/appbar_scrolling_view_behavior" /> | ||
40 | + | ||
41 | + | ||
42 | +</android.support.design.widget.CoordinatorLayout> |
@@ -0,0 +1,13 @@ | @@ -0,0 +1,13 @@ | ||
1 | +<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||
2 | + xmlns:tools="http://schemas.android.com/tools" | ||
3 | + android:layout_width="match_parent" | ||
4 | + android:layout_height="match_parent" | ||
5 | + tools:context="net.plil.clubinfo.etunicorn.app.Crediter"> | ||
6 | + | ||
7 | + <!-- TODO: Update blank fragment layout --> | ||
8 | + <TextView | ||
9 | + android:layout_width="match_parent" | ||
10 | + android:layout_height="match_parent" | ||
11 | + android:text="@string/hello_blank_fragment" /> | ||
12 | + | ||
13 | +</FrameLayout> |
@@ -0,0 +1,13 @@ | @@ -0,0 +1,13 @@ | ||
1 | +<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||
2 | + xmlns:tools="http://schemas.android.com/tools" | ||
3 | + android:layout_width="match_parent" | ||
4 | + android:layout_height="match_parent" | ||
5 | + tools:context="net.plil.clubinfo.etunicorn.app.Debiter"> | ||
6 | + | ||
7 | + <!-- TODO: Update blank fragment layout --> | ||
8 | + <TextView | ||
9 | + android:layout_width="match_parent" | ||
10 | + android:layout_height="match_parent" | ||
11 | + android:text="@string/hello_blank_fragment" /> | ||
12 | + | ||
13 | +</FrameLayout> |
@@ -0,0 +1,16 @@ | @@ -0,0 +1,16 @@ | ||
1 | +<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||
2 | + xmlns:tools="http://schemas.android.com/tools" | ||
3 | + android:layout_width="match_parent" | ||
4 | + android:layout_height="match_parent" | ||
5 | + android:paddingBottom="@dimen/activity_vertical_margin" | ||
6 | + android:paddingLeft="@dimen/activity_horizontal_margin" | ||
7 | + android:paddingRight="@dimen/activity_horizontal_margin" | ||
8 | + android:paddingTop="@dimen/activity_vertical_margin" | ||
9 | + tools:context="net.plil.clubinfo.etunicorn.app.MainActivity$PlaceholderFragment"> | ||
10 | + | ||
11 | + <TextView | ||
12 | + android:id="@+id/section_label" | ||
13 | + android:layout_width="wrap_content" | ||
14 | + android:layout_height="wrap_content" /> | ||
15 | + | ||
16 | +</RelativeLayout> |
@@ -0,0 +1,10 @@ | @@ -0,0 +1,10 @@ | ||
1 | +<menu xmlns:android="http://schemas.android.com/apk/res/android" | ||
2 | + xmlns:app="http://schemas.android.com/apk/res-auto" | ||
3 | + xmlns:tools="http://schemas.android.com/tools" | ||
4 | + tools:context="net.plil.clubinfo.etunicorn.app.MainActivity"> | ||
5 | + <item | ||
6 | + android:id="@+id/action_settings" | ||
7 | + android:orderInCategory="100" | ||
8 | + android:title="@string/action_settings" | ||
9 | + app:showAsAction="never" /> | ||
10 | +</menu> |
3.34 KB
2.15 KB
4.73 KB
7.54 KB
10.2 KB
@@ -0,0 +1,10 @@ | @@ -0,0 +1,10 @@ | ||
1 | +<?xml version="1.0" encoding="utf-8"?> | ||
2 | +<resources> | ||
3 | + <string name="app_name">Etunicorn</string> | ||
4 | + <string name="action_sign_in_short">Se connecter</string> | ||
5 | + <string name="error_field_required">Ce champ est requis</string> | ||
6 | + <string name="error_incorrect_password">Mot de passe incorrect</string> | ||
7 | + <string name="error_invalid_password">Mot de passe invalide</string> | ||
8 | + <string name="prompt_password">Mot de passe</string> | ||
9 | + <string name="prompt_username">Nom d\'utilisateur</string> | ||
10 | +</resources> | ||
0 | \ No newline at end of file | 11 | \ No newline at end of file |
@@ -0,0 +1,9 @@ | @@ -0,0 +1,9 @@ | ||
1 | +<resources> | ||
2 | + | ||
3 | + <style name="AppTheme.NoActionBar"> | ||
4 | + <item name="windowActionBar">false</item> | ||
5 | + <item name="windowNoTitle">true</item> | ||
6 | + <item name="android:windowDrawsSystemBarBackgrounds">true</item> | ||
7 | + <item name="android:statusBarColor">@android:color/transparent</item> | ||
8 | + </style> | ||
9 | +</resources> |
@@ -0,0 +1,6 @@ | @@ -0,0 +1,6 @@ | ||
1 | +<resources> | ||
2 | + <!-- Example customization of dimensions originally defined in res/values/dimens.xml | ||
3 | + (such as screen margins) for screens with more than 820dp of available width. This | ||
4 | + would include 7" and 10" devices in landscape (~960dp and ~1280dp respectively). --> | ||
5 | + <dimen name="activity_horizontal_margin">64dp</dimen> | ||
6 | +</resources> |
@@ -0,0 +1,7 @@ | @@ -0,0 +1,7 @@ | ||
1 | +<resources> | ||
2 | + <!-- Default screen margins, per the Android Design guidelines. --> | ||
3 | + <dimen name="activity_horizontal_margin">16dp</dimen> | ||
4 | + <dimen name="activity_vertical_margin">16dp</dimen> | ||
5 | + <dimen name="fab_margin">16dp</dimen> | ||
6 | + <dimen name="appbar_padding_top">8dp</dimen> | ||
7 | +</resources> |
@@ -0,0 +1,17 @@ | @@ -0,0 +1,17 @@ | ||
1 | +<resources> | ||
2 | + <string name="app_name">Etunicorn</string> | ||
3 | + | ||
4 | + <!-- Strings related to login --> | ||
5 | + <string name="prompt_password">Password</string> | ||
6 | + <string name="action_sign_in_short">Sign in</string> | ||
7 | + <string name="error_invalid_password">This password is too short</string> | ||
8 | + <string name="error_incorrect_password">This password is incorrect</string> | ||
9 | + <string name="error_field_required">This field is required</string> | ||
10 | + <string name="prompt_username">Username</string> | ||
11 | + <string name="title_activity_main">MainActivity</string> | ||
12 | + <string name="action_settings">Settings</string> | ||
13 | + <string name="section_format">Hello World from section: %1$d</string> | ||
14 | + | ||
15 | + <!-- TODO: Remove or change this placeholder text --> | ||
16 | + <string name="hello_blank_fragment">Hello blank fragment</string> | ||
17 | +</resources> |
@@ -0,0 +1,20 @@ | @@ -0,0 +1,20 @@ | ||
1 | +<resources> | ||
2 | + | ||
3 | + <!-- Base application theme. --> | ||
4 | + <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar"> | ||
5 | + <!-- Customize your theme here. --> | ||
6 | + <item name="colorPrimary">@color/colorPrimary</item> | ||
7 | + <item name="colorPrimaryDark">@color/colorPrimaryDark</item> | ||
8 | + <item name="colorAccent">@color/colorAccent</item> | ||
9 | + </style> | ||
10 | + | ||
11 | + <style name="AppTheme.NoActionBar"> | ||
12 | + <item name="windowActionBar">false</item> | ||
13 | + <item name="windowNoTitle">true</item> | ||
14 | + </style> | ||
15 | + | ||
16 | + <style name="AppTheme.AppBarOverlay" parent="ThemeOverlay.AppCompat.Dark.ActionBar" /> | ||
17 | + | ||
18 | + <style name="AppTheme.PopupOverlay" parent="ThemeOverlay.AppCompat.Light" /> | ||
19 | + | ||
20 | +</resources> |
@@ -0,0 +1,14 @@ | @@ -0,0 +1,14 @@ | ||
1 | +<?xml version="1.0" encoding="utf-8"?> | ||
2 | +<resources xmlns:xliff="urn:oasis:names:tc:xliff:document:1.2"> | ||
3 | + <tech-list> | ||
4 | + <tech>android.nfc.tech.IsoDep</tech> | ||
5 | + <tech>android.nfc.tech.NfcA</tech> | ||
6 | + <tech>android.nfc.tech.NfcB</tech> | ||
7 | + <tech>android.nfc.tech.NfcF</tech> | ||
8 | + <tech>android.nfc.tech.NfcV</tech> | ||
9 | + <tech>android.nfc.tech.Ndef</tech> | ||
10 | + <tech>android.nfc.tech.NdefFormatable</tech> | ||
11 | + <tech>android.nfc.tech.MifareClassic</tech> | ||
12 | + <tech>android.nfc.tech.MifareUltralight</tech> | ||
13 | + </tech-list> | ||
14 | +</resources> | ||
0 | \ No newline at end of file | 15 | \ No newline at end of file |
app/src/test/java/net/plil/clubinfo/etunicorn/ExampleUnitTest.java
0 → 100644
@@ -0,0 +1,17 @@ | @@ -0,0 +1,17 @@ | ||
1 | +package net.plil.clubinfo.etunicorn; | ||
2 | + | ||
3 | +import org.junit.Test; | ||
4 | + | ||
5 | +import static org.junit.Assert.*; | ||
6 | + | ||
7 | +/** | ||
8 | + * Example local unit test, which will execute on the development machine (host). | ||
9 | + * | ||
10 | + * @see <a href="http://d.android.com/tools/testing">Testing documentation</a> | ||
11 | + */ | ||
12 | +public class ExampleUnitTest { | ||
13 | + @Test | ||
14 | + public void addition_isCorrect() throws Exception { | ||
15 | + assertEquals(4, 2 + 2); | ||
16 | + } | ||
17 | +} | ||
0 | \ No newline at end of file | 18 | \ No newline at end of file |
@@ -0,0 +1,23 @@ | @@ -0,0 +1,23 @@ | ||
1 | +// Top-level build file where you can add configuration options common to all sub-projects/modules. | ||
2 | + | ||
3 | +buildscript { | ||
4 | + repositories { | ||
5 | + jcenter() | ||
6 | + } | ||
7 | + dependencies { | ||
8 | + classpath 'com.android.tools.build:gradle:2.2.3' | ||
9 | + | ||
10 | + // NOTE: Do not place your application dependencies here; they belong | ||
11 | + // in the individual module build.gradle files | ||
12 | + } | ||
13 | +} | ||
14 | + | ||
15 | +allprojects { | ||
16 | + repositories { | ||
17 | + jcenter() | ||
18 | + } | ||
19 | +} | ||
20 | + | ||
21 | +task clean(type: Delete) { | ||
22 | + delete rootProject.buildDir | ||
23 | +} |
@@ -0,0 +1,17 @@ | @@ -0,0 +1,17 @@ | ||
1 | +# Project-wide Gradle settings. | ||
2 | + | ||
3 | +# IDE (e.g. Android Studio) users: | ||
4 | +# Gradle settings configured through the IDE *will override* | ||
5 | +# any settings specified in this file. | ||
6 | + | ||
7 | +# For more details on how to configure your build environment visit | ||
8 | +# http://www.gradle.org/docs/current/userguide/build_environment.html | ||
9 | + | ||
10 | +# Specifies the JVM arguments used for the daemon process. | ||
11 | +# The setting is particularly useful for tweaking memory settings. | ||
12 | +org.gradle.jvmargs=-Xmx1536m | ||
13 | + | ||
14 | +# When configured, Gradle will run in incubating parallel mode. | ||
15 | +# This option should only be used with decoupled projects. More details, visit | ||
16 | +# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects | ||
17 | +# org.gradle.parallel=true |
No preview for this file type
@@ -0,0 +1,160 @@ | @@ -0,0 +1,160 @@ | ||
1 | +#!/usr/bin/env bash | ||
2 | + | ||
3 | +############################################################################## | ||
4 | +## | ||
5 | +## Gradle start up script for UN*X | ||
6 | +## | ||
7 | +############################################################################## | ||
8 | + | ||
9 | +# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||
10 | +DEFAULT_JVM_OPTS="" | ||
11 | + | ||
12 | +APP_NAME="Gradle" | ||
13 | +APP_BASE_NAME=`basename "$0"` | ||
14 | + | ||
15 | +# Use the maximum available, or set MAX_FD != -1 to use that value. | ||
16 | +MAX_FD="maximum" | ||
17 | + | ||
18 | +warn ( ) { | ||
19 | + echo "$*" | ||
20 | +} | ||
21 | + | ||
22 | +die ( ) { | ||
23 | + echo | ||
24 | + echo "$*" | ||
25 | + echo | ||
26 | + exit 1 | ||
27 | +} | ||
28 | + | ||
29 | +# OS specific support (must be 'true' or 'false'). | ||
30 | +cygwin=false | ||
31 | +msys=false | ||
32 | +darwin=false | ||
33 | +case "`uname`" in | ||
34 | + CYGWIN* ) | ||
35 | + cygwin=true | ||
36 | + ;; | ||
37 | + Darwin* ) | ||
38 | + darwin=true | ||
39 | + ;; | ||
40 | + MINGW* ) | ||
41 | + msys=true | ||
42 | + ;; | ||
43 | +esac | ||
44 | + | ||
45 | +# Attempt to set APP_HOME | ||
46 | +# Resolve links: $0 may be a link | ||
47 | +PRG="$0" | ||
48 | +# Need this for relative symlinks. | ||
49 | +while [ -h "$PRG" ] ; do | ||
50 | + ls=`ls -ld "$PRG"` | ||
51 | + link=`expr "$ls" : '.*-> \(.*\)$'` | ||
52 | + if expr "$link" : '/.*' > /dev/null; then | ||
53 | + PRG="$link" | ||
54 | + else | ||
55 | + PRG=`dirname "$PRG"`"/$link" | ||
56 | + fi | ||
57 | +done | ||
58 | +SAVED="`pwd`" | ||
59 | +cd "`dirname \"$PRG\"`/" >/dev/null | ||
60 | +APP_HOME="`pwd -P`" | ||
61 | +cd "$SAVED" >/dev/null | ||
62 | + | ||
63 | +CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar | ||
64 | + | ||
65 | +# Determine the Java command to use to start the JVM. | ||
66 | +if [ -n "$JAVA_HOME" ] ; then | ||
67 | + if [ -x "$JAVA_HOME/jre/sh/java" ] ; then | ||
68 | + # IBM's JDK on AIX uses strange locations for the executables | ||
69 | + JAVACMD="$JAVA_HOME/jre/sh/java" | ||
70 | + else | ||
71 | + JAVACMD="$JAVA_HOME/bin/java" | ||
72 | + fi | ||
73 | + if [ ! -x "$JAVACMD" ] ; then | ||
74 | + die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME | ||
75 | + | ||
76 | +Please set the JAVA_HOME variable in your environment to match the | ||
77 | +location of your Java installation." | ||
78 | + fi | ||
79 | +else | ||
80 | + JAVACMD="java" | ||
81 | + which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||
82 | + | ||
83 | +Please set the JAVA_HOME variable in your environment to match the | ||
84 | +location of your Java installation." | ||
85 | +fi | ||
86 | + | ||
87 | +# Increase the maximum file descriptors if we can. | ||
88 | +if [ "$cygwin" = "false" -a "$darwin" = "false" ] ; then | ||
89 | + MAX_FD_LIMIT=`ulimit -H -n` | ||
90 | + if [ $? -eq 0 ] ; then | ||
91 | + if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then | ||
92 | + MAX_FD="$MAX_FD_LIMIT" | ||
93 | + fi | ||
94 | + ulimit -n $MAX_FD | ||
95 | + if [ $? -ne 0 ] ; then | ||
96 | + warn "Could not set maximum file descriptor limit: $MAX_FD" | ||
97 | + fi | ||
98 | + else | ||
99 | + warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT" | ||
100 | + fi | ||
101 | +fi | ||
102 | + | ||
103 | +# For Darwin, add options to specify how the application appears in the dock | ||
104 | +if $darwin; then | ||
105 | + GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" | ||
106 | +fi | ||
107 | + | ||
108 | +# For Cygwin, switch paths to Windows format before running java | ||
109 | +if $cygwin ; then | ||
110 | + APP_HOME=`cygpath --path --mixed "$APP_HOME"` | ||
111 | + CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` | ||
112 | + JAVACMD=`cygpath --unix "$JAVACMD"` | ||
113 | + | ||
114 | + # We build the pattern for arguments to be converted via cygpath | ||
115 | + ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` | ||
116 | + SEP="" | ||
117 | + for dir in $ROOTDIRSRAW ; do | ||
118 | + ROOTDIRS="$ROOTDIRS$SEP$dir" | ||
119 | + SEP="|" | ||
120 | + done | ||
121 | + OURCYGPATTERN="(^($ROOTDIRS))" | ||
122 | + # Add a user-defined pattern to the cygpath arguments | ||
123 | + if [ "$GRADLE_CYGPATTERN" != "" ] ; then | ||
124 | + OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)" | ||
125 | + fi | ||
126 | + # Now convert the arguments - kludge to limit ourselves to /bin/sh | ||
127 | + i=0 | ||
128 | + for arg in "$@" ; do | ||
129 | + CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -` | ||
130 | + CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option | ||
131 | + | ||
132 | + if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition | ||
133 | + eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"` | ||
134 | + else | ||
135 | + eval `echo args$i`="\"$arg\"" | ||
136 | + fi | ||
137 | + i=$((i+1)) | ||
138 | + done | ||
139 | + case $i in | ||
140 | + (0) set -- ;; | ||
141 | + (1) set -- "$args0" ;; | ||
142 | + (2) set -- "$args0" "$args1" ;; | ||
143 | + (3) set -- "$args0" "$args1" "$args2" ;; | ||
144 | + (4) set -- "$args0" "$args1" "$args2" "$args3" ;; | ||
145 | + (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; | ||
146 | + (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; | ||
147 | + (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; | ||
148 | + (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; | ||
149 | + (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; | ||
150 | + esac | ||
151 | +fi | ||
152 | + | ||
153 | +# Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules | ||
154 | +function splitJvmOpts() { | ||
155 | + JVM_OPTS=("$@") | ||
156 | +} | ||
157 | +eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS | ||
158 | +JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME" | ||
159 | + | ||
160 | +exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@" |
@@ -0,0 +1,90 @@ | @@ -0,0 +1,90 @@ | ||
1 | +@if "%DEBUG%" == "" @echo off | ||
2 | +@rem ########################################################################## | ||
3 | +@rem | ||
4 | +@rem Gradle startup script for Windows | ||
5 | +@rem | ||
6 | +@rem ########################################################################## | ||
7 | + | ||
8 | +@rem Set local scope for the variables with windows NT shell | ||
9 | +if "%OS%"=="Windows_NT" setlocal | ||
10 | + | ||
11 | +@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||
12 | +set DEFAULT_JVM_OPTS= | ||
13 | + | ||
14 | +set DIRNAME=%~dp0 | ||
15 | +if "%DIRNAME%" == "" set DIRNAME=. | ||
16 | +set APP_BASE_NAME=%~n0 | ||
17 | +set APP_HOME=%DIRNAME% | ||
18 | + | ||
19 | +@rem Find java.exe | ||
20 | +if defined JAVA_HOME goto findJavaFromJavaHome | ||
21 | + | ||
22 | +set JAVA_EXE=java.exe | ||
23 | +%JAVA_EXE% -version >NUL 2>&1 | ||
24 | +if "%ERRORLEVEL%" == "0" goto init | ||
25 | + | ||
26 | +echo. | ||
27 | +echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||
28 | +echo. | ||
29 | +echo Please set the JAVA_HOME variable in your environment to match the | ||
30 | +echo location of your Java installation. | ||
31 | + | ||
32 | +goto fail | ||
33 | + | ||
34 | +:findJavaFromJavaHome | ||
35 | +set JAVA_HOME=%JAVA_HOME:"=% | ||
36 | +set JAVA_EXE=%JAVA_HOME%/bin/java.exe | ||
37 | + | ||
38 | +if exist "%JAVA_EXE%" goto init | ||
39 | + | ||
40 | +echo. | ||
41 | +echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% | ||
42 | +echo. | ||
43 | +echo Please set the JAVA_HOME variable in your environment to match the | ||
44 | +echo location of your Java installation. | ||
45 | + | ||
46 | +goto fail | ||
47 | + | ||
48 | +:init | ||
49 | +@rem Get command-line arguments, handling Windowz variants | ||
50 | + | ||
51 | +if not "%OS%" == "Windows_NT" goto win9xME_args | ||
52 | +if "%@eval[2+2]" == "4" goto 4NT_args | ||
53 | + | ||
54 | +:win9xME_args | ||
55 | +@rem Slurp the command line arguments. | ||
56 | +set CMD_LINE_ARGS= | ||
57 | +set _SKIP=2 | ||
58 | + | ||
59 | +:win9xME_args_slurp | ||
60 | +if "x%~1" == "x" goto execute | ||
61 | + | ||
62 | +set CMD_LINE_ARGS=%* | ||
63 | +goto execute | ||
64 | + | ||
65 | +:4NT_args | ||
66 | +@rem Get arguments from the 4NT Shell from JP Software | ||
67 | +set CMD_LINE_ARGS=%$ | ||
68 | + | ||
69 | +:execute | ||
70 | +@rem Setup the command line | ||
71 | + | ||
72 | +set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar | ||
73 | + | ||
74 | +@rem Execute Gradle | ||
75 | +"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS% | ||
76 | + | ||
77 | +:end | ||
78 | +@rem End local scope for the variables with windows NT shell | ||
79 | +if "%ERRORLEVEL%"=="0" goto mainEnd | ||
80 | + | ||
81 | +:fail | ||
82 | +rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of | ||
83 | +rem the _cmd.exe /c_ return code! | ||
84 | +if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 | ||
85 | +exit /b 1 | ||
86 | + | ||
87 | +:mainEnd | ||
88 | +if "%OS%"=="Windows_NT" endlocal | ||
89 | + | ||
90 | +:omega |
@@ -0,0 +1 @@ | @@ -0,0 +1 @@ | ||
1 | +include ':app' |