Subversion Repositories eFlore/Applications.coel

Rev

Rev 848 | Rev 883 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
69 jpm 1
package org.tela_botanica.client.modeles;
2
 
3
import java.io.Serializable;
385 gduche 4
import java.util.Collection;
248 gduche 5
import java.util.HashMap;
193 jp_milcent 6
import java.util.Iterator;
248 gduche 7
import java.util.LinkedList;
306 jp_milcent 8
import java.util.Map;
193 jp_milcent 9
import java.util.Set;
306 jp_milcent 10
import java.util.TreeSet;
69 jpm 11
 
233 jp_milcent 12
import org.tela_botanica.client.util.UtilArray;
13
 
534 gduche 14
import com.extjs.gxt.ui.client.core.FastMap;
69 jpm 15
import com.extjs.gxt.ui.client.data.BaseModelData;
602 jp_milcent 16
import com.google.gwt.core.client.GWT;
385 gduche 17
import com.google.gwt.http.client.URL;
775 jpm 18
import com.google.gwt.json.client.JSONObject;
69 jpm 19
 
193 jp_milcent 20
/**
21
 * @author jpm
22
 *
23
 */
69 jpm 24
public abstract class aDonnee extends BaseModelData implements Serializable {
25
 
26
	private static final long serialVersionUID = 3527760464061629791L;
748 jpm 27
 
789 jpm 28
	public static final String TYPE_AUTRE = "AUTRE";
29
	public static final String TYPE_TOTAL = "TOTAL";
30
	public static final String SEPARATEUR_TYPE_VALEUR = "##";
31
	public static final String SEPARATEUR_VALEURS = ";;";
32
	public static final String SEPARATEUR_DONNEES = "||";
875 jpm 33
	public static final String ETAT_AJOUTE = "A";
789 jpm 34
 
748 jpm 35
	protected abstract String getPrefixe();
36
 
789 jpm 37
	public String getDateModification() {
38
		return (String) renvoyerValeurCorrecte("cmhl_date_modification");
39
	}
40
 
41
	public String getNotes() {
42
		return (String) renvoyerValeurCorrecte("cmhl_notes");
43
	}
44
 
45
	public String getIdModifierPar() {
46
		return (String) renvoyerValeurCorrecte("cmhl_ce_modifier_par");
47
	}
48
 
49
	public String getIdEtat() {
50
		return (String) renvoyerValeurCorrecte("cmhl_ce_etat");
51
	}
52
 
53
	public String getIp() {
54
		return (String) renvoyerValeurCorrecte("cmhl_ip");
55
	}
56
 
775 jpm 57
	protected void initialiserModele(JSONObject jsonObjet) {
58
		// l'objet JSON est une table de hachage
59
		Set<String> im = jsonObjet.keySet();
60
 
61
		// Parcourt pour chaque clé
62
		for (Iterator<String> it = im.iterator(); it.hasNext();) {
63
			// Si elle est associée à une valeur, nous l'ajoutons
64
			String cle = it.next();
65
			if (cle.startsWith(getPrefixe()+"_")) {
66
				// Suppression de l'abréviation du champ. Inutile dans le contexte d'un objet
67
				String cleObjet = cle.replaceFirst("^"+getPrefixe()+"_", "");
68
				// Sinon, nous ajoutons la clé avec une valeur vide
69
				String valeur = "";
70
				if (jsonObjet.get(cle).isString() != null) {
71
					valeur = jsonObjet.get(cle).isString().stringValue();
72
				}
73
				this.set(cleObjet, valeur);
74
			}
75
		}
76
	}
77
 
69 jpm 78
	/**
79
	 * Pour éviter que l'on traite des valeurs nulles à l'affichage on passe par
80
	 * cette fonction qui retire les charactères nuls qui font planter
81
	 * l'affichage, il ne faut pas utiliser get directement
82
	 *
83
	 * @param cle
84
	 * @return la valeur associée à la clé
85
	 */
193 jp_milcent 86
	protected String renvoyerValeurCorrecte(String cle) {
188 jp_milcent 87
		String sortie = "";
69 jpm 88
		if (this.get(cle) != null) {
89
			String valeur = this.get(cle);
188 jp_milcent 90
			if (! valeur.equals("null")) {
69 jpm 91
				char nullChar = '\u0000';
92
				String sNull = "" + nullChar;
93
				valeur = valeur.replaceAll(sNull, "");
188 jp_milcent 94
				sortie =  valeur;
69 jpm 95
			}
96
		}
188 jp_milcent 97
		return sortie;
69 jpm 98
	}
233 jp_milcent 99
 
193 jp_milcent 100
	/**
242 jp_milcent 101
	 * Ajoute un nouvel élément avec son type à une chaine dénormalisée.
102
	 * Champ de type "truk" contenant des valeurs séparées par ";;" qui elle même possèdent un type séparé par "##".
103
	 * Si l'élément existe déjà, il ne sera pas ajouté.
193 jp_milcent 104
	 *
105
	 * @param champ le nom du champ dénormalisé
106
	 * @param type le type de la valeur à ajouter
107
	 * @param valeur la valeur à ajouter
108
	 */
242 jp_milcent 109
	protected void ajouterChaineDenormaliseAvecType(String champ, String type, Object valeur) {
193 jp_milcent 110
		if (valeur instanceof String) {
111
			String chaineExistante = renvoyerValeurCorrecte(champ);
112
			if (chaineExistante.equals("")) {
789 jpm 113
				this.set(champ, type+SEPARATEUR_TYPE_VALEUR+valeur);
193 jp_milcent 114
			} else {
242 jp_milcent 115
				// Si la valeur à ajouter n'est pas déjà présente, nous l'ajoutons
789 jpm 116
				if (!chaineExistante.matches("(^|"+SEPARATEUR_VALEURS+")"+type+SEPARATEUR_TYPE_VALEUR+valeur+"("+SEPARATEUR_VALEURS+"|$)")) {
117
					this.set(champ, chaineExistante+";;"+type+SEPARATEUR_TYPE_VALEUR+valeur);
242 jp_milcent 118
				}
193 jp_milcent 119
			}
120
		}
121
	}
119 jpm 122
 
306 jp_milcent 123
	protected void supprimerTypeDansChaineDenormalise(String champ, String type) {
124
		String chaineExistante = renvoyerValeurCorrecte(champ);
125
		if (!chaineExistante.equals("")) {
789 jpm 126
			if (chaineExistante.matches("(?:^|.*"+SEPARATEUR_VALEURS+")"+type+SEPARATEUR_TYPE_VALEUR+".*")) {
127
				chaineExistante = chaineExistante.replaceFirst("(^|.*"+SEPARATEUR_VALEURS+")"+type+SEPARATEUR_TYPE_VALEUR+".*?("+SEPARATEUR_VALEURS+".*|$)", "$1$2");
128
				chaineExistante = chaineExistante.replaceAll("(.*)"+SEPARATEUR_VALEURS+SEPARATEUR_VALEURS+"(.*)", "$1"+SEPARATEUR_VALEURS+"$2");
129
				chaineExistante = chaineExistante.replaceAll("^"+SEPARATEUR_VALEURS+"(.*)", "$1");
130
				chaineExistante = chaineExistante.replaceAll("(.*)"+SEPARATEUR_VALEURS+"$", "$1");
306 jp_milcent 131
				this.set(champ, chaineExistante);
132
			}
133
		}
134
	}
135
 
136
	protected void remplacerTypeDansChaineDenormalise(String champ, String type, Object valeur) {
137
		if (valeur != null && !valeur.equals("")) {
138
			ajouterChaineDenormaliseAvecType(champ, type, valeur);
139
		} else {
140
			supprimerTypeDansChaineDenormalise(champ, type);
141
		}
142
	}
233 jp_milcent 143
	/**
242 jp_milcent 144
	 * Ajoute un nouvel élément sans type à une chaine dénormalisée.
145
	 * Champ de type "truk" contenant seulement des valeurs séparées par ";;".
146
	 * Si l'élément existe déjà, il ne sera pas ajouté.
147
	 *
148
	 * @param champ le nom du champ dénormalisé
149
	 * @param valeur la valeur à ajouter
150
	 */
151
	protected void ajouterChaineDenormalise(String champ, Object valeur) {
152
		if (valeur instanceof String) {
153
			String chaineExistante = renvoyerValeurCorrecte(champ);
154
			if (chaineExistante.equals("")) {
155
				this.set(champ, valeur);
156
			} else {
157
				// Si la valeur à ajouter n'est pas déjà présente, nous l'ajoutons
789 jpm 158
				if (!chaineExistante.matches("(^|"+SEPARATEUR_VALEURS+")"+valeur+"("+SEPARATEUR_VALEURS+"|$)")) {
159
					this.set(champ, chaineExistante+SEPARATEUR_VALEURS+valeur);
242 jp_milcent 160
				}
161
			}
162
		}
163
	}
164
 
165
	/**
233 jp_milcent 166
	 * Permet de constuire correctement une chaine dénormalisée unique (champ de type "ce_truk").
167
	 *
168
	 * @param champ le nom du champ dénormalisé
169
	 * @param type le type de la valeur à ajouter
170
	 * @param valeur la valeur à ajouter
171
	 */
793 jpm 172
	protected void setChaineDenormaliseUnique(String champ, String type, String valeur) {
608 jp_milcent 173
		if (valeur == null || valeur.equals("")) {
174
			this.set(champ, "");
175
		} else if (valeur instanceof String) {
793 jpm 176
			if (((String) valeur).matches("^[0-9]+$")) {
177
				this.set(champ, valeur);
178
			} else {
179
				this.set(champ, type+SEPARATEUR_TYPE_VALEUR+valeur);
180
			}
233 jp_milcent 181
		}
182
	}
183
 
245 jp_milcent 184
	/**
185
	 * Permet de récupérer pour l'affichage une chaine dénormalisée unique (champ de type "ce_truk").
186
	 *
187
	 * @param champ le nom du champ dénormalisé
188
	 */
189
	protected String getChaineDenormaliseUnique(String champ) {
793 jpm 190
		String valeur = renvoyerValeurCorrecte(champ);
245 jp_milcent 191
 
793 jpm 192
		if (!valeur.equals("")) {
193
			valeur = valeur.replaceFirst("^"+TYPE_AUTRE+SEPARATEUR_TYPE_VALEUR, "");
245 jp_milcent 194
		}
195
 
793 jpm 196
		return valeur;
245 jp_milcent 197
	}
198
 
208 jp_milcent 199
	protected String getInfoDenormaliseParType(String chaineExistante, String type) {
200
		String sortie = "";
201
		if (!chaineExistante.equals("")) {
789 jpm 202
			String[] valeurs = chaineExistante.split(SEPARATEUR_VALEURS);
208 jp_milcent 203
			for (int i = 0; i < valeurs.length; i++) {
789 jpm 204
				if (valeurs[i].startsWith(type+SEPARATEUR_TYPE_VALEUR)) {
205
					sortie =  valeurs[i].replaceFirst("^"+type+SEPARATEUR_TYPE_VALEUR, "");
208 jp_milcent 206
				}
207
			}
208
		}
209
		return sortie;
210
	}
211
 
248 gduche 212
 
233 jp_milcent 213
	/**
248 gduche 214
	 * Permet de récupérer une map avec toutes les valeurs de la chaine truk sous la forme clé => valeur
215
	 *
216
	 * @param champ le nom du champ dénormalisé
217
	 * @return map ou liste en fonction du type de chaine truk (list si champ;;champ;; map si type##champ;;)
218
	 */
219
 
220
	public Object getChaineDenormaliseAsMapOrList(String champ)	{
221
 
222
			Object retourObjet = null;
223
 
224
			String valeurChamp = renvoyerValeurCorrecte(champ);
252 gduche 225
 
226
			if ((valeurChamp!=null)&&(!valeurChamp.trim().equals("")))	{
789 jpm 227
				String[] valeurs = valeurChamp.split(SEPARATEUR_VALEURS);
252 gduche 228
 
229
				if (valeurs.length > 0)	{
789 jpm 230
					if (valeurs[0].contains(SEPARATEUR_TYPE_VALEUR))	{
252 gduche 231
						// Les champs sont typés, on en fait une Map
748 jpm 232
						HashMap<String,String> mapValeurs = new HashMap<String,String>();
252 gduche 233
						for (int i = 0; i < valeurs.length; i++)	{
789 jpm 234
							String typeEtValeur[] = valeurs[i].split(SEPARATEUR_TYPE_VALEUR);
235
							mapValeurs.put(typeEtValeur[1], typeEtValeur[0]);
252 gduche 236
						}
237
						retourObjet = mapValeurs;
248 gduche 238
					}
252 gduche 239
					else	{
240
 
241
						//Les champs ne sont pas typés, on en fait une Liste
748 jpm 242
						LinkedList<String> listeValeurs = new LinkedList<String>();
252 gduche 243
						for (int i = 0; i < valeurs.length; i++)	{
244
							if ((valeurs[i]!=null)&&(!valeurs[i].equals("")))	{
245
								listeValeurs.add(valeurs[i]);
246
							}
249 gduche 247
						}
252 gduche 248
						retourObjet = listeValeurs;
248 gduche 249
					}
252 gduche 250
 
248 gduche 251
				}
252
			}
253
 
254
			return retourObjet;
255
 
256
	}
257
 
258
 
259
	/**
233 jp_milcent 260
	 * Permet de modifier correctement une chaine dénormalisée (champ de type "truk").
261
	 * Remplace par la valeur de la première instance du type indiqué dans la chaine dénormalisée.
602 jp_milcent 262
	 * Si aucun type n'est trouvé, nous en ajoutons un avec la nouvelle valeur.
233 jp_milcent 263
	 *
264
	 * @param champ le nom du champ dénormalisé
265
	 * @param type le type de la valeur à modifier
266
	 * @param valeur la valeur pour le type en question
267
	 */
242 jp_milcent 268
	protected void modifierChaineDenormaliseParType(String champ, String type, Object valeur) {
608 jp_milcent 269
		if (valeur == null || valeur.equals("")) {
602 jp_milcent 270
			supprimerTypeDansChaineDenormalise(champ, type);
271
		} else if (valeur instanceof String) {
233 jp_milcent 272
			String chaineExistante = renvoyerValeurCorrecte(champ);
602 jp_milcent 273
 
233 jp_milcent 274
			if (chaineExistante.equals("")) {
789 jpm 275
				this.set(champ, type+SEPARATEUR_TYPE_VALEUR+valeur);
233 jp_milcent 276
			} else {
789 jpm 277
				String[] valeurs = chaineExistante.split(SEPARATEUR_VALEURS);
602 jp_milcent 278
				HashMap<String,String> valeursModifiees = new HashMap<String,String>();
233 jp_milcent 279
				for (int i = 0; i < valeurs.length; i++) {
789 jpm 280
					if (valeurs[i].startsWith(type+SEPARATEUR_TYPE_VALEUR)) {
281
						valeursModifiees.put(type, type+SEPARATEUR_TYPE_VALEUR+valeur);
282
					} else if (i == (valeurs.length -1) && !valeurs[i].startsWith(type+SEPARATEUR_TYPE_VALEUR)) {
283
						valeursModifiees.put(valeurs[i].split(SEPARATEUR_TYPE_VALEUR)[0], valeurs[i]);
284
						valeursModifiees.put(type, type+SEPARATEUR_TYPE_VALEUR+valeur);
602 jp_milcent 285
					} else {
789 jpm 286
						valeursModifiees.put(valeurs[i].split(SEPARATEUR_TYPE_VALEUR)[0], valeurs[i]);
233 jp_milcent 287
					}
288
				}
602 jp_milcent 289
				String[] tableauValeursModifiees = valeursModifiees.values().toArray(new String[valeursModifiees.size()]);
789 jpm 290
				this.set(champ, UtilArray.implode(tableauValeursModifiees, SEPARATEUR_VALEURS));
233 jp_milcent 291
			}
292
		}
293
	}
294
 
208 jp_milcent 295
	protected String getInfoDenormaliseParPosition(String chaineExistante, int position) {
296
		String sortie = "";
297
		if (!chaineExistante.equals("")) {
789 jpm 298
			String[] valeurs = chaineExistante.split(SEPARATEUR_VALEURS);
208 jp_milcent 299
			if (valeurs.length >= position) {
300
				for (int i = 0; i < valeurs.length; i++) {
301
					if (i == (position - 1)) {
789 jpm 302
						if (valeurs[i].contains(SEPARATEUR_TYPE_VALEUR)) {
303
							sortie = valeurs[i].replaceFirst("^[^#]+"+SEPARATEUR_VALEURS, "");
208 jp_milcent 304
						} else {
603 jp_milcent 305
							sortie = valeurs[i];
208 jp_milcent 306
						}
307
						break;
308
					}
309
				}
310
			}
311
		}
312
		return sortie;
313
	}
314
 
233 jp_milcent 315
	/**
316
	 * Permet de modifier correctement une chaine dénormalisée (champ de type "truk").
317
	 * Remplace par la valeur l'instance dont la position a été indiquée.
242 jp_milcent 318
	 * Si la chaine dénormalisée est vide, l'élement est ajouté quelque soit la position indiquée.
319
	 * Si la position est supérieure au nombre d'élément de la chaine dénormalisé, rien n'est modifié.
233 jp_milcent 320
	 *
321
	 * @param champ le nom du champ dénormalisé
322
	 * @param position le type de la valeur à modifier
323
	 * @param valeur la valeur à remplacer à la position indiquée
324
	 */
242 jp_milcent 325
	protected void modifierChaineDenormaliseParPosition(String champ, int position, Object valeur) {
608 jp_milcent 326
		if (valeur == null || valeur.equals("")) {
603 jp_milcent 327
			supprimerChaineDenormaliseParPosition(champ, position);
328
		} else if (valeur instanceof String) {
233 jp_milcent 329
			String chaineExistante = renvoyerValeurCorrecte(champ);
603 jp_milcent 330
			if (chaineExistante.equals("")) {
331
				this.set(champ, valeur);
332
			} else {
789 jpm 333
				String[] valeurs = chaineExistante.split(SEPARATEUR_VALEURS);
603 jp_milcent 334
				if (valeurs.length >= position) {
233 jp_milcent 335
					for (int i = 0; i < valeurs.length; i++) {
336
						if (i == (position - 1)) {
337
							valeurs[i] = (String) valeur;
338
							break;
339
						}
340
					}
789 jpm 341
					this.set(champ, UtilArray.implode(valeurs, SEPARATEUR_VALEURS));
233 jp_milcent 342
				}
343
			}
344
		}
345
	}
346
 
603 jp_milcent 347
	protected void supprimerChaineDenormaliseParPosition(String champ, int position) {
348
		String chaineExistante = renvoyerValeurCorrecte(champ);
349
		if (!chaineExistante.equals("")) {
789 jpm 350
			String[] valeurs = chaineExistante.split(SEPARATEUR_VALEURS);
603 jp_milcent 351
			HashMap<String,String> valeursModifiees = new HashMap<String,String>();
352
			if (valeurs.length >= position) {
353
				for (int i = 0; i < valeurs.length; i++) {
354
					if (i != (position - 1)) {
355
						valeursModifiees.put(""+i, valeurs[i]);
356
					}
357
				}
358
				String[] tableauValeursModifiees = valeursModifiees.values().toArray(new String[valeursModifiees.size()]);
789 jpm 359
				this.set(champ, UtilArray.implode(tableauValeursModifiees, SEPARATEUR_VALEURS));
603 jp_milcent 360
			}
361
		}
362
	}
363
 
193 jp_milcent 364
	/** (non-Javadoc)
365
	 * @see java.lang.Object#toString()
366
	 */
367
	public String toString() {
368
		String sortie = "";
369
 
370
		// Champs du BaseModelData
371
		Set<String> proprietes = this.getProperties().keySet();
306 jp_milcent 372
		TreeSet<String> proprietesTriees = new TreeSet<String>(proprietes);
373
		for (Iterator<String> it = proprietesTriees.iterator(); it.hasNext();) {
193 jp_milcent 374
			String cle = it.next();
306 jp_milcent 375
			if (this.get(cle) != null && !this.get(cle).equals("")) {
202 jp_milcent 376
				sortie += cle+" : "+this.get(cle)+"\n";
377
			}
193 jp_milcent 378
		}
379
 
380
		return sortie;
381
	}
306 jp_milcent 382
 
383
	public Boolean comparer(BaseModelData objetAComparer) {
384
		Boolean retour = true;
385
		Map<String, Object> a = this.getProperties();
386
		Map<String, Object> b = objetAComparer.getProperties();
387
		if (a.size() != b.size()) {
388
			retour = false;
389
		} else {
390
			Set<String> cles = a.keySet();
391
			Iterator<String> it = cles.iterator();
392
			while (it.hasNext()) {
393
				String cle = it.next();
394
				if (a.get(cle) != null && !a.get(cle).equals(b.get(cle))) {
395
					retour = false;
396
					break;
397
				}
398
			}
399
		}
400
 
401
		return retour;
402
	}
403
 
404
	public Object cloner(BaseModelData nouvelleInstance) {
405
		Map<String, Object> proprietes = this.getProperties();
406
		Set<String> cles = proprietes.keySet();
407
		for (Iterator<String> it = cles.iterator(); it.hasNext();) {
408
			String cle = it.next();
409
			nouvelleInstance.set(cle, this.get(cle));
410
		}
411
 
412
		return nouvelleInstance;
413
	}
385 gduche 414
 
415
	/**
748 jpm 416
	 * Renvoie une chaîne de caractère formatée et encodée pour POST avec toutes les propriétés du modèle
385 gduche 417
	 * */
748 jpm 418
	public String obtenirChainePOST() {
419
		String post = "";
385 gduche 420
 
748 jpm 421
		FastMap<?> proprietees = (FastMap<?>) getProperties();
422
		Collection<String> cles = proprietees.keySet();
423
		Iterator<String> it = cles.iterator();
385 gduche 424
 
425
		while (it.hasNext())	{
748 jpm 426
			String cle = it.next();
826 gduche 427
			//Les Radio Box couplées à la fonction autobind créer des variables gxt.RadioGroup.X, qu'il ne faut pas mettre dans la requête
428
			if (!cle.startsWith("gxt."))	{
429
				post += getPrefixe() + "_" +  cle + "=" + URL.encodeComponent(renvoyerValeurCorrecte(cle));
430
				if (it.hasNext())	{
431
					post += "&";
432
				}
385 gduche 433
			}
434
		}
435
 
748 jpm 436
		return post;
786 jpm 437
	}
438
 
439
	/**
440
	 * Met à jour l'objet this avec les données de l'objet passé en paramêtre.
441
	 *
442
	 * */
443
	public void mettreAJour(aDonnee nouveau) {
444
		Collection<String> cles = nouveau.getProperties().keySet();
445
		Iterator<String> it = cles.iterator();
446
		while (it.hasNext())	{
447
			String cle = it.next();
448
			if (!this.get(cle).equals(nouveau.get(cle))) {
449
				this.set(cle, nouveau.get(cle));
450
			}
451
		}
452
	}
69 jpm 453
}