Subversion Repositories eFlore/Applications.coel

Compare Revisions

Ignore whitespace Rev 276 → Rev 277

/trunk/src/org/tela_botanica/client/vues/PersonneVue.java
1,17 → 1,19
package org.tela_botanica.client.vues;
 
import org.tela_botanica.client.Mediateur;
import org.tela_botanica.client.RegistreId;
import org.tela_botanica.client.interfaces.Rafraichissable;
import org.tela_botanica.client.modeles.Information;
import org.tela_botanica.client.modeles.PersonneListe;
import org.tela_botanica.client.modeles.StructureListe;
 
import com.extjs.gxt.ui.client.Registry;
import com.extjs.gxt.ui.client.Style.LayoutRegion;
import com.extjs.gxt.ui.client.util.Margins;
import com.extjs.gxt.ui.client.widget.Info;
import com.extjs.gxt.ui.client.widget.LayoutContainer;
import com.extjs.gxt.ui.client.widget.layout.BorderLayout;
import com.extjs.gxt.ui.client.widget.layout.BorderLayoutData;
import com.google.gwt.user.client.Window;
import com.google.gwt.core.client.GWT;
 
public class PersonneVue extends LayoutContainer implements Rafraichissable {
 
36,8 → 38,19
public void rafraichir(Object nouvelleDonnees) {
if (nouvelleDonnees instanceof PersonneListe) {
remplirListe((PersonneListe) nouvelleDonnees);
} else if (nouvelleDonnees instanceof Information) {
Information info = (Information) nouvelleDonnees;
// Affichage des éventuels messages de déboguage ou d'alerte
if (info.getMessages() != null && !info.getMessages().toString().equals("[]")) {
GWT.log(info.getMessages().toString(), null);
}
// Traitement en fonction des types d'information
if (info.getType().equals("liste_personne")) {
((Mediateur) Registry.get(RegistreId.MEDIATEUR)).afficherListePersonnes((PersonneListe) info.getDonnee(0));
Info.display("Chargement d'une liste de personnes", "");
}
} else {
Window.alert("Problème!");
GWT.log("Pas de correspondance dans la méthode rafraichir() de la classe "+this.getClass(), null);
}
}
/trunk/src/org/tela_botanica/client/vues/StructureListePanneauVue.java
32,7 → 32,6
import com.extjs.gxt.ui.client.widget.toolbar.TextToolItem;
import com.extjs.gxt.ui.client.widget.toolbar.ToolBar;
import com.google.gwt.core.client.GWT;
import com.google.gwt.user.client.Window;
 
public class StructureListePanneauVue extends ContentPanel implements Rafraichissable {
46,7 → 45,7
private TextToolItem ajouter;
 
public StructureListePanneauVue() {
Utilisateur utilisateur = (Utilisateur) Registry.get(RegistreId.UTILISATEUR);
Utilisateur utilisateur = (Utilisateur) Registry.get(RegistreId.UTILISATEUR_COURANT);
mediateur = Registry.get(RegistreId.MEDIATEUR);
structureListePanneauVue = this;
162,7 → 161,7
modifier.disable();
}
} else if (info.getType().equals("maj_utilisateur")) {
if (((Utilisateur) Registry.get(RegistreId.UTILISATEUR)).isIdentifie()) {
if (((Utilisateur) Registry.get(RegistreId.UTILISATEUR_COURANT)).isIdentifie()) {
if (table.getItemCount() != 0) {
supprimer.enable();
}
/trunk/src/org/tela_botanica/client/vues/EntetePanneauVue.java
124,7 → 124,7
if (nouvelleDonnees instanceof Information) {
Information info = (Information) nouvelleDonnees;
if (info.getType().equals("maj_utilisateur")) {
Utilisateur utilisateur = ((Utilisateur) Registry.get(RegistreId.UTILISATEUR));
Utilisateur utilisateur = ((Utilisateur) Registry.get(RegistreId.UTILISATEUR_COURANT));
if (utilisateur.isIdentifie() == true) {
identificationInfoHtml.setHtml(Format.substitute(identificationInfoTpl, (new Params()).add("Bienvenue : "+utilisateur.getNomComplet())));
identificationBouton.setText("Deconnexion");
/trunk/src/org/tela_botanica/client/vues/MenuPanneauVue.java
1,13 → 1,11
package org.tela_botanica.client.vues;
 
import java.util.Collection;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
 
import org.tela_botanica.client.ComposantId;
import org.tela_botanica.client.Mediateur;
import org.tela_botanica.client.RegistreId;
import org.tela_botanica.client.interfaces.Rafraichissable;
import org.tela_botanica.client.modeles.Menu;
import org.tela_botanica.client.modeles.Projet;
import org.tela_botanica.client.modeles.ProjetListe;
18,24 → 16,21
import com.extjs.gxt.ui.client.event.TreeEvent;
import com.extjs.gxt.ui.client.util.TreeBuilder;
import com.extjs.gxt.ui.client.widget.ContentPanel;
import com.extjs.gxt.ui.client.widget.layout.FitLayout;
import com.extjs.gxt.ui.client.widget.layout.FlowLayout;
import com.extjs.gxt.ui.client.widget.tree.Tree;
import com.extjs.gxt.ui.client.widget.tree.TreeItem;
import com.google.gwt.user.client.Window;
import com.google.gwt.user.client.ui.ChangeListener;
import com.google.gwt.user.client.ui.ClickListener;
import com.google.gwt.user.client.ui.ListBox;
import com.google.gwt.user.client.ui.MouseListener;
import com.google.gwt.user.client.ui.Widget;
 
public class MenuPanneauVue extends ContentPanel implements Rafraichissable {
 
public class MenuPanneauVue extends ContentPanel {
 
private Tree tree;
private ListBox listeProjets;
private boolean listeProjetsInitialise = false;
private ProjetListe projetsCache = null;
public MenuPanneauVue() {
setBodyBorder(false);
setLayoutOnChange(true);
47,15 → 42,13
if (nouvelleDonnees instanceof Menu) {
afficherMenu((Menu) nouvelleDonnees);
} else if (nouvelleDonnees instanceof ProjetListe) {
afficherProjets((ProjetListe) nouvelleDonnees);
projetsCache = (ProjetListe) nouvelleDonnees;
afficherProjets();
}
}
 
private void afficherProjets(ProjetListe projets) {
Collection<Projet> valeursProjets = projets.values();
Iterator it = valeursProjets.iterator();
private void afficherProjets() {
Iterator it = projetsCache.values().iterator();
while (it.hasNext()) {
Projet projetCourant = (Projet) it.next();
listeProjets.addItem(projetCourant.getNom(), projetCourant.getId());
74,7 → 67,7
listeProjets.addClickListener(new ClickListener() {
public void onClick(Widget sender) {
if(!listeProjetsInitialise) {
((Mediateur) Registry.get(RegistreId.MEDIATEUR)).rafraichirListeProjets();
chargerProjets();
listeProjetsInitialise = true;
}
}
85,7 → 78,7
listeProjets.addChangeListener(new ChangeListener() {
public void onChange(Widget sender) {
// TODO : récupérer la valeur passé par l'évenement et enregistrer dans le registre
((Mediateur) Registry.get(RegistreId.MEDIATEUR)).selectionnerProjet(listeProjets.getValue(listeProjets.getSelectedIndex()));
((Mediateur) Registry.get(RegistreId.MEDIATEUR)).selectionnerProjetCourant(projetsCache.get(listeProjets.getValue(listeProjets.getSelectedIndex())));
}
});
127,4 → 120,9
return menus;
}
}
private void chargerProjets() {
((Mediateur) Registry.get(RegistreId.MEDIATEUR)).selectionnerProjets(this);
}
}
/trunk/src/org/tela_botanica/client/vues/StructureVue.java
2,7 → 2,6
 
import org.tela_botanica.client.RegistreId;
import org.tela_botanica.client.interfaces.Rafraichissable;
import org.tela_botanica.client.modeles.StructureListe;
 
import com.extjs.gxt.ui.client.Registry;
import com.extjs.gxt.ui.client.Style.LayoutRegion;
11,7 → 10,6
import com.extjs.gxt.ui.client.widget.layout.BorderLayout;
import com.extjs.gxt.ui.client.widget.layout.BorderLayoutData;
import com.google.gwt.core.client.GWT;
import com.google.gwt.user.client.Window;
 
public class StructureVue extends LayoutContainer implements Rafraichissable {
 
/trunk/src/org/tela_botanica/client/vues/ContenuPanneauVue.java
1,13 → 1,51
package org.tela_botanica.client.vues;
 
import org.tela_botanica.client.modeles.Utilisateur;
import org.tela_botanica.client.Mediateur;
import org.tela_botanica.client.RegistreId;
import org.tela_botanica.client.interfaces.Rafraichissable;
import org.tela_botanica.client.modeles.Information;
import org.tela_botanica.client.modeles.PersonneListe;
import org.tela_botanica.client.modeles.ProjetListe;
import org.tela_botanica.client.modeles.PublicationListe;
import org.tela_botanica.client.modeles.StructureListe;
 
import com.extjs.gxt.ui.client.Registry;
import com.extjs.gxt.ui.client.widget.Info;
import com.extjs.gxt.ui.client.widget.LayoutContainer;
import com.extjs.gxt.ui.client.widget.layout.FitLayout;
import com.google.gwt.core.client.GWT;
 
public class ContenuPanneauVue extends LayoutContainer {
public class ContenuPanneauVue extends LayoutContainer implements Rafraichissable {
public ContenuPanneauVue() {
setLayout(new FitLayout());
}
//+----------------------------------------------------------------------------------------------------------------+
// RAFRAICHISSEMENT
//+----------------------------------------------------------------------------------------------------------------+
public void rafraichir(Object nouvelleDonnees) {
Mediateur mediateur = ((Mediateur) Registry.get(RegistreId.MEDIATEUR));
if (nouvelleDonnees instanceof StructureListe) {
mediateur.afficherListeStructures((StructureListe) nouvelleDonnees);
} else if (nouvelleDonnees instanceof PublicationListe) {
mediateur.afficherListePublication((PublicationListe) nouvelleDonnees);
} else if (nouvelleDonnees instanceof PersonneListe) {
} else if (nouvelleDonnees instanceof ProjetListe) {
mediateur.afficherListeProjets((ProjetListe) nouvelleDonnees);
} else if (nouvelleDonnees instanceof Information) {
Information info = (Information) nouvelleDonnees;
// Affichage des éventuels messages de déboguage ou d'alerte
if (info.getMessages() != null && !info.getMessages().toString().equals("[]")) {
GWT.log(info.getMessages().toString(), null);
}
// Traitement en fonction des types d'information
if (info.getType().equals("liste_personne")) {
mediateur.afficherListePersonnes((PersonneListe) info.getDonnee(0));
Info.display("Chargement d'une liste de personnes", "");
}
}
}
}
/trunk/src/org/tela_botanica/client/vues/FormStructureVue.java
15,6 → 15,8
import org.tela_botanica.client.modeles.InterneValeurListe;
import org.tela_botanica.client.modeles.Personne;
import org.tela_botanica.client.modeles.PersonneListe;
import org.tela_botanica.client.modeles.Projet;
import org.tela_botanica.client.modeles.ProjetListe;
import org.tela_botanica.client.modeles.Structure;
import org.tela_botanica.client.modeles.StructureAPersonne;
import org.tela_botanica.client.modeles.StructureAPersonneListe;
86,6 → 88,7
import com.google.gwt.i18n.client.DateTimeFormat;
import com.google.gwt.i18n.client.NumberFormat;
import com.google.gwt.user.client.Window;
import com.google.gwt.user.client.ui.ListBox;
 
public class FormStructureVue extends LayoutContainer implements Rafraichissable {
94,6 → 97,7
private Modele modele = null ;
 
private String mode = "AJOUT";
private int tabIndex = 100;
private FormPanel structureFormPanneau = null;
private TabPanel onglets = null;
 
209,6 → 213,9
private ListStore<Personne> personneExistanteMagazin;
private ComboBox<Personne> personneExistanteCombo;
private TextToolItem supprimerPersonnelBtn;
private ListBox projetChp;
private ListStore<Projet> projetsMagazin;
private ComboBox<Projet> projetsCombo;
 
 
public FormStructureVue() {
298,7 → 305,7
if (mode.equals("AJOUT")) {
// Ajout des informations sur la Structure
mediateur.ajouterStructure(this, structure);
mediateur.ajouterStructure(this, structure, conservation, valorisation);
// L'ajout des relations StructureAPersonne se fait quand la structure a été ajoutée
// Voir la méthode rafraichir().
} else if (mode.equals("MODIF")) {
625,6 → 632,10
Structure structure = new Structure();
structure.setId(idStructureChp.getValue());
structure.setNom(nomStructureChp.getValue());
// Récupération de l'identifiant du projet
if (projetsCombo.getValue() != null) {
structure.setIdProjet(projetsCombo.getValue().getId());
}
// Récupération de l'acronyme (= identifiant alternatif)
structure.setIdAlternatif(null);
if (comboAcronyme.getValue() != null) {
680,6 → 691,10
if (mode.equals("MODIF") && identification != null && identificationOnglet.getData("acces").equals(false)) {
idStructureChp.setValue(identification.getId());
nomStructureChp.setValue(identification.getNom());
if (!identification.getIdProjet().equals("0")) {
projetsCombo.setValue(projetsCombo.getStore().findModel("id_projet", identification.getIdProjet()));
}
if (!identification.getIdAlternatif().isEmpty()) {
String[] acronyme = identification.getIdAlternatif().split("##");
if (acronyme[0].matches("^IH$")) {
1104,7 → 1119,7
configs.add(r);
ColumnConfig column = new ColumnConfig("fonction", "Fonction", 150);
modele.obtenirListeValeurs(((Configuration) Registry.get(RegistreId.CONFIG)).getListeId("fonction"));
modele.obtenirListeValeurs(this, ((Configuration) Registry.get(RegistreId.CONFIG)).getListeId("fonction"));
magazinLiFonction = new ListStore<Valeur>();
magazinLiFonction.add(new ArrayList<Valeur>());
1203,7 → 1218,7
column.setEditor(new CellEditor(emailChp));
configs.add(column);
modele.obtenirListeValeurs(((Configuration) Registry.get(RegistreId.CONFIG)).getListeId("statut"));
modele.obtenirListeValeurs(this, ((Configuration) Registry.get(RegistreId.CONFIG)).getListeId("statut"));
magazinLiStatut = new ListStore<Valeur>();
magazinLiStatut.add(new ArrayList<Valeur>());
1421,12 → 1436,25
fieldSetIdentite.setLayout(creerFormLayout(200, LabelAlign.LEFT, 4));
nomStructureChp = new TextField<String>();
nomStructureChp.setTabIndex(100);
nomStructureChp.setTabIndex(tabIndex++);
nomStructureChp.setFieldLabel("Nom de la structure");
nomStructureChp.setAllowBlank(false);
nomStructureChp.getMessages().setBlankText("Ce champ est obligatoire.");
fieldSetIdentite.add(nomStructureChp, new FormData(450, 0));
modele.selectionnerProjets(this);
projetsMagazin = new ListStore<Projet>();
projetsMagazin.add(new ArrayList<Projet>());
projetsCombo = new ComboBox<Projet>();
projetsCombo.setTabIndex(tabIndex++);
projetsCombo.setFieldLabel("Projet");
projetsCombo.setLabelSeparator("");
projetsCombo.setDisplayField("nom");
projetsCombo.setEditable(false);
projetsCombo.setTriggerAction(TriggerAction.ALL);
projetsCombo.setStore(projetsMagazin);
fieldSetIdentite.add(projetsCombo, new FormData(450, 0));
// Création du sous-formulaire : Acronyme
LayoutContainer ligne = new LayoutContainer();
ligne.setLayout(new ColumnLayout());
1439,7 → 1467,7
acronymes.add(InterneValeurListe.getTypeAcronyme());
comboAcronyme = new ComboBox<InterneValeur>();
comboAcronyme.setTabIndex(101);
comboAcronyme.setTabIndex(tabIndex++);
comboAcronyme.setEmptyText("Sélectioner un type d'acronyme...");
comboAcronyme.setFieldLabel("Acronymes");
comboAcronyme.setDisplayField("nom");
1468,7 → 1496,7
ihChp = new TextField<String>();
//ihChp.setEmptyText("Index Herbariorum");
ihChp.setTabIndex(102);
ihChp.setTabIndex(tabIndex++);
ihChp.setLabelSeparator("");
ihChp.setToolTip("Index Herbariorum : herbier de plus de 5000 échantillons");
ihChp.hide();
1475,7 → 1503,7
droite.add(ihChp);
mnhnChp = new TextField<String>();
mnhnChp.setTabIndex(103);
mnhnChp.setTabIndex(tabIndex++);
//mnhnChp.setEmptyText("MNHN");
mnhnChp.setLabelSeparator("");
mnhnChp.setToolTip("Acronyme MNHN : herbier de moins de 5000 échantillons");
1500,7 → 1528,7
typesStructure.add(InterneValeurListe.getTypeStructure());
comboTypeStructure = new ComboBox<InterneValeur>();
comboTypeStructure.setTabIndex(104);
comboTypeStructure.setTabIndex(tabIndex++);
comboTypeStructure.setEmptyText("Sélectioner un type de structure...");
comboTypeStructure.setFieldLabel("Statut des structures");
comboTypeStructure.setDisplayField("nom");
1527,11 → 1555,11
});
gaucheTs.add(comboTypeStructure);
modele.obtenirListeValeurs(((Configuration) Registry.get(RegistreId.CONFIG)).getListeId("stpu"));
modele.obtenirListeValeurs(this, ((Configuration) Registry.get(RegistreId.CONFIG)).getListeId("stpu"));
magazinLstpu = new ListStore<Valeur>();
magazinLstpu.add(new ArrayList<Valeur>());
comboLstpu = new ComboBox<Valeur>();
comboLstpu.setTabIndex(105);
comboLstpu.setTabIndex(tabIndex++);
//comboLstpu.setFieldLabel("Statut des structures publiques");
comboLstpu.setLabelSeparator("");
comboLstpu.setDisplayField("nom");
1541,11 → 1569,11
comboLstpu.hide();
droiteTs.add(comboLstpu);
modele.obtenirListeValeurs(((Configuration) Registry.get(RegistreId.CONFIG)).getListeId("stpr"));
modele.obtenirListeValeurs(this, ((Configuration) Registry.get(RegistreId.CONFIG)).getListeId("stpr"));
magazinLstpr = new ListStore<Valeur>();
magazinLstpr.add(new ArrayList<Valeur>());
comboLstpr = new ComboBox<Valeur>();
comboLstpr.setTabIndex(106);
comboLstpr.setTabIndex(tabIndex++);
//comboLstpr.setFieldLabel("Statut des structures privées");
comboLstpr.setLabelSeparator("");
comboLstpr.setDisplayField("nom");
1560,7 → 1588,7
fieldSetIdentite.add(ligneTs);
dateFondationChp = new DateField();
dateFondationChp.setTabIndex(107);
dateFondationChp.setTabIndex(tabIndex++);
dateFondationChp.setFieldLabel("Date de fondation");
dateFondationChp.getPropertyEditor().getFormat();
dateFondationChp.getPropertyEditor().setFormat(DateTimeFormat.getFormat("dd/MM/yyyy"));
1594,22 → 1622,22
fieldSetAdresse.setLayout(creerFormLayout(100, LabelAlign.LEFT, 4));
adrChp = new TextArea();
adrChp.setTabIndex(108);
adrChp.setTabIndex(tabIndex++);
adrChp.setFieldLabel("Adresse");
fieldSetAdresse.add(adrChp, new FormData(550, 0));
cpChp = new TextField<String>();
cpChp.setTabIndex(109);
cpChp.setTabIndex(tabIndex++);
cpChp.setFieldLabel("Code postal");
gaucheFdAdresse.add(cpChp);
villeChp = new TextField<String>();
villeChp.setTabIndex(110);
villeChp.setTabIndex(tabIndex++);
villeChp.setFieldLabel("Ville");
droiteFdAdresse.add(villeChp);
regionChp = new TextField<String>();
regionChp.setTabIndex(111);
regionChp.setTabIndex(tabIndex++);
regionChp.setFieldLabel("Région");
gaucheFdAdresse.add(regionChp);
1616,11 → 1644,11
//paysChp = new TextField<String>();
//paysChp.setTabIndex(112);
//paysChp.setFieldLabel("Pays");
modele.obtenirListeValeurs(((Configuration) Registry.get(RegistreId.CONFIG)).getListeId("pays"));
modele.obtenirListeValeurs(this, ((Configuration) Registry.get(RegistreId.CONFIG)).getListeId("pays"));
magazinPays = new ListStore<Valeur>();
magazinPays.add(new ArrayList<Valeur>());
comboPays = new ComboBox<Valeur>();
comboPays.setTabIndex(112);
comboPays.setTabIndex(tabIndex++);
comboPays.setFieldLabel("Pays");
comboPays.setEmptyText("Sélectioner un pays...");
comboPays.setEditable(true);
1655,23 → 1683,23
fieldSetTelMail.setLayout(creerFormLayout(200, LabelAlign.LEFT, 4));
telChp = new TextField<String>();
telChp.setTabIndex(113);
telChp.setTabIndex(tabIndex++);
telChp.setFieldLabel("Téléphone");
gaucheFdTelMail.add(telChp);
faxChp = new TextField<String>();
faxChp.setTabIndex(114);
faxChp.setTabIndex(tabIndex++);
faxChp.setFieldLabel("Fax");
droiteFdTelMail.add(faxChp);
emailChp = new TextField<String>();
emailChp.setTabIndex(115);
emailChp.setTabIndex(tabIndex++);
emailChp.setFieldLabel("Courriel");
emailChp.setToolTip("Saisir le courriel de l'organisation, pas de courriel individuel. Ex. : accueil@organisation.org");
gaucheFdTelMail.add(emailChp);
urlChp = new TextField<String>();
urlChp.setTabIndex(116);
urlChp.setTabIndex(tabIndex++);
urlChp.setFieldLabel("Site web");
droiteFdTelMail.add(urlChp);
1866,7 → 1894,7
* @return
*/
private ContentPanel creerChoixMultipleCp(String listeNom) {
modele.obtenirListeValeurs(((Configuration) Registry.get(RegistreId.CONFIG)).getListeId(listeNom));
modele.obtenirListeValeurs(this, ((Configuration) Registry.get(RegistreId.CONFIG)).getListeId(listeNom));
ContentPanel cp = new ContentPanel();
cp.setLayout(creerFormLayout(650, LabelAlign.TOP, 0));
cp.setHeaderVisible(false);
2103,6 → 2131,18
} else {
GWT.log("La liste #"+listeValeurs.getId()+" ne contient aucune valeurs!", null);
}
} else if (nouvelleDonnees instanceof ProjetListe) {
ProjetListe projets = (ProjetListe) nouvelleDonnees;
List<Projet> liste = new ArrayList<Projet>();
for (Iterator<String> it = projets.keySet().iterator(); it.hasNext();) {
liste.add(projets.get(it.next()));
}
projetsMagazin.removeAll();
projetsMagazin.add(liste);
projetsCombo.setStore(projetsMagazin);
} else {
GWT.log("Pas de correspondance dans la méthode rafraichir() de la classe "+this.getClass(), null);
}
} catch (Exception e) {
GWT.log("rafraichir()", e);