c8059613
JLo'w
Re-fonte de l'app...
|
1
2
|
package com.example.app_10p5;
|
c8059613
JLo'w
Re-fonte de l'app...
|
3
|
import android.content.Intent;
|
c8059613
JLo'w
Re-fonte de l'app...
|
4
|
import android.os.Bundle;
|
96cf88d2
JLo'w
Réception de JSON...
|
5
|
import android.os.SystemClock;
|
c8059613
JLo'w
Re-fonte de l'app...
|
6
7
|
import android.support.design.widget.TabLayout;
import android.support.v4.app.FragmentActivity;
|
c8059613
JLo'w
Re-fonte de l'app...
|
8
9
|
import android.support.v4.view.ViewPager;
import android.view.View;
|
520cecde
JLo'w
Un petit plus, un...
|
10
|
import android.widget.EditText;
|
93f90e35
JLo'w
NFC et foreground
|
11
12
|
import android.widget.Toast;
|
c1f92981
JLo'w
Implémentation de...
|
13
14
15
16
17
|
import org.json.JSONObject;
import java.net.URL;
import java.util.HashMap;
|
c8059613
JLo'w
Re-fonte de l'app...
|
18
19
20
21
|
/**
* Created by beaus on 24/04/2016.
*/
|
c1f92981
JLo'w
Implémentation de...
|
22
|
public class MainActivite extends FragmentActivity implements ASyncResponse {
|
c8059613
JLo'w
Re-fonte de l'app...
|
23
|
|
520cecde
JLo'w
Un petit plus, un...
|
24
25
26
27
28
29
30
31
32
33
|
public static final int STATE_RIEN = 0;
public static final int STATE_COMMANDE = 3;
public static final int STATE_VIDANGE = 4;
public static final int STATE_RECHARGEMENT = 2;
public static final int STATE_CREATION_COMPTE = 1;
public static final int STATE_CONNEXION = 5;
public static final long EXPIRATION = 1000*60*10;
private int mState;
private String mToken;
|
8cd8911a
JLo'w
Connexion enfin f...
|
34
|
private int mDroit;
|
520cecde
JLo'w
Un petit plus, un...
|
35
|
private long mTimeToken;
|
8cd8911a
JLo'w
Connexion enfin f...
|
36
|
private String mUser;
|
520cecde
JLo'w
Un petit plus, un...
|
37
|
|
c8059613
JLo'w
Re-fonte de l'app...
|
38
39
40
41
|
@Override
protected void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.layout_main);
|
520cecde
JLo'w
Un petit plus, un...
|
42
43
44
45
46
|
mState = STATE_RIEN;
mTimeToken = -1;
mToken = "";
|
c8059613
JLo'w
Re-fonte de l'app...
|
47
48
|
TabLayout tabLayout = (TabLayout) findViewById(R.id.tab_layout);
tabLayout.setTabMode(TabLayout.MODE_SCROLLABLE);
|
520cecde
JLo'w
Un petit plus, un...
|
49
|
tabLayout.addTab(tabLayout.newTab().setText("Connexion"));
|
c8059613
JLo'w
Re-fonte de l'app...
|
50
51
52
53
|
tabLayout.addTab(tabLayout.newTab().setText("Commande"));
tabLayout.addTab(tabLayout.newTab().setText("Rechargement"));
tabLayout.addTab(tabLayout.newTab().setText("Création"));
tabLayout.addTab(tabLayout.newTab().setText("Vidange"));
|
c8059613
JLo'w
Re-fonte de l'app...
|
54
55
56
57
58
59
60
61
62
63
|
tabLayout.setTabGravity(TabLayout.GRAVITY_FILL);
final ViewPager viewPager = (ViewPager) findViewById(R.id.pager);
final PagerAdapter adapter = new PagerAdapter
(getSupportFragmentManager(), tabLayout.getTabCount());
viewPager.setAdapter(adapter);
viewPager.addOnPageChangeListener(new TabLayout.TabLayoutOnPageChangeListener(tabLayout));
tabLayout.setOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
@Override
public void onTabSelected(TabLayout.Tab tab) {
|
520cecde
JLo'w
Un petit plus, un...
|
64
65
66
67
68
69
|
if(mToken != "" && System.currentTimeMillis() - mTimeToken < EXPIRATION){
viewPager.setCurrentItem(tab.getPosition());
}
else{
viewPager.setCurrentItem(tab.getPosition()); //Empeche un bug graphique
viewPager.setCurrentItem(0);
|
c66109e1
JLo'w
Ajout du code des...
|
70
|
Toast.makeText(MainActivite.this, "Veuillez vous connecter biatche.", Toast.LENGTH_LONG).show();
|
520cecde
JLo'w
Un petit plus, un...
|
71
|
}
|
c8059613
JLo'w
Re-fonte de l'app...
|
72
73
74
75
76
77
78
79
80
81
82
83
84
85
|
}
@Override
public void onTabUnselected(TabLayout.Tab tab) {
}
@Override
public void onTabReselected(TabLayout.Tab tab) {
}
});
}
|
c66109e1
JLo'w
Ajout du code des...
|
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
|
@Override
public void onSaveInstanceState(Bundle savedInstanceState){
savedInstanceState.putString("token", mToken);
savedInstanceState.putInt("state", mState);
savedInstanceState.putString("user", mUser);
savedInstanceState.putInt("droit", mDroit);
savedInstanceState.putLong("timeToken", mTimeToken);
super.onSaveInstanceState(savedInstanceState);
}
@Override
public void onRestoreInstanceState(Bundle savedInstanceState) {
mTimeToken = savedInstanceState.getLong("timeToken");
mToken = savedInstanceState.getString("user");
mState = savedInstanceState.getInt("state");
mUser = savedInstanceState.getString("user");
mDroit = savedInstanceState.getInt("droit");
super.onRestoreInstanceState(savedInstanceState);
}
public void valideCreationCompte(View v){
if((mToken != "") && ((System.currentTimeMillis() - mTimeToken) < EXPIRATION)) {
EditText champMontant = (EditText) findViewById(R.id.creation_montant);
float montant = 0.0f;
try{
montant = Float.parseFloat(champMontant.getText().toString());
}
catch (Throwable t){
Toast.makeText(this, "Remplir le champ montant avec un nombre: " + t.toString(), Toast.LENGTH_LONG).show();
}
if((montant > 0.0f) && (montant < 200.0f) && (mDroit >= 1)){
mState = STATE_CREATION_COMPTE;
Intent intent = new Intent(this, CarteActivite.class);
intent.putExtra("token", mToken);
intent.putExtra("state", mState);
intent.putExtra("montant", montant);
startActivityForResult(intent, mState);
}
else{
Toast.makeText(this, "Valeur incorrecte ou droit insuffisant.", Toast.LENGTH_LONG).show();
}
}
else{
Toast.makeText(this, "Veuillez vous reconnecter.", Toast.LENGTH_LONG).show();
final ViewPager viewPager = (ViewPager) findViewById(R.id.pager);
viewPager.setCurrentItem(0);
}
}
|
c8059613
JLo'w
Re-fonte de l'app...
|
139
140
|
public void valideCommande(View v)
{
|
520cecde
JLo'w
Un petit plus, un...
|
141
142
143
|
if((mToken != "") && ((System.currentTimeMillis() - mTimeToken) < EXPIRATION)) {
EditText champMontant = (EditText) findViewById(R.id.commande_prix);
EditText champQuantite = (EditText) findViewById(R.id.commande_quantite);
|
c66109e1
JLo'w
Ajout du code des...
|
144
145
146
147
148
149
150
151
152
153
154
|
float montant = 0.0f;
int quantite = 0;
try{
montant = Float.parseFloat(champMontant.getText().toString());
quantite = Integer.parseInt(champQuantite.getText().toString());
}
catch (Throwable t)
{
Toast.makeText(this, "Remplir les champs avec des nombres: " + t.toString(), Toast.LENGTH_LONG).show();
}
|
520cecde
JLo'w
Un petit plus, un...
|
155
|
|
c66109e1
JLo'w
Ajout du code des...
|
156
|
if ((montant > 0.0f) && (montant < 200.0f) && (quantite > 0) && (mDroit >= 1)) {
|
520cecde
JLo'w
Un petit plus, un...
|
157
158
159
160
161
162
163
164
|
mState = STATE_COMMANDE;
Intent intent = new Intent(this, CarteActivite.class);
intent.putExtra("token", mToken);
intent.putExtra("state", mState);
intent.putExtra("montant", montant);
intent.putExtra("quantite", quantite);
startActivityForResult(intent, mState);
}
|
c66109e1
JLo'w
Ajout du code des...
|
165
166
167
|
else{
Toast.makeText(this, "Valeur incorrecte ou droit insuffisant.", Toast.LENGTH_LONG).show();
}
|
520cecde
JLo'w
Un petit plus, un...
|
168
169
170
171
172
173
174
175
176
177
|
}
else{
Toast.makeText(this, "Veuillez vous reconnecter.", Toast.LENGTH_LONG).show();
final ViewPager viewPager = (ViewPager) findViewById(R.id.pager);
viewPager.setCurrentItem(0);
}
}
public void valideRechargement(View v)
{
|
96cf88d2
JLo'w
Réception de JSON...
|
178
|
if((mToken != "") && ((System.currentTimeMillis() - mTimeToken) < EXPIRATION)) {
|
c66109e1
JLo'w
Ajout du code des...
|
179
180
181
182
183
184
185
186
187
|
EditText champMontant = (EditText) findViewById(R.id.rechargement_champ_montant);
float montant = 0.0f;
try{
montant = Float.parseFloat(champMontant.getText().toString());
}
catch (Throwable t){
Toast.makeText(this, "Remplir le champ montant avec un nombre: " + t.toString(), Toast.LENGTH_LONG).show();
}
|
520cecde
JLo'w
Un petit plus, un...
|
188
|
|
c66109e1
JLo'w
Ajout du code des...
|
189
190
191
192
193
194
195
196
197
198
199
|
if((montant > 0.0f) && (montant < 200.0f) && (mDroit >= 2)){
mState = STATE_RECHARGEMENT;
Intent intent = new Intent(this, CarteActivite.class);
intent.putExtra("token", mToken);
intent.putExtra("state", mState);
intent.putExtra("montant", montant);
startActivityForResult(intent, mState);
}
else{
Toast.makeText(this, "Valeur incorrecte ou droit insuffisant.", Toast.LENGTH_LONG).show();
}
|
520cecde
JLo'w
Un petit plus, un...
|
200
201
202
203
204
205
206
207
208
209
210
211
212
|
}
else{
Toast.makeText(this, "Veuillez vous reconnecter.", Toast.LENGTH_LONG).show();
final ViewPager viewPager = (ViewPager) findViewById(R.id.pager);
viewPager.setCurrentItem(0);
}
}
public void valideConnection(View v)
{
EditText viewUser = (EditText) findViewById(R.id.connection_username);
EditText viewPsw = (EditText) findViewById(R.id.connection_password);
|
c1f92981
JLo'w
Implémentation de...
|
213
214
215
|
String user = viewUser.getText().toString();
String password = viewPsw.getText().toString();
|
520cecde
JLo'w
Un petit plus, un...
|
216
217
|
if ((user != "") && (password != "")) {
mState = STATE_CONNEXION;
|
c1f92981
JLo'w
Implémentation de...
|
218
219
|
try{
|
c1f92981
JLo'w
Implémentation de...
|
220
|
URL url = new URL(CarteActivite.HOST + "api/utilisateur/connexion");
|
c1f92981
JLo'w
Implémentation de...
|
221
222
223
224
225
226
227
228
229
230
|
HashMap<String, String> param = new HashMap<String, String>();
param.put("login", user);
param.put("mdp", password);
NetworkThread nt = new NetworkThread(url, param);
nt.delegate = this;
nt.execute();
}
catch (Throwable t) {
//TODO: gérer les exceptions du cancer de la connexion
}
|
520cecde
JLo'w
Un petit plus, un...
|
231
|
}
|
c66109e1
JLo'w
Ajout du code des...
|
232
233
234
|
else{
Toast.makeText(this, "Veuillez remplir les champs.", Toast.LENGTH_LONG).show();
}
|
520cecde
JLo'w
Un petit plus, un...
|
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
|
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data){
//TODO: faire des choses avec ca
switch (requestCode) {
case STATE_COMMANDE:
break;
case STATE_CONNEXION:
break;
case STATE_CREATION_COMPTE:
break;
case STATE_RECHARGEMENT:
break;
case STATE_VIDANGE:
break;
case STATE_RIEN:
default:
Toast.makeText(this, "WTF, le cancer est dans l'application!!", Toast.LENGTH_LONG).show();
break;
}
|
c8059613
JLo'w
Re-fonte de l'app...
|
256
|
}
|
93f90e35
JLo'w
NFC et foreground
|
257
|
|
c1f92981
JLo'w
Implémentation de...
|
258
259
260
|
/* Retour du network thread */
@Override
public void processFinish(JSONObject output) {
|
96cf88d2
JLo'w
Réception de JSON...
|
261
262
|
if(output.length() != 0){
try{
|
8cd8911a
JLo'w
Connexion enfin f...
|
263
264
|
if(output.get("status").toString().equals("ok")){
mToken = output.get("jeton").toString();
|
96cf88d2
JLo'w
Réception de JSON...
|
265
|
mTimeToken = System.currentTimeMillis();
|
8cd8911a
JLo'w
Connexion enfin f...
|
266
267
268
|
mDroit = output.getInt("droit");
mUser = output.get("login").toString();
Toast.makeText(this, "Bonjour " + mUser + " vous êtes bien connecté pour " + EXPIRATION / (1000 * 60) + " minutes.", Toast.LENGTH_LONG).show();
|
c66109e1
JLo'w
Ajout du code des...
|
269
270
|
final ViewPager viewPager = (ViewPager) findViewById(R.id.pager);
viewPager.setCurrentItem(1);
|
96cf88d2
JLo'w
Réception de JSON...
|
271
272
273
274
275
276
|
}
else{
Toast.makeText(this, "Erreur dans la requête: " + output.get("status"), Toast.LENGTH_LONG).show();
}
}
catch(Throwable t){
|
8cd8911a
JLo'w
Connexion enfin f...
|
277
|
Toast.makeText(this, "WTF, le cancer est dans l'application!!" + t.toString(), Toast.LENGTH_LONG).show();
|
96cf88d2
JLo'w
Réception de JSON...
|
278
279
280
281
282
|
}
}
else{
Toast.makeText(this, "Impossible de se connecter au serveur", Toast.LENGTH_LONG).show();
}
|
c1f92981
JLo'w
Implémentation de...
|
283
|
}
|
c8059613
JLo'w
Re-fonte de l'app...
|
284
|
}
|