665 |
jp_milcent |
1 |
package org.tela_botanica.client.composants;
|
|
|
2 |
|
|
|
3 |
import java.util.HashMap;
|
|
|
4 |
|
691 |
jp_milcent |
5 |
import org.tela_botanica.client.Mediateur;
|
665 |
jp_milcent |
6 |
import org.tela_botanica.client.images.Images;
|
721 |
gduche |
7 |
import org.tela_botanica.client.modeles.Valeur;
|
955 |
jpm |
8 |
import org.tela_botanica.client.modeles.aDonnee;
|
1468 |
jpm |
9 |
import org.tela_botanica.client.util.Debug;
|
665 |
jp_milcent |
10 |
|
|
|
11 |
import com.extjs.gxt.ui.client.event.ButtonEvent;
|
1262 |
cyprien |
12 |
import com.extjs.gxt.ui.client.event.Events;
|
|
|
13 |
import com.extjs.gxt.ui.client.event.FieldEvent;
|
|
|
14 |
import com.extjs.gxt.ui.client.event.Listener;
|
665 |
jp_milcent |
15 |
import com.extjs.gxt.ui.client.event.SelectionListener;
|
721 |
gduche |
16 |
import com.extjs.gxt.ui.client.store.ListStore;
|
665 |
jp_milcent |
17 |
import com.extjs.gxt.ui.client.widget.LayoutContainer;
|
|
|
18 |
import com.extjs.gxt.ui.client.widget.MessageBox;
|
|
|
19 |
import com.extjs.gxt.ui.client.widget.Text;
|
|
|
20 |
import com.extjs.gxt.ui.client.widget.button.Button;
|
721 |
gduche |
21 |
import com.extjs.gxt.ui.client.widget.form.ComboBox;
|
857 |
jpm |
22 |
import com.extjs.gxt.ui.client.widget.form.Field;
|
665 |
jp_milcent |
23 |
import com.extjs.gxt.ui.client.widget.form.HiddenField;
|
|
|
24 |
import com.extjs.gxt.ui.client.widget.form.LabelField;
|
|
|
25 |
import com.extjs.gxt.ui.client.widget.form.TextField;
|
1093 |
gduche |
26 |
import com.extjs.gxt.ui.client.widget.form.ComboBox.TriggerAction;
|
665 |
jp_milcent |
27 |
import com.extjs.gxt.ui.client.widget.layout.ColumnData;
|
|
|
28 |
import com.extjs.gxt.ui.client.widget.layout.ColumnLayout;
|
|
|
29 |
import com.extjs.gxt.ui.client.widget.layout.FormLayout;
|
|
|
30 |
import com.extjs.gxt.ui.client.widget.layout.RowLayout;
|
|
|
31 |
|
|
|
32 |
public class ChampMultiValeurs extends LayoutContainer {
|
727 |
gduche |
33 |
//TODO : changer le champRecapitulatif par une hashMap
|
|
|
34 |
//TODO : autoriser la modification des champs saisis
|
|
|
35 |
|
665 |
jp_milcent |
36 |
String idChampCache = null;
|
|
|
37 |
|
|
|
38 |
String nomLabelChampTxt = "";
|
|
|
39 |
|
|
|
40 |
String titreErreur = null;
|
|
|
41 |
String valeurVideMsg = null;
|
|
|
42 |
String valeurIdentiqueMsg = null;
|
694 |
gduche |
43 |
String valeurNonValideMsg = null;
|
|
|
44 |
|
693 |
gduche |
45 |
String valeurParDefaut = "";
|
857 |
jpm |
46 |
String validationMasque = null;
|
694 |
gduche |
47 |
String exempleValidation = null;
|
700 |
gduche |
48 |
String boutonSupprimerLabel = "";
|
665 |
jp_milcent |
49 |
|
|
|
50 |
LayoutContainer principalLayout = null;
|
857 |
jpm |
51 |
Field<String> champValeurTxt = null;
|
|
|
52 |
ComboBox<Valeur> champValeurCombo = null;
|
665 |
jp_milcent |
53 |
HiddenField<String> champRecapitulatif = null;
|
|
|
54 |
HashMap<String, LayoutContainer> valeurs = null;
|
721 |
gduche |
55 |
ComboBox<Valeur> types = null;
|
665 |
jp_milcent |
56 |
|
|
|
57 |
int largeurTotale = 420;
|
|
|
58 |
int largeurBouton = 20;
|
|
|
59 |
int largeurChamp = 0;
|
861 |
jpm |
60 |
int largeurType = 0;
|
665 |
jp_milcent |
61 |
|
721 |
gduche |
62 |
boolean estMultiType = false;
|
857 |
jpm |
63 |
boolean estComboBox = false;
|
721 |
gduche |
64 |
|
665 |
jp_milcent |
65 |
public ChampMultiValeurs() {
|
|
|
66 |
initialiserChampMultiValeur(null, 0);
|
|
|
67 |
}
|
|
|
68 |
|
|
|
69 |
public ChampMultiValeurs(String label) {
|
|
|
70 |
initialiserChampMultiValeur(label, 0);
|
|
|
71 |
}
|
|
|
72 |
|
|
|
73 |
public ChampMultiValeurs(String label, int largeurTotale) {
|
|
|
74 |
initialiserChampMultiValeur(label, largeurTotale);
|
|
|
75 |
}
|
|
|
76 |
|
972 |
gduche |
77 |
public ChampMultiValeurs(boolean estMultiType, String label, int largeurTotale, int largeurType) {
|
857 |
jpm |
78 |
this.estMultiType = estMultiType;
|
721 |
gduche |
79 |
initialiserChampMultiValeur(label, largeurTotale);
|
|
|
80 |
}
|
861 |
jpm |
81 |
|
|
|
82 |
public ChampMultiValeurs(boolean estCombobox, boolean estMultiType, String label, int largeurTotale, int largeurType) {
|
857 |
jpm |
83 |
this.estMultiType = estMultiType;
|
|
|
84 |
this.estComboBox = estCombobox;
|
861 |
jpm |
85 |
setLargeurType(largeurType);
|
857 |
jpm |
86 |
initialiserChampMultiValeur(label, largeurTotale);
|
|
|
87 |
}
|
|
|
88 |
|
1262 |
cyprien |
89 |
public ComboBox<Valeur> getTypes() {
|
|
|
90 |
return this.types;
|
|
|
91 |
}
|
|
|
92 |
|
665 |
jp_milcent |
93 |
public void setLabel(String label) {
|
|
|
94 |
if (label == null) {
|
|
|
95 |
label = "";
|
|
|
96 |
}
|
|
|
97 |
nomLabelChampTxt = label;
|
|
|
98 |
}
|
|
|
99 |
|
861 |
jpm |
100 |
public void setLargeurChamp(int largeurMax) {
|
|
|
101 |
if (largeurMax != 0 && largeurMax > 20) {
|
|
|
102 |
largeurTotale = largeurMax;
|
665 |
jp_milcent |
103 |
}
|
861 |
jpm |
104 |
|
665 |
jp_milcent |
105 |
largeurChamp = largeurTotale - largeurBouton;
|
|
|
106 |
}
|
|
|
107 |
|
861 |
jpm |
108 |
public void setLargeurType(int largeur) {
|
|
|
109 |
largeurType = largeur;
|
|
|
110 |
}
|
|
|
111 |
|
694 |
gduche |
112 |
public void setValidation (String validation, String exempleValidation) {
|
857 |
jpm |
113 |
this.validationMasque = validation;
|
694 |
gduche |
114 |
this.exempleValidation = exempleValidation;
|
|
|
115 |
|
|
|
116 |
this.valeurNonValideMsg = Mediateur.i18nM.valeurNonValideMsg(exempleValidation);
|
|
|
117 |
}
|
|
|
118 |
|
693 |
gduche |
119 |
public void setValeurParDefaut(String valeur) {
|
|
|
120 |
this.valeurParDefaut = valeur;
|
857 |
jpm |
121 |
champValeurTxt.setValue(valeur);
|
693 |
gduche |
122 |
}
|
|
|
123 |
|
700 |
gduche |
124 |
public void setValeurBoutonSupprimer(String valeur) {
|
|
|
125 |
this.boutonSupprimerLabel = valeur;
|
|
|
126 |
}
|
|
|
127 |
|
665 |
jp_milcent |
128 |
private void initialiserChampMultiValeur(String label, int largeur) {
|
|
|
129 |
setLabel(label);
|
861 |
jpm |
130 |
setLargeurChamp(largeur);
|
665 |
jp_milcent |
131 |
|
691 |
jp_milcent |
132 |
titreErreur = Mediateur.i18nC.erreurSaisieTitre();
|
|
|
133 |
valeurVideMsg = Mediateur.i18nC.demanderValeur();
|
|
|
134 |
valeurIdentiqueMsg = Mediateur.i18nC.valeurDejaPresente();
|
665 |
jp_milcent |
135 |
|
|
|
136 |
valeurs = new HashMap<String, LayoutContainer>();
|
|
|
137 |
champRecapitulatif = new HiddenField<String>();
|
|
|
138 |
champRecapitulatif.setValue("");
|
|
|
139 |
|
|
|
140 |
setLayout(new FormLayout());
|
|
|
141 |
|
|
|
142 |
creerChampMultiValeurs();
|
|
|
143 |
}
|
|
|
144 |
|
|
|
145 |
private void creerChampMultiValeurs() {
|
|
|
146 |
principalLayout = new LayoutContainer();
|
|
|
147 |
principalLayout.setLayout(new RowLayout());
|
|
|
148 |
|
|
|
149 |
LabelField label = new LabelField(nomLabelChampTxt + ":");
|
861 |
jpm |
150 |
label.setWidth("95%");
|
665 |
jp_milcent |
151 |
principalLayout.add(label);
|
|
|
152 |
|
861 |
jpm |
153 |
LayoutContainer colonneConteneur = new LayoutContainer();
|
|
|
154 |
colonneConteneur.setLayout(new ColumnLayout());
|
665 |
jp_milcent |
155 |
|
721 |
gduche |
156 |
if (estMultiType == true) {
|
|
|
157 |
types = new ComboBox<Valeur>();
|
|
|
158 |
types.setDisplayField("nom");
|
|
|
159 |
types.setEmptyText("Choisissez:");
|
|
|
160 |
types.setStore(new ListStore<Valeur>());
|
1093 |
gduche |
161 |
types.setTypeAhead(true);
|
|
|
162 |
types.setTriggerAction(TriggerAction.ALL);
|
1262 |
cyprien |
163 |
|
|
|
164 |
types.addListener(Events.Select, new Listener<FieldEvent>() {
|
|
|
165 |
public void handleEvent(FieldEvent fe) {
|
|
|
166 |
|
|
|
167 |
}
|
|
|
168 |
});
|
|
|
169 |
|
861 |
jpm |
170 |
colonneConteneur.add(types, new ColumnData(largeurType));
|
721 |
gduche |
171 |
}
|
|
|
172 |
|
857 |
jpm |
173 |
if (estComboBox) {
|
|
|
174 |
champValeurCombo = new ComboBox<Valeur>();
|
|
|
175 |
champValeurCombo.setDisplayField("nom");
|
|
|
176 |
champValeurCombo.setStore(new ListStore<Valeur>());
|
1262 |
cyprien |
177 |
colonneConteneur.add(champValeurCombo, new ColumnData(largeurChamp));
|
857 |
jpm |
178 |
} else {
|
|
|
179 |
champValeurTxt = new TextField<String>();
|
861 |
jpm |
180 |
colonneConteneur.add(champValeurTxt, new ColumnData(largeurChamp));
|
857 |
jpm |
181 |
}
|
665 |
jp_milcent |
182 |
Button ajouterBouton = new Button();
|
|
|
183 |
ajouterBouton.setIcon(Images.ICONES.ajouter());
|
857 |
jpm |
184 |
ajouterBouton.addSelectionListener(new SelectionListener<ButtonEvent>() {
|
|
|
185 |
public void componentSelected(ButtonEvent ce) {
|
1641 |
aurelien |
186 |
surAjoutValeur(true);
|
857 |
jpm |
187 |
}
|
|
|
188 |
});
|
861 |
jpm |
189 |
colonneConteneur.add(ajouterBouton, new ColumnData(largeurBouton));
|
665 |
jp_milcent |
190 |
|
|
|
191 |
principalLayout.add(champRecapitulatif);
|
861 |
jpm |
192 |
principalLayout.add(colonneConteneur);
|
665 |
jp_milcent |
193 |
add(principalLayout);
|
|
|
194 |
}
|
|
|
195 |
|
1641 |
aurelien |
196 |
private void surAjoutValeur(boolean validerChamp) {
|
|
|
197 |
String valeurChamp = "";
|
|
|
198 |
if (estComboBox) {
|
|
|
199 |
if (champValeurCombo.getValue() != null) {
|
|
|
200 |
valeurChamp = champValeurCombo.getValue().getId();
|
|
|
201 |
}
|
|
|
202 |
} else {
|
|
|
203 |
valeurChamp = champValeurTxt.getValue();
|
|
|
204 |
}
|
|
|
205 |
|
|
|
206 |
if ((valeurChamp == null) || valeurChamp.trim().equals("") || valeurChamp.trim().equals(valeurParDefaut)) {
|
|
|
207 |
if(validerChamp) {
|
|
|
208 |
MessageBox.alert(titreErreur, valeurVideMsg, null);
|
|
|
209 |
}
|
|
|
210 |
} else if (valeurs.get(valeurChamp) != null) {
|
|
|
211 |
if(validerChamp) {
|
|
|
212 |
MessageBox.alert(titreErreur, valeurIdentiqueMsg, null);
|
|
|
213 |
}
|
|
|
214 |
} else {
|
|
|
215 |
if (validationMasque != null && !valeurChamp.matches(validationMasque)) {
|
|
|
216 |
if(validerChamp) {
|
|
|
217 |
MessageBox.alert(titreErreur, valeurNonValideMsg, null);
|
|
|
218 |
}
|
|
|
219 |
} else {
|
|
|
220 |
if (estMultiType) {
|
|
|
221 |
String type = "";
|
|
|
222 |
String id = "";
|
|
|
223 |
Valeur valeur = types.getValue();
|
|
|
224 |
|
|
|
225 |
if (valeur != null) {
|
|
|
226 |
type = valeur.getNom();
|
|
|
227 |
id = valeur.getId();
|
|
|
228 |
} else {
|
|
|
229 |
type = types.getRawValue();
|
|
|
230 |
id = type;
|
|
|
231 |
}
|
|
|
232 |
|
|
|
233 |
if (type.trim().equals("")) {
|
|
|
234 |
MessageBox.alert(Mediateur.i18nM.titreErreurSaisie(), Mediateur.i18nM.typeChampMulti(), null);
|
|
|
235 |
} else {
|
|
|
236 |
ajouterValeur(valeurChamp, type, id);
|
|
|
237 |
}
|
|
|
238 |
} else {
|
|
|
239 |
ajouterValeur(valeurChamp);
|
|
|
240 |
}
|
|
|
241 |
}
|
|
|
242 |
}
|
|
|
243 |
}
|
|
|
244 |
|
721 |
gduche |
245 |
public void ajouterValeur(final String texte, final String strValeur, final String id) {
|
|
|
246 |
//Implémenté dans classe inférieure
|
|
|
247 |
}
|
|
|
248 |
|
700 |
gduche |
249 |
public void ajouterValeur(final String texte) {
|
1468 |
jpm |
250 |
|
665 |
jp_milcent |
251 |
LayoutContainer colonneLayout = new LayoutContainer();
|
|
|
252 |
colonneLayout.setLayout(new ColumnLayout());
|
|
|
253 |
valeurs.put(texte, colonneLayout);
|
|
|
254 |
|
|
|
255 |
Text champTxt = new Text();
|
|
|
256 |
champTxt.setText(texte);
|
|
|
257 |
colonneLayout.add(champTxt, new ColumnData(largeurChamp));
|
|
|
258 |
|
|
|
259 |
Button supprimerBouton = new Button();
|
|
|
260 |
supprimerBouton.setIcon(Images.ICONES.supprimer());
|
700 |
gduche |
261 |
supprimerBouton.setText(boutonSupprimerLabel);
|
665 |
jp_milcent |
262 |
supprimerBouton.setData("valeur", texte);
|
|
|
263 |
supprimerBouton.addSelectionListener(new SelectionListener<ButtonEvent>() {
|
|
|
264 |
public void componentSelected(ButtonEvent ce) {
|
|
|
265 |
String valeur = ce.getComponent().getData("valeur");
|
|
|
266 |
LayoutContainer valeurLayout = valeurs.get(valeur);
|
|
|
267 |
principalLayout.remove(valeurLayout);
|
|
|
268 |
|
|
|
269 |
valeurs.remove(valeur);
|
1468 |
jpm |
270 |
|
700 |
gduche |
271 |
supprimerValeurDuRecapitulatif(valeur);
|
665 |
jp_milcent |
272 |
|
|
|
273 |
actualiserLayoutGlobal();
|
|
|
274 |
}
|
|
|
275 |
});
|
|
|
276 |
colonneLayout.add(supprimerBouton, new ColumnData(largeurBouton));
|
|
|
277 |
|
|
|
278 |
// Ajout du layout de la valeur au layout principal
|
|
|
279 |
principalLayout.add(colonneLayout);
|
|
|
280 |
|
|
|
281 |
// Ajout de la valeur au champ récapitulatif des valeurs ajoutées
|
|
|
282 |
ajouterValeurAuRecapitulatif(texte);
|
693 |
gduche |
283 |
reinitialiserChamp();
|
665 |
jp_milcent |
284 |
actualiserLayoutGlobal();
|
|
|
285 |
}
|
|
|
286 |
|
721 |
gduche |
287 |
public void reinitialiserChamp() {
|
857 |
jpm |
288 |
if (estComboBox) {
|
|
|
289 |
champValeurCombo.setValue(champValeurCombo.getStore().findModel("id_valeur", valeurParDefaut));
|
|
|
290 |
} else {
|
|
|
291 |
champValeurTxt.setValue(valeurParDefaut);
|
|
|
292 |
}
|
|
|
293 |
|
|
|
294 |
if (estMultiType) {
|
|
|
295 |
types.reset();
|
|
|
296 |
}
|
693 |
gduche |
297 |
}
|
|
|
298 |
|
721 |
gduche |
299 |
public void actualiserLayoutGlobal() {
|
665 |
jp_milcent |
300 |
layout();
|
|
|
301 |
}
|
|
|
302 |
|
700 |
gduche |
303 |
public void ajouterValeurAuRecapitulatif(String texte) {
|
665 |
jp_milcent |
304 |
String texteRecapitulatif = "";
|
|
|
305 |
if (champRecapitulatif.getValue() != null) {
|
|
|
306 |
texteRecapitulatif = champRecapitulatif.getValue();
|
|
|
307 |
}
|
955 |
jpm |
308 |
texteRecapitulatif += texte + aDonnee.SEPARATEUR_VALEURS;
|
665 |
jp_milcent |
309 |
champRecapitulatif.setValue(texteRecapitulatif);
|
|
|
310 |
}
|
|
|
311 |
|
700 |
gduche |
312 |
public void supprimerValeurDuRecapitulatif(String texte) {
|
1468 |
jpm |
313 |
|
665 |
jp_milcent |
314 |
if (champRecapitulatif.getValue() != null) {
|
1468 |
jpm |
315 |
String texteValeur = "";
|
1513 |
jpm |
316 |
if (estComboBox) {
|
|
|
317 |
// comme c'est le nom de la valeur qui est passée en paramètre,
|
|
|
318 |
// on doit récupérer son id
|
|
|
319 |
ListStore<Valeur> valeurs = champValeurCombo.getStore();
|
|
|
320 |
Valeur objetValeur = valeurs.findModel("nom", texte);
|
|
|
321 |
|
|
|
322 |
if (objetValeur != null) {
|
|
|
323 |
texteValeur = objetValeur.getId();
|
|
|
324 |
} else {
|
|
|
325 |
texteValeur = texte;
|
|
|
326 |
}
|
1468 |
jpm |
327 |
} else {
|
|
|
328 |
texteValeur = texte;
|
|
|
329 |
}
|
|
|
330 |
|
665 |
jp_milcent |
331 |
String texteRecapitulatif = champRecapitulatif.getValue();
|
1468 |
jpm |
332 |
texteRecapitulatif = texteRecapitulatif.replace(texteValeur + aDonnee.SEPARATEUR_VALEURS, "");
|
665 |
jp_milcent |
333 |
champRecapitulatif.setValue(texteRecapitulatif);
|
|
|
334 |
}
|
|
|
335 |
}
|
|
|
336 |
|
|
|
337 |
public String getValeurs() {
|
1641 |
aurelien |
338 |
// permet de s'assurer qu'une valeur saisie dans le champ mais non ajoutée par le
|
|
|
339 |
// clic sur le + soit bien prise en compte
|
|
|
340 |
surAjoutValeur(false);
|
665 |
jp_milcent |
341 |
String texteRecapitulatif = "";
|
|
|
342 |
if (champRecapitulatif.getValue() != null) {
|
|
|
343 |
texteRecapitulatif = champRecapitulatif.getValue();
|
955 |
jpm |
344 |
texteRecapitulatif = texteRecapitulatif.replaceAll("(.*)"+aDonnee.SEPARATEUR_VALEURS+"$", "$1");
|
665 |
jp_milcent |
345 |
}
|
|
|
346 |
return texteRecapitulatif;
|
|
|
347 |
}
|
669 |
jp_milcent |
348 |
|
|
|
349 |
public void peupler(String chaineExistante) {
|
853 |
gduche |
350 |
if (valeurs.size()>0) {
|
|
|
351 |
reinitialiser();
|
|
|
352 |
}
|
691 |
jp_milcent |
353 |
if (chaineExistante != null && !chaineExistante.trim().equals("")) {
|
955 |
jpm |
354 |
String[] valeurs = chaineExistante.split(aDonnee.SEPARATEUR_VALEURS);
|
669 |
jp_milcent |
355 |
for (int i = 0; i < valeurs.length; i++) {
|
|
|
356 |
ajouterValeur(valeurs[i]);
|
|
|
357 |
}
|
|
|
358 |
}
|
|
|
359 |
}
|
830 |
gduche |
360 |
|
|
|
361 |
public void reinitialiser() {
|
|
|
362 |
//TODO : pourrait etre mieux fait si les valeurs étaient enregistrées dans un
|
|
|
363 |
// layout particulier. Il suffirait alors d'enlever les valeurs de ce layout.
|
|
|
364 |
principalLayout.removeAll();
|
|
|
365 |
initialiserChampMultiValeur(nomLabelChampTxt, largeurTotale);
|
|
|
366 |
}
|
665 |
jp_milcent |
367 |
}
|