Subversion Repositories eFlore/Applications.coel

Rev

Rev 252 | Rev 306 | 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;
248 gduche 4
import java.util.HashMap;
193 jp_milcent 5
import java.util.Iterator;
248 gduche 6
import java.util.LinkedList;
193 jp_milcent 7
import java.util.Set;
69 jpm 8
 
233 jp_milcent 9
import org.tela_botanica.client.util.UtilArray;
10
 
69 jpm 11
import com.extjs.gxt.ui.client.data.BaseModelData;
12
 
193 jp_milcent 13
/**
14
 * @author jpm
15
 *
16
 */
69 jpm 17
public abstract class aDonnee extends BaseModelData implements Serializable {
18
 
19
	/**
20
	 * Identifiant pour sérialisé l'objet...
21
	 */
22
	private static final long serialVersionUID = 3527760464061629791L;
23
 
24
	/**
25
	 * Pour éviter que l'on traite des valeurs nulles à l'affichage on passe par
26
	 * cette fonction qui retire les charactères nuls qui font planter
27
	 * l'affichage, il ne faut pas utiliser get directement
28
	 *
29
	 * @param cle
30
	 * @return la valeur associée à la clé
31
	 */
193 jp_milcent 32
	protected String renvoyerValeurCorrecte(String cle) {
188 jp_milcent 33
		String sortie = "";
69 jpm 34
		if (this.get(cle) != null) {
35
			String valeur = this.get(cle);
188 jp_milcent 36
			if (! valeur.equals("null")) {
69 jpm 37
				char nullChar = '\u0000';
38
				String sNull = "" + nullChar;
39
				valeur = valeur.replaceAll(sNull, "");
188 jp_milcent 40
				sortie =  valeur;
69 jpm 41
			}
42
		}
188 jp_milcent 43
		return sortie;
69 jpm 44
	}
233 jp_milcent 45
 
193 jp_milcent 46
	/**
242 jp_milcent 47
	 * Ajoute un nouvel élément avec son type à une chaine dénormalisée.
48
	 * Champ de type "truk" contenant des valeurs séparées par ";;" qui elle même possèdent un type séparé par "##".
49
	 * Si l'élément existe déjà, il ne sera pas ajouté.
193 jp_milcent 50
	 *
51
	 * @param champ le nom du champ dénormalisé
52
	 * @param type le type de la valeur à ajouter
53
	 * @param valeur la valeur à ajouter
54
	 */
242 jp_milcent 55
	protected void ajouterChaineDenormaliseAvecType(String champ, String type, Object valeur) {
193 jp_milcent 56
		if (valeur instanceof String) {
57
			String chaineExistante = renvoyerValeurCorrecte(champ);
58
			if (chaineExistante.equals("")) {
59
				this.set(champ, type+"##"+valeur);
60
			} else {
242 jp_milcent 61
				// Si la valeur à ajouter n'est pas déjà présente, nous l'ajoutons
62
				if (!chaineExistante.matches("(^|;;)"+type+"##"+valeur+"(;;|$)")) {
63
					this.set(champ, chaineExistante+";;"+type+"##"+valeur);
64
				}
193 jp_milcent 65
			}
66
		}
67
	}
119 jpm 68
 
233 jp_milcent 69
	/**
242 jp_milcent 70
	 * Ajoute un nouvel élément sans type à une chaine dénormalisée.
71
	 * Champ de type "truk" contenant seulement des valeurs séparées par ";;".
72
	 * Si l'élément existe déjà, il ne sera pas ajouté.
73
	 *
74
	 * @param champ le nom du champ dénormalisé
75
	 * @param valeur la valeur à ajouter
76
	 */
77
	protected void ajouterChaineDenormalise(String champ, Object valeur) {
78
		if (valeur instanceof String) {
79
			String chaineExistante = renvoyerValeurCorrecte(champ);
80
			if (chaineExistante.equals("")) {
81
				this.set(champ, valeur);
82
			} else {
83
				// Si la valeur à ajouter n'est pas déjà présente, nous l'ajoutons
84
				if (!chaineExistante.matches("(^|;;)"+valeur+"(;;|$)")) {
85
					this.set(champ, chaineExistante+";;"+valeur);
86
				}
87
			}
88
		}
89
	}
90
 
91
	/**
233 jp_milcent 92
	 * Permet de constuire correctement une chaine dénormalisée unique (champ de type "ce_truk").
93
	 *
94
	 * @param champ le nom du champ dénormalisé
95
	 * @param type le type de la valeur à ajouter
96
	 * @param valeur la valeur à ajouter
97
	 */
98
	protected void setChaineDenormaliseUnique(String champ, String type, Object valeur) {
99
		if (valeur instanceof String) {
100
			this.set(champ, type+"##"+valeur);
101
		}
102
	}
103
 
245 jp_milcent 104
	/**
105
	 * Permet de récupérer pour l'affichage une chaine dénormalisée unique (champ de type "ce_truk").
106
	 *
107
	 * @param champ le nom du champ dénormalisé
108
	 */
109
	protected String getChaineDenormaliseUnique(String champ) {
110
		String sortie = renvoyerValeurCorrecte(champ);
111
 
112
		if (!sortie.equals("")) {
113
			sortie = sortie.replaceFirst("^AUTRE##", "");
114
		}
115
 
116
		return sortie;
117
	}
118
 
208 jp_milcent 119
	protected String getInfoDenormaliseParType(String chaineExistante, String type) {
120
		String sortie = "";
121
		if (!chaineExistante.equals("")) {
122
			String[] valeurs = chaineExistante.split(";;");
123
			for (int i = 0; i < valeurs.length; i++) {
124
				if (valeurs[i].startsWith(type+"##")) {
125
					sortie =  valeurs[i].replaceFirst("^"+type+"##", "");
126
				}
127
			}
128
		}
129
		return sortie;
130
	}
131
 
248 gduche 132
 
233 jp_milcent 133
	/**
248 gduche 134
	 * Permet de récupérer une map avec toutes les valeurs de la chaine truk sous la forme clé => valeur
135
	 *
136
	 * @param champ le nom du champ dénormalisé
137
	 * @return map ou liste en fonction du type de chaine truk (list si champ;;champ;; map si type##champ;;)
138
	 */
139
 
140
	public Object getChaineDenormaliseAsMapOrList(String champ)	{
141
 
142
			Object retourObjet = null;
143
 
144
			String valeurChamp = renvoyerValeurCorrecte(champ);
252 gduche 145
 
146
			if ((valeurChamp!=null)&&(!valeurChamp.trim().equals("")))	{
147
				String[] valeurs = valeurChamp.split(";;");
148
 
149
				if (valeurs.length > 0)	{
150
					if (valeurs[0].contains("##"))	{
151
						// Les champs sont typés, on en fait une Map
152
						HashMap mapValeurs = new HashMap();
153
 
154
						for (int i = 0; i < valeurs.length; i++)	{
155
							String typeEtValeur[] = valeurs[i].split("##");
156
							mapValeurs.put(typeEtValeur[0], typeEtValeur[1]);
157
						}
158
 
159
						retourObjet = mapValeurs;
248 gduche 160
					}
252 gduche 161
					else	{
162
 
163
						//Les champs ne sont pas typés, on en fait une Liste
164
						LinkedList listeValeurs = new LinkedList<String>();
165
						for (int i = 0; i < valeurs.length; i++)	{
166
							if ((valeurs[i]!=null)&&(!valeurs[i].equals("")))	{
167
								listeValeurs.add(valeurs[i]);
168
							}
249 gduche 169
						}
252 gduche 170
						retourObjet = listeValeurs;
248 gduche 171
					}
252 gduche 172
 
248 gduche 173
				}
174
			}
175
 
176
			return retourObjet;
177
 
178
	}
179
 
180
 
181
	/**
233 jp_milcent 182
	 * Permet de modifier correctement une chaine dénormalisée (champ de type "truk").
183
	 * Remplace par la valeur de la première instance du type indiqué dans la chaine dénormalisée.
184
	 *
185
	 * @param champ le nom du champ dénormalisé
186
	 * @param type le type de la valeur à modifier
187
	 * @param valeur la valeur pour le type en question
188
	 */
242 jp_milcent 189
	protected void modifierChaineDenormaliseParType(String champ, String type, Object valeur) {
233 jp_milcent 190
		if (valeur instanceof String) {
191
			String chaineExistante = renvoyerValeurCorrecte(champ);
192
			if (chaineExistante.equals("")) {
193
				this.set(champ, type+"##"+valeur);
194
			} else {
195
				String[] valeurs = chaineExistante.split(";;");
196
				for (int i = 0; i < valeurs.length; i++) {
197
					if (valeurs[i].startsWith(type+"##") || i == (valeurs.length -1)) {
198
						valeurs[i] = type+"##"+valeur;
199
						break;
200
					}
201
				}
202
				this.set(champ, UtilArray.implode(valeurs, ";;"));
203
			}
204
		}
205
	}
206
 
208 jp_milcent 207
	protected String getInfoDenormaliseParPosition(String chaineExistante, int position) {
208
		String sortie = "";
209
		if (!chaineExistante.equals("")) {
210
			String[] valeurs = chaineExistante.split(";;");
211
			if (valeurs.length >= position) {
212
				for (int i = 0; i < valeurs.length; i++) {
213
					if (i == (position - 1)) {
214
						if (valeurs[i].contains("##")) {
215
							sortie =  valeurs[i].replaceFirst("^[^#]+##", "");
216
						} else {
217
							sortie =  valeurs[i];
218
						}
219
						break;
220
					}
221
				}
222
			}
223
		}
224
		return sortie;
225
	}
226
 
233 jp_milcent 227
	/**
228
	 * Permet de modifier correctement une chaine dénormalisée (champ de type "truk").
229
	 * Remplace par la valeur l'instance dont la position a été indiquée.
242 jp_milcent 230
	 * Si la chaine dénormalisée est vide, l'élement est ajouté quelque soit la position indiquée.
231
	 * Si la position est supérieure au nombre d'élément de la chaine dénormalisé, rien n'est modifié.
233 jp_milcent 232
	 *
233
	 * @param champ le nom du champ dénormalisé
234
	 * @param position le type de la valeur à modifier
235
	 * @param valeur la valeur à remplacer à la position indiquée
236
	 */
242 jp_milcent 237
	protected void modifierChaineDenormaliseParPosition(String champ, int position, Object valeur) {
233 jp_milcent 238
		if (valeur instanceof String) {
239
			String chaineExistante = renvoyerValeurCorrecte(champ);
240
			if (!chaineExistante.equals("")) {
241
				String[] valeurs = chaineExistante.split(";;");
242
				if (valeurs.length == 0) {
243
					this.set(champ, valeur);
244
				} else if (valeurs.length >= position) {
245
					for (int i = 0; i < valeurs.length; i++) {
246
						if (i == (position - 1)) {
247
							valeurs[i] = (String) valeur;
248
							break;
249
						}
250
					}
251
					this.set(champ, UtilArray.implode(valeurs, ";;"));
252
				}
253
			}
254
		}
255
	}
256
 
119 jpm 257
	public String getDateModification() {
258
		return (String) renvoyerValeurCorrecte("cmhl_date_modification");
259
	}
260
 
261
	public String getNotes() {
262
		return (String) renvoyerValeurCorrecte("cmhl_notes");
263
	}
264
 
265
	public String getIdModifierPar() {
266
		return (String) renvoyerValeurCorrecte("cmhl_ce_modifier_par");
267
	}
268
 
269
	public String getIdEtat() {
270
		return (String) renvoyerValeurCorrecte("cmhl_ce_etat");
271
	}
272
 
273
	public String getIp() {
274
		return (String) renvoyerValeurCorrecte("cmhl_ip");
275
	}
193 jp_milcent 276
 
277
	/** (non-Javadoc)
278
	 * @see java.lang.Object#toString()
279
	 */
280
	public String toString() {
281
		String sortie = "";
282
 
283
		// Champs du BaseModelData
284
		Set<String> proprietes = this.getProperties().keySet();
285
		for (Iterator<String> it = proprietes.iterator(); it.hasNext();) {
286
			String cle = it.next();
202 jp_milcent 287
			if (!this.get(cle).equals("")) {
288
				sortie += cle+" : "+this.get(cle)+"\n";
289
			}
193 jp_milcent 290
		}
291
 
292
		return sortie;
293
	}
69 jpm 294
}