| Line 5... |
Line 5... |
| 5 |
import java.util.List;
|
5 |
import java.util.List;
|
| Line 6... |
Line 6... |
| 6 |
|
6 |
|
| 7 |
import org.tela_botanica.client.Mediateur;
|
7 |
import org.tela_botanica.client.Mediateur;
|
| 8 |
import org.tela_botanica.client.images.Images;
|
8 |
import org.tela_botanica.client.images.Images;
|
| - |
|
9 |
import org.tela_botanica.client.interfaces.Rafraichissable;
|
| - |
|
10 |
import org.tela_botanica.client.modeles.Collection;
|
| - |
|
11 |
import org.tela_botanica.client.modeles.CollectionAPersonne;
|
| 9 |
import org.tela_botanica.client.interfaces.Rafraichissable;
|
12 |
import org.tela_botanica.client.modeles.CollectionAPersonneListe;
|
| 10 |
import org.tela_botanica.client.modeles.Information;
|
13 |
import org.tela_botanica.client.modeles.Information;
|
| 11 |
import org.tela_botanica.client.modeles.InterneValeur;
|
14 |
import org.tela_botanica.client.modeles.InterneValeur;
|
| 12 |
import org.tela_botanica.client.modeles.Personne;
|
15 |
import org.tela_botanica.client.modeles.Personne;
|
| - |
|
16 |
import org.tela_botanica.client.modeles.PersonneListe;
|
| - |
|
17 |
import org.tela_botanica.client.modeles.Publication;
|
| 13 |
import org.tela_botanica.client.modeles.PersonneListe;
|
18 |
import org.tela_botanica.client.modeles.StructureAPersonne;
|
| 14 |
import org.tela_botanica.client.modeles.UniteBase;
|
19 |
import org.tela_botanica.client.modeles.UniteBase;
|
| 15 |
import org.tela_botanica.client.modeles.UniteRangement;
|
20 |
import org.tela_botanica.client.modeles.UniteRangement;
|
| 16 |
import org.tela_botanica.client.modeles.Valeur;
|
21 |
import org.tela_botanica.client.modeles.Valeur;
|
| - |
|
22 |
import org.tela_botanica.client.modeles.ValeurListe;
|
| Line 17... |
Line 23... |
| 17 |
import org.tela_botanica.client.modeles.ValeurListe;
|
23 |
import org.tela_botanica.client.modeles.aDonnee;
|
| 18 |
|
24 |
|
| 19 |
import com.extjs.gxt.ui.client.event.BaseEvent;
|
25 |
import com.extjs.gxt.ui.client.event.BaseEvent;
|
| 20 |
import com.extjs.gxt.ui.client.event.ButtonEvent;
|
26 |
import com.extjs.gxt.ui.client.event.ButtonEvent;
|
| 21 |
import com.extjs.gxt.ui.client.event.ComponentEvent;
|
27 |
import com.extjs.gxt.ui.client.event.ComponentEvent;
|
| 22 |
import com.extjs.gxt.ui.client.event.EventType;
|
28 |
import com.extjs.gxt.ui.client.event.EventType;
|
| 23 |
import com.extjs.gxt.ui.client.event.Events;
|
29 |
import com.extjs.gxt.ui.client.event.Events;
|
| 24 |
import com.extjs.gxt.ui.client.event.KeyListener;
|
30 |
import com.extjs.gxt.ui.client.event.KeyListener;
|
| 25 |
import com.extjs.gxt.ui.client.event.Listener;
|
31 |
import com.extjs.gxt.ui.client.event.Listener;
|
| - |
|
32 |
import com.extjs.gxt.ui.client.event.SelectionListener;
|
| 26 |
import com.extjs.gxt.ui.client.event.SelectionListener;
|
33 |
import com.extjs.gxt.ui.client.store.ListStore;
|
| 27 |
import com.extjs.gxt.ui.client.store.ListStore;
|
34 |
import com.extjs.gxt.ui.client.store.Record;
|
| 28 |
import com.extjs.gxt.ui.client.store.Store;
|
35 |
import com.extjs.gxt.ui.client.store.Store;
|
| 29 |
import com.extjs.gxt.ui.client.store.StoreEvent;
|
36 |
import com.extjs.gxt.ui.client.store.StoreEvent;
|
| 30 |
import com.extjs.gxt.ui.client.widget.ContentPanel;
|
37 |
import com.extjs.gxt.ui.client.widget.ContentPanel;
|
| 31 |
import com.extjs.gxt.ui.client.widget.Info;
|
38 |
import com.extjs.gxt.ui.client.widget.Info;
|
| 32 |
import com.extjs.gxt.ui.client.widget.Text;
|
39 |
import com.extjs.gxt.ui.client.widget.Text;
|
| 33 |
import com.extjs.gxt.ui.client.widget.button.Button;
|
40 |
import com.extjs.gxt.ui.client.widget.button.Button;
|
| - |
|
41 |
import com.extjs.gxt.ui.client.widget.button.ButtonBar;
|
| 34 |
import com.extjs.gxt.ui.client.widget.button.ButtonBar;
|
42 |
import com.extjs.gxt.ui.client.widget.form.ComboBox;
|
| 35 |
import com.extjs.gxt.ui.client.widget.form.ComboBox;
|
43 |
import com.extjs.gxt.ui.client.widget.form.FormPanel;
|
| 36 |
import com.extjs.gxt.ui.client.widget.form.ComboBox.TriggerAction;
|
44 |
import com.extjs.gxt.ui.client.widget.form.ComboBox.TriggerAction;
|
| - |
|
45 |
import com.extjs.gxt.ui.client.widget.grid.CellEditor;
|
| 37 |
import com.extjs.gxt.ui.client.widget.grid.CellEditor;
|
46 |
import com.extjs.gxt.ui.client.widget.grid.ColumnConfig;
|
| 38 |
import com.extjs.gxt.ui.client.widget.grid.ColumnConfig;
|
47 |
import com.extjs.gxt.ui.client.widget.grid.ColumnData;
|
| 39 |
import com.extjs.gxt.ui.client.widget.grid.ColumnModel;
|
48 |
import com.extjs.gxt.ui.client.widget.grid.ColumnModel;
|
| - |
|
49 |
import com.extjs.gxt.ui.client.widget.grid.EditorGrid;
|
| 40 |
import com.extjs.gxt.ui.client.widget.grid.EditorGrid;
|
50 |
import com.extjs.gxt.ui.client.widget.grid.Grid;
|
| 41 |
import com.extjs.gxt.ui.client.widget.grid.Grid;
|
51 |
import com.extjs.gxt.ui.client.widget.grid.GridCellRenderer;
|
| 42 |
import com.extjs.gxt.ui.client.widget.grid.GridSelectionModel;
|
52 |
import com.extjs.gxt.ui.client.widget.grid.GridSelectionModel;
|
| 43 |
import com.extjs.gxt.ui.client.widget.grid.HeaderGroupConfig;
|
53 |
import com.extjs.gxt.ui.client.widget.grid.HeaderGroupConfig;
|
| 44 |
import com.extjs.gxt.ui.client.widget.grid.RowNumberer;
|
54 |
import com.extjs.gxt.ui.client.widget.grid.RowNumberer;
|
| Line 48... |
Line 58... |
| 48 |
import com.google.gwt.core.client.GWT;
|
58 |
import com.google.gwt.core.client.GWT;
|
| 49 |
import com.google.gwt.event.dom.client.KeyCodes;
|
59 |
import com.google.gwt.event.dom.client.KeyCodes;
|
| Line 50... |
Line 60... |
| 50 |
|
60 |
|
| Line -... |
Line 61... |
| - |
|
61 |
public class CollectionFormPersonne extends FormulaireOnglet implements Rafraichissable {
|
| - |
|
62 |
|
| - |
|
63 |
private Collection collection = null;
|
| 51 |
public class CollectionFormPersonne extends FormulaireOnglet implements Rafraichissable {
|
64 |
private Collection collectionCollectee = null;
|
| 52 |
|
65 |
|
| 53 |
private ContentPanel panneauPrincipal = null;
|
66 |
private ContentPanel panneauPrincipal = null;
|
| 54 |
private ToolBar barreOutils = null;
|
67 |
private ToolBar barreOutils = null;
|
| Line 55... |
Line 68... |
| 55 |
private Grid<Personne> grille;
|
68 |
private Grid<CollectionAPersonne> grille;
|
| 56 |
private ComboBox<Valeur> typeRelationCombo = null;
|
69 |
private ComboBox<Valeur> typeRelationCombo = null;
|
| - |
|
70 |
|
| 57 |
|
71 |
private CollectionAPersonneListe personnes = null;
|
| 58 |
private PersonneListe personnes = null;
|
72 |
private CollectionAPersonneListe personnesAjoutees = null;
|
| 59 |
private PersonneListe personnesAjoutes = null;
|
73 |
private CollectionAPersonneListe personnesModifiees = null;
|
| 60 |
private PersonneListe personnesSupprimes = null;
|
74 |
private CollectionAPersonneListe personnesSupprimees = null;
|
| 61 |
private ComboBox<Personne> personnesSaisisComboBox = null;
|
75 |
private ComboBox<Personne> personnesSaisisComboBox = null;
|
| - |
|
76 |
private Button personnesBoutonSupprimer = null;
|
| - |
|
77 |
private Button personnesBoutonModifier = null;
|
| Line 62... |
Line 78... |
| 62 |
private Button personnesBoutonSupprimer = null;
|
78 |
private ValeurListe listeIon = null;
|
| 63 |
private Button personnesBoutonModifier = null;
|
79 |
|
| Line 64... |
Line 80... |
| 64 |
private Button ajouterPersonneSaisiBouton = null;
|
80 |
private FenetreForm fenetreFormulaire = null;
|
| Line 75... |
Line 91... |
| 75 |
panneauPrincipal = creerPanneauContenantGrille();
|
91 |
panneauPrincipal = creerPanneauContenantGrille();
|
| 76 |
barreOutils = creerBarreOutilsGrille();
|
92 |
barreOutils = creerBarreOutilsGrille();
|
| 77 |
panneauPrincipal.setTopComponent(barreOutils);
|
93 |
panneauPrincipal.setTopComponent(barreOutils);
|
| 78 |
grille = creerGrille();
|
94 |
grille = creerGrille();
|
| 79 |
panneauPrincipal.add(grille);
|
95 |
panneauPrincipal.add(grille);
|
| - |
|
96 |
mediateur.obtenirListeValeurEtRafraichir(this, "ion");
|
| 80 |
mediateur.obtenirListeValeurEtRafraichir(this, "relationPersonneCollection");
|
97 |
mediateur.obtenirListeValeurEtRafraichir(this, "relationPersonneCollection");
|
| 81 |
add(panneauPrincipal);
|
98 |
add(panneauPrincipal);
|
| Line 82... |
Line 99... |
| 82 |
|
99 |
|
| 83 |
initialiser();
|
100 |
initialiser();
|
| Line 84... |
Line 101... |
| 84 |
}
|
101 |
}
|
| 85 |
|
102 |
|
| 86 |
private void initialiser() {
|
103 |
private void initialiser() {
|
| - |
|
104 |
// Remise à zéro des modification dans la liste des auteurs
|
| 87 |
// Remise à zéro des modification dans la liste des auteurs
|
105 |
personnesAjoutees = new CollectionAPersonneListe();
|
| Line 88... |
Line 106... |
| 88 |
personnesAjoutes = new PersonneListe();
|
106 |
personnesModifiees = new CollectionAPersonneListe();
|
| 89 |
personnesSupprimes = new PersonneListe();
|
107 |
personnesSupprimees = new CollectionAPersonneListe();
|
| 90 |
|
108 |
|
| - |
|
109 |
// Actualisation de l'état des boutons de la barre d'outils
|
| - |
|
110 |
actualiserEtatBoutonsBarreOutils();
|
| - |
|
111 |
}
|
| - |
|
112 |
|
| - |
|
113 |
private void initialiserCollection() {
|
| Line 91... |
Line 114... |
| 91 |
// Actualisation de l'état des boutons de la barre d'outils
|
114 |
collection = ((CollectionForm) formulaire).collection;
|
| 92 |
actualiserEtatBoutonsBarreOutils();
|
115 |
collectionCollectee = ((CollectionForm) formulaire).collectionCollectee;
|
| Line 93... |
Line 116... |
| 93 |
}
|
116 |
}
|
| Line 109... |
Line 132... |
| 109 |
Button ajouterPersonneBouton = creerBoutonAjouter();
|
132 |
Button ajouterPersonneBouton = creerBoutonAjouter();
|
| 110 |
barreOutils.add(ajouterPersonneBouton);
|
133 |
barreOutils.add(ajouterPersonneBouton);
|
| Line 111... |
Line 134... |
| 111 |
|
134 |
|
| Line 112... |
Line 135... |
| 112 |
barreOutils.add(new Text(" ou "));
|
135 |
barreOutils.add(new Text(" ou "));
|
| 113 |
|
136 |
|
| Line 114... |
Line 137... |
| 114 |
personnesSaisisComboBox = creerComboBoxAuteursSaisis();
|
137 |
personnesSaisisComboBox = creerComboBoxPersonnesSaisies();
|
| Line 115... |
Line 138... |
| 115 |
barreOutils.add(personnesSaisisComboBox);
|
138 |
barreOutils.add(personnesSaisisComboBox);
|
| Line 134... |
Line 157... |
| 134 |
|
157 |
|
| 135 |
private Button creerBoutonAjouter() {
|
158 |
private Button creerBoutonAjouter() {
|
| 136 |
Button bouton = new Button(i18nC.ajouter());
|
159 |
Button bouton = new Button(i18nC.ajouter());
|
| 137 |
bouton.setIcon(Images.ICONES.vcardAjouter());
|
160 |
bouton.setIcon(Images.ICONES.vcardAjouter());
|
| - |
|
161 |
bouton.addSelectionListener(new SelectionListener<ButtonEvent>() {
|
| 138 |
bouton.addSelectionListener(new SelectionListener<ButtonEvent>() {
|
162 |
|
| 139 |
@Override
|
163 |
@Override
|
| 140 |
public void componentSelected(ButtonEvent ce) {
|
164 |
public void componentSelected(ButtonEvent ce) {
|
| 141 |
FenetreForm fenetre = creerFenetreModaleAvecFormulairePersonne(Formulaire.MODE_AJOUTER);
|
165 |
fenetreFormulaire = creerFenetreModaleAvecFormulairePersonne(Formulaire.MODE_AJOUTER);
|
| 142 |
fenetre.show();
|
166 |
fenetreFormulaire.show();
|
| 143 |
}
|
167 |
}
|
| 144 |
});
|
168 |
});
|
| 145 |
return bouton;
|
169 |
return bouton;
|
| Line 149... |
Line 173... |
| 149 |
Button bouton = new Button(i18nC.modifier());
|
173 |
Button bouton = new Button(i18nC.modifier());
|
| 150 |
bouton.setIcon(Images.ICONES.vcardModifier());
|
174 |
bouton.setIcon(Images.ICONES.vcardModifier());
|
| 151 |
bouton.addSelectionListener(new SelectionListener<ButtonEvent>() {
|
175 |
bouton.addSelectionListener(new SelectionListener<ButtonEvent>() {
|
| 152 |
@Override
|
176 |
@Override
|
| 153 |
public void componentSelected(ButtonEvent ce) {
|
177 |
public void componentSelected(ButtonEvent ce) {
|
| 154 |
Personne auteurSaisiSelectionne = grille.getSelectionModel().getSelectedItem();
|
178 |
CollectionAPersonne personneSaisiSelectionne = grille.getSelectionModel().getSelectedItem();
|
| 155 |
if (auteurSaisiSelectionne == null) {
|
179 |
if (personneSaisiSelectionne == null) {
|
| 156 |
Info.display(i18nC.informationTitreGenerique(), i18nC.selectionnerPersonne());
|
180 |
Info.display(i18nC.informationTitreGenerique(), i18nC.selectionnerPersonne());
|
| 157 |
} else {
|
181 |
} else {
|
| 158 |
FenetreForm fenetre = creerFenetreModaleAvecFormulairePersonne(Formulaire.MODE_MODIFIER);
|
182 |
fenetreFormulaire = creerFenetreModaleAvecFormulairePersonne(Formulaire.MODE_MODIFIER);
|
| 159 |
fenetre.show();
|
183 |
fenetreFormulaire.show();
|
| 160 |
}
|
184 |
}
|
| 161 |
}
|
185 |
}
|
| 162 |
});
|
186 |
});
|
| 163 |
return bouton;
|
187 |
return bouton;
|
| 164 |
}
|
188 |
}
|
| Line 165... |
Line 189... |
| 165 |
|
189 |
|
| - |
|
190 |
private FenetreForm creerFenetreModaleAvecFormulairePersonne(String mode) {
|
| - |
|
191 |
String personneId = null;
|
| - |
|
192 |
if (mode.equals(Formulaire.MODE_MODIFIER)) {
|
| - |
|
193 |
CollectionAPersonne personneSaisieSelectionnee = grille.getSelectionModel().getSelectedItem();
|
| - |
|
194 |
personneId = personneSaisieSelectionnee.getId();
|
| - |
|
195 |
}
|
| 166 |
private FenetreForm creerFenetreModaleAvecFormulairePersonne(String mode) {
|
196 |
|
| 167 |
final FenetreForm fenetre = new FenetreForm("");
|
197 |
final FenetreForm fenetre = new FenetreForm("");
|
| 168 |
final PersonneForm formulaire = creerFormulairePersonne(fenetre);
|
198 |
final PersonneForm formulaire = creerFormulairePersonne(fenetre, personneId);
|
| 169 |
fenetre.add(formulaire);
|
199 |
fenetre.add(formulaire);
|
| 170 |
return fenetre;
|
200 |
return fenetre;
|
| Line 171... |
Line 201... |
| 171 |
}
|
201 |
}
|
| 172 |
|
202 |
|
| - |
|
203 |
private PersonneForm creerFormulairePersonne(final FenetreForm fenetre, String personneId) {
|
| 173 |
private PersonneForm creerFormulairePersonne(final FenetreForm fenetre) {
|
204 |
PersonneForm formulaire = new PersonneForm(mediateur, personneId, this);
|
| 174 |
PersonneForm formulaire = new PersonneForm(mediateur, PersonneForm.MODE_AJOUTER, null);
|
205 |
FormPanel panneauFormulaire = formulaire.getFormulaire();
|
| 175 |
/*fenetre.setHeading(formulaire.getHeading());
|
206 |
fenetre.setHeading(panneauFormulaire.getHeading());
|
| Line 176... |
Line 207... |
| 176 |
formulaire.setHeaderVisible(false);
|
207 |
panneauFormulaire.setHeaderVisible(false);
|
| 177 |
formulaire.setTopComponent(null);*/
|
208 |
panneauFormulaire.setTopComponent(null);
|
| 178 |
|
209 |
|
| 179 |
// TODO : gérer la barre d'outil avec des évènements spécifique au contexte de fenêtre modale
|
210 |
// TODO : gérer la barre d'outil avec des évènements spécifique au contexte de fenêtre modale
|
| 180 |
SelectionListener<ButtonEvent> ecouteur = creerEcouteurValidationFormulairePersonne(fenetre, formulaire);
|
- |
|
| 181 |
final ButtonBar barreValidation = new FormulaireBarreValidation(ecouteur);
|
- |
|
| 182 |
//formulaire.setBottomComponent(barreValidation);
|
- |
|
| 183 |
|
- |
|
| 184 |
if (mode.equals(Formulaire.MODE_MODIFIER)) {
|
- |
|
| 185 |
// TODO : simplifier la gestion de l'ajout des données d'une Personne au form pour la modification... (pas besoin de passer par une liste).
|
- |
|
| 186 |
Information info = new Information("liste_personne");
|
- |
|
| 187 |
PersonneListe personnes = new PersonneListe();
|
- |
|
| 188 |
Personne auteurSaisiSelectionne = grille.getSelectionModel().getSelectedItem();
|
- |
|
| 189 |
personnes.put(auteurSaisiSelectionne.getId(), auteurSaisiSelectionne);
|
- |
|
| Line 190... |
Line 211... |
| 190 |
info.setDonnee(0, personnes);
|
211 |
SelectionListener<ButtonEvent> ecouteur = creerEcouteurValidationFormulairePersonne(fenetre, formulaire);
|
| 191 |
formulaire.rafraichir(info);
|
212 |
final ButtonBar barreValidation = new FormulaireBarreValidation(ecouteur);
|
| Line 192... |
Line 213... |
| 192 |
}
|
213 |
panneauFormulaire.setBottomComponent(barreValidation);
|
| 193 |
|
214 |
|
| 194 |
return formulaire;
|
215 |
return formulaire;
|
| 195 |
}
|
216 |
}
|
| 196 |
|
217 |
|
| 197 |
private SelectionListener<ButtonEvent> creerEcouteurValidationFormulairePersonne(final FenetreForm fenetre, final PersonneForm formulaire) {
|
218 |
private SelectionListener<ButtonEvent> creerEcouteurValidationFormulairePersonne(final FenetreForm fenetre, final PersonneForm formulaire) {
|
| 198 |
SelectionListener<ButtonEvent> ecouteur = new SelectionListener<ButtonEvent>() {
|
219 |
SelectionListener<ButtonEvent> ecouteur = new SelectionListener<ButtonEvent>() {
|
| 199 |
@Override
|
220 |
@Override
|
| 200 |
public void componentSelected(ButtonEvent ce) {
|
- |
|
| 201 |
String code = ((Button) ce.getComponent()).getData("code");
|
221 |
public void componentSelected(ButtonEvent ce) {
|
| 202 |
if (code.equals(FormulaireBarreValidation.CODE_BOUTON_VALIDER)) {
|
- |
|
| 203 |
Boolean ok = formulaire.enregistrer();
|
222 |
String code = ((Button) ce.getComponent()).getData("code");
|
| 204 |
if (ok == true) {
|
223 |
if (code.equals(FormulaireBarreValidation.CODE_BOUTON_VALIDER)) {
|
| 205 |
// Fermer fenêtre et ajouter/modifier l'élément dans la liste
|
- |
|
| 206 |
}
|
- |
|
| 207 |
fenetre.hide();
|
- |
|
| 208 |
} else if (code.equals(FormulaireBarreValidation.CODE_BOUTON_APPLIQUER)) {
|
224 |
if (formulaire.soumettreFormulaire()) {
|
| 209 |
Boolean ok = formulaire.enregistrer();
|
225 |
fenetre.hide();
|
| 210 |
if (ok == true) {
|
226 |
}
|
| - |
|
227 |
} else if (code.equals(FormulaireBarreValidation.CODE_BOUTON_APPLIQUER)) {
|
| - |
|
228 |
formulaire.soumettreFormulaire();
|
| 211 |
// Fermer fenêtre et ajouter/modifier l'élément dans la liste
|
229 |
} else if (code.equals(FormulaireBarreValidation.CODE_BOUTON_ANNULER)) {
|
| 212 |
}
|
230 |
fenetre.hide();
|
| 213 |
} else if (code.equals(FormulaireBarreValidation.CODE_BOUTON_ANNULER)) {
|
231 |
} else if (code.equals(FormulaireBarreValidation.CODE_BOUTON_REINITIALISER)) {
|
| 214 |
fenetre.hide();
|
232 |
fenetreFormulaire.hide();
|
| Line 215... |
Line 233... |
| 215 |
} else if (code.equals(FormulaireBarreValidation.CODE_BOUTON_REINITIALISER)) {
|
233 |
fenetreFormulaire = creerFenetreModaleAvecFormulairePersonne(formulaire.mode);
|
| Line 225... |
Line 243... |
| 225 |
Button bouton = new Button(i18nC.supprimer());
|
243 |
Button bouton = new Button(i18nC.supprimer());
|
| 226 |
bouton.setIcon(Images.ICONES.vcardSupprimer());
|
244 |
bouton.setIcon(Images.ICONES.vcardSupprimer());
|
| 227 |
bouton.addSelectionListener(new SelectionListener<ButtonEvent>() {
|
245 |
bouton.addSelectionListener(new SelectionListener<ButtonEvent>() {
|
| 228 |
@Override
|
246 |
@Override
|
| 229 |
public void componentSelected(ButtonEvent ce) {
|
247 |
public void componentSelected(ButtonEvent ce) {
|
| 230 |
Personne auteurSaisiSelectionne = grille.getSelectionModel().getSelectedItem();
|
248 |
CollectionAPersonne personneSaisiSelectionnee = grille.getSelectionModel().getSelectedItem();
|
| 231 |
if (auteurSaisiSelectionne == null) {
|
249 |
if (personneSaisiSelectionnee == null) {
|
| 232 |
Info.display(i18nC.informationTitreGenerique(), i18nC.selectionnerPersonne());
|
250 |
Info.display(i18nC.informationTitreGenerique(), i18nC.selectionnerPersonne());
|
| 233 |
} else {
|
251 |
} else {
|
| 234 |
supprimerDansGrille(auteurSaisiSelectionne);
|
252 |
supprimerDansGrille(personneSaisiSelectionnee);
|
| 235 |
}
|
253 |
}
|
| 236 |
}
|
254 |
}
|
| 237 |
});
|
255 |
});
|
| 238 |
return bouton;
|
256 |
return bouton;
|
| 239 |
}
|
257 |
}
|
| Line 248... |
Line 266... |
| 248 |
}
|
266 |
}
|
| 249 |
});
|
267 |
});
|
| 250 |
return bouton;
|
268 |
return bouton;
|
| 251 |
}
|
269 |
}
|
| Line 252... |
Line 270... |
| 252 |
|
270 |
|
| 253 |
private ComboBox<Personne> creerComboBoxAuteursSaisis() {
|
271 |
private ComboBox<Personne> creerComboBoxPersonnesSaisies() {
|
| 254 |
ListStore<Personne> personnesSaisiesStore = new ListStore<Personne>();
|
272 |
ListStore<Personne> personnesSaisiesStore = new ListStore<Personne>();
|
| Line 255... |
Line 273... |
| 255 |
personnesSaisiesStore.add(new ArrayList<Personne>());
|
273 |
personnesSaisiesStore.add(new ArrayList<Personne>());
|
| 256 |
|
274 |
|
| Line 272... |
Line 290... |
| 272 |
});
|
290 |
});
|
| 273 |
comboBox.addListener(Events.Select, new Listener<BaseEvent>() {
|
291 |
comboBox.addListener(Events.Select, new Listener<BaseEvent>() {
|
| 274 |
@Override
|
292 |
@Override
|
| 275 |
public void handleEvent(BaseEvent be) {
|
293 |
public void handleEvent(BaseEvent be) {
|
| 276 |
if (personnesSaisisComboBox.getValue() instanceof Personne) {
|
294 |
if (personnesSaisisComboBox.getValue() instanceof Personne) {
|
| 277 |
Personne auteurSaisiSelectionne = personnesSaisisComboBox.getValue();
|
295 |
Personne personneSaisiSelectionnee = personnesSaisisComboBox.getValue();
|
| 278 |
ajouterDansGrille(auteurSaisiSelectionne);
|
296 |
ajouterDansGrille(personneSaisiSelectionnee);
|
| 279 |
personnesSaisisComboBox.setValue(null);
|
297 |
personnesSaisisComboBox.setValue(null);
|
| 280 |
}
|
298 |
}
|
| 281 |
}
|
299 |
}
|
| 282 |
});
|
300 |
});
|
| 283 |
return comboBox;
|
301 |
return comboBox;
|
| 284 |
}
|
302 |
}
|
| Line 285... |
Line 303... |
| 285 |
|
303 |
|
| 286 |
private void ajouterDansGrille(Personne personne) {
|
304 |
private void ajouterDansGrille(Personne personne) {
|
| - |
|
305 |
if (personne != null) {
|
| - |
|
306 |
CollectionAPersonne relationCollectionPersonne = new CollectionAPersonne();
|
| - |
|
307 |
relationCollectionPersonne.setPersonne(personne);
|
| 287 |
if (personne != null) {
|
308 |
|
| 288 |
// Ajout de la personne ajoutée à la liste
|
309 |
// Ajout de la personne ajoutée à la liste
|
| 289 |
if (personne.getId() != null && !personne.getId().equals("")) {
|
310 |
if (relationCollectionPersonne.getId() != null && !relationCollectionPersonne.getId().equals("")) {
|
| 290 |
personnesAjoutes.put(personne.getId(), personne);
|
311 |
personnesAjoutees.put(relationCollectionPersonne.getId(), relationCollectionPersonne);
|
| Line 291... |
Line 312... |
| 291 |
}
|
312 |
}
|
| 292 |
|
313 |
|
| Line 293... |
Line 314... |
| 293 |
// Définition de l'état
|
314 |
// Définition de l'état
|
| 294 |
personne.set("etat", ETAT_AJOUTE);
|
315 |
relationCollectionPersonne.set("etat", ETAT_AJOUTE);
|
| 295 |
|
316 |
|
| 296 |
// Ajout à la grille
|
317 |
// Ajout à la grille
|
| 297 |
grille.getStore().insert(personne, 0);
|
318 |
grille.getStore().insert(relationCollectionPersonne, 0);
|
| Line 298... |
Line 319... |
| 298 |
grille.getSelectionModel().select(0, false);
|
319 |
grille.getSelectionModel().select(0, false);
|
| 299 |
}
|
320 |
}
|
| 300 |
}
|
321 |
}
|
| 301 |
|
322 |
|
| - |
|
323 |
private void supprimerDansGrille(CollectionAPersonne relationCollectionPersonne) {
|
| - |
|
324 |
if (relationCollectionPersonne != null) {
|
| 302 |
private void supprimerDansGrille(Personne personne) {
|
325 |
// Ajout de la personne supprimée à la liste
|
| 303 |
if (personne != null) {
|
326 |
if ((relationCollectionPersonne.get("etat") == null || !relationCollectionPersonne.get("etat").equals(ETAT_AJOUTE))
|
| Line 304... |
Line 327... |
| 304 |
// Ajout de la personne supprimée à la liste
|
327 |
&& relationCollectionPersonne.getId() != null
|
| 305 |
if ((personne.get("etat") == null || !personne.get("etat").equals(ETAT_AJOUTE)) && personne.getId() != null && !personne.getId().equals("")) {
|
328 |
&& !relationCollectionPersonne.getId().equals("")) {
|
| 306 |
personnesSupprimes.put(personne.getId(), personne);
|
329 |
personnesSupprimees.put(relationCollectionPersonne.getId(), relationCollectionPersonne);
|
| 307 |
}
|
330 |
}
|
| Line 308... |
Line 331... |
| 308 |
|
331 |
|
| 309 |
// Suppression de l'enregistrement de la grille
|
332 |
// Suppression de l'enregistrement de la grille
|
| 310 |
grille.getStore().remove(personne);
|
333 |
grille.getStore().remove(relationCollectionPersonne);
|
| 311 |
}
|
334 |
}
|
| 312 |
}
|
335 |
}
|
| 313 |
|
336 |
|
| Line 361... |
Line 384... |
| 361 |
}
|
384 |
}
|
| 362 |
return retour;
|
385 |
return retour;
|
| 363 |
}
|
386 |
}
|
| 364 |
};
|
387 |
};
|
| Line 365... |
Line 388... |
| 365 |
|
388 |
|
| 366 |
ColumnConfig typeRelationColonne = new ColumnConfig("type_relation", i18nC.typeRelationPersonneCollection(), 75);
|
389 |
ColumnConfig typeRelationColonne = new ColumnConfig("id_role", i18nC.typeRelationPersonneCollection(), 75);
|
| 367 |
typeRelationColonne.setEditor(editeurRelation);
|
390 |
typeRelationColonne.setEditor(editeurRelation);
|
| Line 368... |
Line 391... |
| 368 |
colonnes.add(typeRelationColonne);
|
391 |
colonnes.add(typeRelationColonne);
|
| 369 |
|
392 |
|
| 370 |
colonnes.add(new ColumnConfig("fmt_nom_complet", i18nC.personneNomComplet(), 150));
|
393 |
colonnes.add(new ColumnConfig("fmt_nom_complet", i18nC.personneNomComplet(), 150));
|
| 371 |
colonnes.add(new ColumnConfig("nom", i18nC.personneNom(), 75));
|
- |
|
| 372 |
colonnes.add(new ColumnConfig("prenom", i18nC.personnePrenom(), 75));
|
- |
|
| 373 |
colonnes.add(new ColumnConfig("prefixe", i18nC.personnePrefixe(), 50));
|
394 |
colonnes.add(new ColumnConfig("nom", i18nC.personneNom(), 75));
|
| 374 |
//colonnes.add(new ColumnConfig("truk_nom_autre", i18nC.personneNomAutre(), 200));
|
395 |
colonnes.add(new ColumnConfig("prenom", i18nC.personnePrenom(), 75));
|
| 375 |
colonnes.add(new ColumnConfig("naissance_date", i18nC.date(), 75));
|
396 |
colonnes.add(new ColumnConfig("naissance_date", i18nC.date(), 75));
|
| 376 |
colonnes.add(new ColumnConfig("naissance_lieu", i18nC.lieu(), 100));
|
397 |
colonnes.add(new ColumnConfig("naissance_lieu", i18nC.lieu(), 100));
|
| 377 |
colonnes.add(new ColumnConfig("ce_deces", i18nC.personneDecedeeInterogation(), 50));
|
398 |
colonnes.add(creerColonneDeces());
|
| Line 378... |
Line 399... |
| 378 |
colonnes.add(new ColumnConfig("deces_date", i18nC.date(), 75));
|
399 |
colonnes.add(new ColumnConfig("deces_date", i18nC.date(), 75));
|
| Line 379... |
Line 400... |
| 379 |
colonnes.add(new ColumnConfig("deces_lieu", i18nC.lieu(), 100));
|
400 |
colonnes.add(new ColumnConfig("deces_lieu", i18nC.lieu(), 100));
|
| 380 |
|
401 |
|
| 381 |
GridSelectionModel<Personne> modeleDeSelection = new GridSelectionModel<Personne>();
|
402 |
GridSelectionModel<CollectionAPersonne> modeleDeSelection = new GridSelectionModel<CollectionAPersonne>();
|
| 382 |
|
403 |
|
| Line 383... |
Line 404... |
| 383 |
ColumnModel modeleDeColonnes = new ColumnModel(colonnes);
|
404 |
ColumnModel modeleDeColonnes = new ColumnModel(colonnes);
|
| 384 |
modeleDeColonnes.addHeaderGroup(0, 1, new HeaderGroupConfig(i18nC.personneIdentite(), 1, 4));
|
405 |
modeleDeColonnes.addHeaderGroup(0, 1, new HeaderGroupConfig(i18nC.personneIdentite(), 1, 4));
|
| 385 |
modeleDeColonnes.addHeaderGroup(0, 5, new HeaderGroupConfig(i18nC.personneNaissance(), 1, 2));
|
406 |
modeleDeColonnes.addHeaderGroup(0, 5, new HeaderGroupConfig(i18nC.personneNaissance(), 1, 2));
|
| 386 |
modeleDeColonnes.addHeaderGroup(0, 7, new HeaderGroupConfig(i18nC.personneDeces(), 1, 3));
|
407 |
modeleDeColonnes.addHeaderGroup(0, 7, new HeaderGroupConfig(i18nC.personneDeces(), 1, 3));
|
| 387 |
|
408 |
|
| 388 |
EditorGrid<Personne> grillePersonne = new EditorGrid<Personne>(storeGrille, modeleDeColonnes);
|
409 |
EditorGrid<CollectionAPersonne> grillePersonne = new EditorGrid<CollectionAPersonne>(storeGrille, modeleDeColonnes);
|
| Line 396... |
Line 417... |
| 396 |
grillePersonne.setTrackMouseOver(true);
|
417 |
grillePersonne.setTrackMouseOver(true);
|
| Line 397... |
Line 418... |
| 397 |
|
418 |
|
| 398 |
return grillePersonne;
|
419 |
return grillePersonne;
|
| Line -... |
Line 420... |
| - |
|
420 |
}
|
| - |
|
421 |
|
| - |
|
422 |
public ColumnConfig creerColonneDeces() {
|
| - |
|
423 |
GridCellRenderer<CollectionAPersonne> decesRendu = new GridCellRenderer<CollectionAPersonne>() {
|
| - |
|
424 |
@Override
|
| - |
|
425 |
public String render(CollectionAPersonne modele, String property, ColumnData config, int rowIndex, int colIndex, ListStore<CollectionAPersonne> store, Grid<CollectionAPersonne> grid) {
|
| - |
|
426 |
String deces = modele.getPersonne().getDeces();
|
| - |
|
427 |
if (listeIon != null && modele.getPersonne().getDeces().matches("[0-9]+")) {
|
| - |
|
428 |
deces = listeIon.get(modele.getPersonne().getDeces()).getNom();
|
| - |
|
429 |
}
|
| - |
|
430 |
modele.set("_deces_", deces);
|
| - |
|
431 |
return deces;
|
| - |
|
432 |
}
|
| - |
|
433 |
};
|
| - |
|
434 |
ColumnConfig decesColonne = new ColumnConfig("_deces_", Mediateur.i18nC.personneDecedeeInterogation(), 50);
|
| - |
|
435 |
decesColonne.setRenderer(decesRendu);
|
| - |
|
436 |
return decesColonne;
|
| 399 |
}
|
437 |
}
|
| 400 |
|
438 |
|
| 401 |
public void actualiserEtatBoutonsBarreOutils() {
|
439 |
public void actualiserEtatBoutonsBarreOutils() {
|
| 402 |
// Activation des boutons si la grille contient un élément
|
440 |
// Activation des boutons si la grille contient un élément
|
| 403 |
if (grille.getStore().getCount() > 0) {
|
441 |
if (grille.getStore().getCount() > 0) {
|
| Line 422... |
Line 460... |
| 422 |
GWT.log(Mediateur.i18nM.erreurRafraichir(nouvellesDonnees.getClass(), this.getClass()), null);
|
460 |
GWT.log(Mediateur.i18nM.erreurRafraichir(nouvellesDonnees.getClass(), this.getClass()), null);
|
| 423 |
}
|
461 |
}
|
| 424 |
}
|
462 |
}
|
| Line 425... |
Line 463... |
| 425 |
|
463 |
|
| - |
|
464 |
private void rafraichirValeurListe(ValeurListe listeValeurs) {
|
| - |
|
465 |
if (listeValeurs.getId().equals(config.getListeId("ion"))) {
|
| 426 |
private void rafraichirValeurListe(ValeurListe listeValeurs) {
|
466 |
listeIon = listeValeurs;
|
| 427 |
if (listeValeurs.getId().equals(config.getListeId("relationPersonneCollection"))) {
|
467 |
} else if (listeValeurs.getId().equals(config.getListeId("relationPersonneCollection"))) {
|
| 428 |
Formulaire.rafraichirComboBox(listeValeurs, typeRelationCombo);
|
468 |
Formulaire.rafraichirComboBox(listeValeurs, typeRelationCombo);
|
| 429 |
} else {
|
469 |
} else {
|
| 430 |
GWT.log("Gestion de la liste "+listeValeurs.getId()+" non implémenté!", null);
|
470 |
GWT.log("Gestion de la liste "+listeValeurs.getId()+" non implémenté!", null);
|
| 431 |
}
|
471 |
}
|
| Line 450... |
Line 490... |
| 450 |
initialiser();
|
490 |
initialiser();
|
| 451 |
// TODO : passer à la méthode peupler un objet CollectionAPersonneListe et modifier le type de auteurs
|
491 |
// TODO : passer à la méthode peupler un objet CollectionAPersonneListe et modifier le type de auteurs
|
| 452 |
//auteurs = (CollectionAPersonneListe) info.getDonnee(0);
|
492 |
//auteurs = (CollectionAPersonneListe) info.getDonnee(0);
|
| 453 |
peupler();
|
493 |
peupler();
|
| 454 |
}
|
494 |
}
|
| - |
|
495 |
} else if (info.getType().equals("ajout_collection")) {
|
| - |
|
496 |
if (info.getDonnee(0) != null && info.getDonnee(0) instanceof String) {
|
| - |
|
497 |
String collectionId = (String) info.getDonnee(0);
|
| - |
|
498 |
|
| - |
|
499 |
// Suite à la récupération de l'id de la collection nouvellement ajoutée nous ajoutons les personnes liées
|
| - |
|
500 |
// En mode AJOUT, il ne peut que y avoir des personnes liées ajoutées
|
| - |
|
501 |
mediateur.ajouterCollectionAPersonne(this, collectionId, personnesAjoutees);
|
| - |
|
502 |
} else {
|
| - |
|
503 |
Info.display("Ajout d'une Institution", info.toString());
|
| - |
|
504 |
}
|
| - |
|
505 |
} else if (info.getType().equals("modif_collection_a_personne")) {
|
| - |
|
506 |
Info.display("Modification des personnes liées à la collection", info.toString());
|
| - |
|
507 |
} else if (info.getType().equals("suppression_collection_a_personne")) {
|
| - |
|
508 |
Info.display("Suppression des personnes liées à la collection", info.toString());
|
| - |
|
509 |
} else if (info.getType().equals("ajout_collection_a_personne")) {
|
| - |
|
510 |
Info.display("Ajout des personnes liées à la collection", info.toString());
|
| 455 |
}
|
511 |
}
|
| 456 |
}
|
512 |
}
|
| 457 |
|
513 |
|
| 458 |
private void peupler() {
|
514 |
public void peupler() {
|
| - |
|
515 |
initialiserCollection();
|
| 459 |
layout();
|
516 |
layout();
|
| 460 |
Info.display(i18nC.chargementPersonne(), i18nC.ok());
|
517 |
Info.display(i18nC.chargementPersonne(), i18nC.ok());
|
| 461 |
}
|
518 |
}
|
| - |
|
519 |
|
| - |
|
520 |
public ArrayList<String> verifier() {
|
| - |
|
521 |
ArrayList<String> messages = new ArrayList<String>();
|
| - |
|
522 |
String personneNumero = "";
|
| - |
|
523 |
int nbrePersonne = grille.getStore().getCount();
|
| - |
|
524 |
|
| - |
|
525 |
if (nbrePersonne > 0) {
|
| - |
|
526 |
for (int i = 0; i < nbrePersonne; i++) {
|
| - |
|
527 |
CollectionAPersonne personne = grille.getStore().getAt(i);
|
| - |
|
528 |
if (personne.getIdRole().equals("")) {
|
| - |
|
529 |
personneNumero += (i != 0 ? ", " : "")+(i+1);
|
| - |
|
530 |
}
|
| - |
|
531 |
}
|
| - |
|
532 |
if (!personneNumero.equals("")) {
|
| - |
|
533 |
messages.add("Veuillez indiquez le type de relation existant entre la collection et les personnes numéros : "+personneNumero);
|
| - |
|
534 |
}
|
| - |
|
535 |
}
|
| - |
|
536 |
|
| - |
|
537 |
return messages;
|
| - |
|
538 |
}
|
| - |
|
539 |
|
| - |
|
540 |
public void collecter() {
|
| - |
|
541 |
initialiserCollection();
|
| - |
|
542 |
if (etreAccede()) {
|
| - |
|
543 |
int nbrePersonne = grille.getStore().getCount();
|
| - |
|
544 |
for (int i = 0; i < nbrePersonne; i++) {
|
| - |
|
545 |
CollectionAPersonne personne = grille.getStore().getAt(i);
|
| - |
|
546 |
// Seules les lignes ajoutées ou modifiées sont prises en compte.
|
| - |
|
547 |
Record enregistrement = grille.getStore().getRecord(personne);
|
| - |
|
548 |
if (grille.getStore().getModifiedRecords().contains(enregistrement) == true
|
| - |
|
549 |
|| (personne.get("etat") != null && personne.get("etat").equals(aDonnee.ETAT_AJOUTE) )) {
|
| - |
|
550 |
|
| - |
|
551 |
// Gestion de l'id de la structure
|
| - |
|
552 |
if (mode.equals(Formulaire.MODE_MODIFIER)) {
|
| - |
|
553 |
personne.setIdCollection(collection.getId());
|
| - |
|
554 |
}
|
| - |
|
555 |
|
| - |
|
556 |
// Ajout de la personne dans la liste correspondant à son état (ajouté ou modifié)
|
| - |
|
557 |
if (personne.get("etat") != null && personne.get("etat").equals(aDonnee.ETAT_AJOUTE)) {// Une personne ajoutée
|
| - |
|
558 |
personnesAjoutees.put(""+i, personne);
|
| - |
|
559 |
} else {// Une personne modifiée
|
| - |
|
560 |
personnesModifiees.put(personne.getId(), personne);
|
| - |
|
561 |
}
|
| - |
|
562 |
} else {
|
| - |
|
563 |
GWT.log("Personne non modifiées : "+personne.getPersonne().getPrenom()+" "+personne.getPersonne().getNom(), null);
|
| - |
|
564 |
}
|
| - |
|
565 |
}
|
| - |
|
566 |
}
|
| - |
|
567 |
}
|
| - |
|
568 |
|
| - |
|
569 |
public void soumettre() {
|
| - |
|
570 |
if (mode.equals(Formulaire.MODE_MODIFIER)) {
|
| - |
|
571 |
if (personnesModifiees.size() == 0 && personnesAjoutees.size() == 0 && personnesSupprimees.size() == 0) {
|
| - |
|
572 |
Info.display("Modification des personnes liées", "Rien n'a été enregistré car le formulaire n'a pas été modifié.");
|
| - |
|
573 |
} else {
|
| - |
|
574 |
if (personnesModifiees.size() != 0) {
|
| - |
|
575 |
mediateur.modifierCollectionAPersonne(this, personnesModifiees);
|
| - |
|
576 |
}
|
| - |
|
577 |
// Ajout des relations CollectionAPersonne
|
| - |
|
578 |
if (personnesAjoutees.size() != 0) {
|
| - |
|
579 |
mediateur.ajouterCollectionAPersonne(this, collection.getId(), personnesAjoutees);
|
| - |
|
580 |
}
|
| - |
|
581 |
// Suppression des relations StructureAPersonne
|
| - |
|
582 |
if (personnesSupprimees.size() != 0) {
|
| - |
|
583 |
mediateur.supprimerCollectionAPersonne(this, personnesSupprimees);
|
| - |
|
584 |
}
|
| - |
|
585 |
}
|
| - |
|
586 |
}
|
| - |
|
587 |
}
|
| 462 |
|
588 |
|
| 463 |
private void obtenirPersonnesSaisis(String nom) {
|
589 |
private void obtenirPersonnesSaisis(String nom) {
|
| 464 |
mediateur.selectionnerPersonneParNomComplet(this, null, nom+"%");
|
590 |
mediateur.selectionnerPersonneParNomComplet(this, null, nom+"%");
|
| 465 |
}
|
591 |
}
|
| 466 |
}
|
592 |
}
|