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