Subversion Repositories eFlore/Applications.del

Compare Revisions

Ignore whitespace Rev 925 → Rev 926

/trunk/src/org/tela_botanica/del/client/i18n/Vocabulary.properties
110,6 → 110,7
 
#ecran detail de votes détermination
aucunVoteEffectue = Aucun vote n'a été effectué sur cette détermination, soyez le premier a voter !
aucunCommentaireEffectue = Aucun commentaire n'a été effectué sur cette détermination
valeurVote = Vote
 
#composant recherche simple
/trunk/src/org/tela_botanica/del/client/i18n/Vocabulary.java
2,7 → 2,7
 
/**
* Interface to represent the constants contained in resource bundle:
* '/home/aurelien/web/del/src/org/tela_botanica/del/client/i18n/Vocabulary.properties'.
* 'D:/dev/svn/del/src/org/tela_botanica/del/client/i18n/Vocabulary.properties'.
*/
public interface Vocabulary extends com.google.gwt.i18n.client.Constants {
52,6 → 52,15
String anonyme();
 
/**
* Translated "Aucun commentaire n'a été effectué sur cette détermination".
*
* @return translated "Aucun commentaire n'a été effectué sur cette détermination"
*/
@DefaultStringValue("Aucun commentaire n'a été effectué sur cette détermination")
@Key("aucunCommentaireEffectue")
String aucunCommentaireEffectue();
 
/**
* Translated "Aucun resultat trouvé".
*
* @return translated "Aucun resultat trouvé"
/trunk/src/org/tela_botanica/del/client/utils/UtilitairesServiceResultat.java
22,35 → 22,34
import com.google.gwt.json.client.JSONValue;
 
public class UtilitairesServiceResultat {
public static Image parserImageJSON (JSONObject imageJson) {
 
public static Image parserImageJSON(JSONObject imageJson) {
 
Image image = new Image();
String idImage = imageJson.get("id_image").isString().stringValue();
image.setIdImage(idImage);
image.setUrlFormat("http://www.tela-botanica.org/appli:cel-img:"+getIdAvecPadding(idImage)+"%s%.jpg");
image.setUrl("http://www.tela-botanica.org/appli:cel-img:"+getIdAvecPadding(idImage)+"CRS.jpg");
image.setMiniature("http://www.tela-botanica.org/appli:cel-img:"+getIdAvecPadding(idImage)+"XS.jpg");
image.setUrlFormat("http://www.tela-botanica.org/appli:cel-img:" + getIdAvecPadding(idImage) + "%s%.jpg");
image.setUrl("http://www.tela-botanica.org/appli:cel-img:" + getIdAvecPadding(idImage) + "CRS.jpg");
image.setMiniature("http://www.tela-botanica.org/appli:cel-img:" + getIdAvecPadding(idImage) + "XS.jpg");
 
return image;
}
public static Observation parserObservationEtCreerPropositionDetermination(JSONObject observationJson) {
 
public static Observation parserObservationEtCreerPropositionDetermination(JSONObject observationJson) {
Observation observation = parserObservationJSON(observationJson);
return observation;
}
 
public static Observation parserObservationJSON(JSONObject observationJson) {
 
Observation observation = new Observation();
observation.setAuteur(getValeurOuVide(observationJson, "auteur.prenom")+
" "+getValeurOuVide(observationJson,"auteur.nom"));
observation.setNomAuteur(getValeurOuVide(observationJson,"auteur.nom"));
observation.setPrenomAuteur(getValeurOuVide(observationJson,"auteur.nom"));
observation.setIdAuteur(getValeurOuVide(observationJson,"auteur.id"));
//TODO: renvoyer le courriel de l'auteur dans les obs
observation.setAuteur(getValeurOuVide(observationJson, "auteur.prenom") + " " + getValeurOuVide(observationJson, "auteur.nom"));
observation.setNomAuteur(getValeurOuVide(observationJson, "auteur.nom"));
observation.setPrenomAuteur(getValeurOuVide(observationJson, "auteur.nom"));
observation.setIdAuteur(getValeurOuVide(observationJson, "auteur.id"));
// TODO: renvoyer le courriel de l'auteur dans les obs
observation.setCourrielAuteur("");
observation.setDateTransmission(getValeurOuVide(observationJson,"date_observation"));
observation.setDateTransmission(getValeurOuVide(observationJson, "date_observation"));
observation.setDateReleve(getValeurOuVide(observationJson, "date_observation"));
observation.setFamille(getValeurOuVide(observationJson, "determination.famille"));
observation.setId(getValeurOuVide(observationJson, "id_observation"));
60,11 → 59,12
observation.setMilieu(getValeurOuVide(observationJson, "milieu"));
observation.setLieuDit(getValeurOuVide(observationJson, "lieudit"));
observation.setNumNomenclatural(getValeurOuVide(observationJson, "determination.nn"));
//TODO: renvoyer les mots clés des observations
//observation.setMotsClefs(parserMotsCles(UtilitairesServiceResultat.getValeurOuVide(observationJson, "mots_cles_texte")));
// TODO: renvoyer les mots clés des observations
// observation.setMotsClefs(parserMotsCles(UtilitairesServiceResultat.getValeurOuVide(observationJson,
// "mots_cles_texte")));
JSONValue propositions = observationJson.get("commentaires");
if(propositions != null && propositions.isObject() != null) {
 
if (propositions != null && propositions.isObject() != null) {
List<InterventionForum> interventions = parserInterventions(propositions.isObject(), observation);
observation.setInterventionsForum(interventions);
} else {
72,29 → 72,46
}
return observation;
}
 
public static List<Commentaire> parserCommentaires(JSONObject commentaires, Observation observation) {
List<InterventionForum> interventionForums = parserInterventions(commentaires, observation);
List<Commentaire> commentairesListe = new ArrayList<Commentaire>();
for (InterventionForum interventionForum : interventionForums) {
if (interventionForum instanceof Commentaire) {
commentairesListe.add((Commentaire) interventionForum);
}
}
return commentairesListe;
 
}
 
public static List<InterventionForum> parserInterventions(JSONObject interventions, Observation observation) {
HashMap<String, InterventionForum> interventionsNonTypees = new HashMap<String, InterventionForum>();
 
List<InterventionForum> retour = new ArrayList<InterventionForum>();
//parcourir les interventions et en faire un tableau
// parcourir les interventions et en faire un tableau
if(interventions==null){
return retour;
}
Iterator<String> itInterventions = interventions.keySet().iterator();
while (itInterventions.hasNext()) {
JSONObject jsonIntervention = interventions.get(itInterventions.next()).isObject();
String nomSel = getValeurOuVide(jsonIntervention, "nom_sel");
 
String id = getValeurOuVide(jsonIntervention, "id_commentaire");
String idParent = getValeurOuVide(jsonIntervention, "ce_commentaire_parent");
String texte = getValeurOuVide(jsonIntervention, "texte");
 
String idUtilisateur = getValeurOuVide(jsonIntervention, "ce_utilisateur");
String nom = getValeurOuVide(jsonIntervention, "utilisateur_nom");
String prenom = getValeurOuVide(jsonIntervention, "utilisateur_prenom");
String courriel = getValeurOuVide(jsonIntervention, "utilisateur_courriel");
Contributeur contributeur = new Contributeur(idUtilisateur, nom, prenom, courriel);
//TODO : parser date
 
// TODO : parser date
Date date = new Date();
 
if (!nomSel.equals("")) {
String nom_sel = getValeurOuVide(jsonIntervention, "nom_sel");
String nom_sel_nn = getValeurOuVide(jsonIntervention, "nom_sel_nn");
102,29 → 119,28
String nom_ret_nn = getValeurOuVide(jsonIntervention, "nom_ret_nn");
String famille = getValeurOuVide(jsonIntervention, "famille");
String nom_referentiel = getValeurOuVide(jsonIntervention, "nom_referentiel");
 
String nbCommentaires = getValeurOuVide(jsonIntervention, "nb_commentaires");
 
PropositionDetermination intervention = new PropositionDetermination(id, contributeur, texte);
intervention.setObservation(observation);
intervention.setEspece(nom_sel);
if(!nbCommentaires.equals("")) {
 
if (!nbCommentaires.equals("")) {
intervention.setNbCommentaires(Integer.parseInt(nbCommentaires));
}
 
if (!idParent.equals("")) {
intervention.setIdParent(idParent);
}
if(jsonIntervention.get("votes") != null && jsonIntervention.get("votes").isObject() != null) {
 
if (jsonIntervention.get("votes") != null && jsonIntervention.get("votes").isObject() != null) {
intervention.setVotesDeterminations(parserVotesDetermination(jsonIntervention.get("votes").isObject(), intervention));
}
 
intervention.setDate(date);
interventionsNonTypees.put(intervention.getId(), intervention);
 
} else {
Commentaire intervention = new Commentaire(contributeur, date, texte);
intervention.setId(id);
146,26 → 162,26
intervention.setParent(parent);
}
}
 
List<InterventionForum> retour = new ArrayList<InterventionForum>();
retour.addAll(interventionsNonTypees.values());
return retour;
}
 
public static String parserRetourAjoutCommentaire(JSONObject retour) {
String id = "";
if(retour != null) {
if (retour != null) {
id = getValeurOuVide(retour, "id_commentaire");
}
return id;
}
 
public static String getValeurOuVide(JSONObject objet, String index) {
return (objet.get(index) != null && objet.get(index).isString() != null) ? objet.get(index).isString().stringValue() : "";
}
 
public static PropositionDetermination creerPropositionDeterminationAPartirObservation(Observation observation) {
 
String utilisateurNom = observation.getNomAuteur();
String utilisateurPrenom = observation.getPrenomAuteur();
String utilisateurCourriel = observation.getCourrielAuteur();
176,22 → 192,22
java.util.Date datePropDeter = parserDateObservation(observation.getDateReleve());
propositionDetermination.setDate(datePropDeter);
propositionDetermination.setEspece(observation.getNomRetenu());
 
return propositionDetermination;
}
 
public static HashMap<String, VoteDetermination> parserRetourListeVotesDetermination(String votesString, PropositionDetermination proposition) {
 
HashMap<String, VoteDetermination> retour = null;
 
JSONObject votes = JSONParser.parseStrict(votesString).isObject();
if(votes != null && votes.get("resultats") != null && votes.get("resultats").isObject() != null) {
if (votes != null && votes.get("resultats") != null && votes.get("resultats").isObject() != null) {
JSONObject resultat = votes.get("resultats").isObject();
retour = parserVotesDetermination(resultat, proposition);
}
return retour;
}
 
public static HashMap<String, VoteDetermination> parserVotesDetermination(JSONObject votes, PropositionDetermination proposition) {
HashMap<String, VoteDetermination> votesDetermination = new HashMap<String, VoteDetermination>();
java.util.Iterator<String> itVotes = votes.keySet().iterator();
204,32 → 220,27
vd.setPropositionDetermination(proposition);
vd.setVote(Integer.parseInt(getValeurOuVide(vote, "vote")));
vd.setContributeur(getValeurOuVide(vote, "auteur.id"));
if(vote.get("auteur.nom") != null &&
vote.get("auteur.nom") != null &&
vote.get("auteur.courriel") != null) {
Contributeur auteur = new Contributeur(getValeurOuVide(vote, "auteur.id"),
getValeurOuVide(vote, "auteur.nom"),
getValeurOuVide(vote, "auteur.prenom"),
getValeurOuVide(vote, "auteur.courriel"));
 
if (vote.get("auteur.nom") != null && vote.get("auteur.nom") != null && vote.get("auteur.courriel") != null) {
Contributeur auteur = new Contributeur(getValeurOuVide(vote, "auteur.id"), getValeurOuVide(vote, "auteur.nom"), getValeurOuVide(vote, "auteur.prenom"), getValeurOuVide(vote, "auteur.courriel"));
vd.setAuteur(auteur);
}
 
votesDetermination.put(getValeurOuVide(vote, "auteur.id"), vd);
}
}
return votesDetermination;
}
public static HashMap<String, HashMap<String,VoteProtocole>> parserVotesProtocoles(JSONObject votes) {
HashMap<String, HashMap<String,VoteProtocole>> votesProtocoles = new HashMap<String, HashMap<String,VoteProtocole>>();
 
public static HashMap<String, HashMap<String, VoteProtocole>> parserVotesProtocoles(JSONObject votes) {
 
HashMap<String, HashMap<String, VoteProtocole>> votesProtocoles = new HashMap<String, HashMap<String, VoteProtocole>>();
java.util.Iterator<String> itProtocoles = votes.keySet().iterator();
while(itProtocoles.hasNext()) {
JSONObject protocole = votes.get(itProtocoles.next()).isObject();
while (itProtocoles.hasNext()) {
JSONObject protocole = votes.get(itProtocoles.next()).isObject();
JSONObject votesPourCeProtocoles = protocole.get("votes").isObject();
String idProtocoleVote = protocole.get("protocole.id").isString().stringValue();
java.util.Iterator<String> itVotes = votesPourCeProtocoles.keySet().iterator();
while(itVotes.hasNext()) {
while (itVotes.hasNext()) {
JSONObject voteEnCours = votesPourCeProtocoles.get(itVotes.next()).isObject();
VoteProtocole vd = new VoteProtocole();
vd.setContributeur(voteEnCours.get("auteur.id").isString().stringValue());
237,27 → 248,27
vd.setDate(new Date());
int valeurVote = Integer.parseInt(voteEnCours.get("vote").isString().stringValue());
vd.setVote(valeurVote);
if(!votesProtocoles.containsKey(idProtocoleVote)) {
votesProtocoles.put(idProtocoleVote, new HashMap<String,VoteProtocole>());
if (!votesProtocoles.containsKey(idProtocoleVote)) {
votesProtocoles.put(idProtocoleVote, new HashMap<String, VoteProtocole>());
}
votesProtocoles.get(idProtocoleVote).put(vd.getContributeur(), vd);
}
}
 
return votesProtocoles;
}
 
public static Date parserDateObservation(String date) {
Date dateParsee = new Date();
DateTimeFormat formatDateObs = DateTimeFormat.getFormat("yyyy-MM-dd HH:mm:ss");
try{
dateParsee = formatDateObs.parse(date);
} catch (IllegalArgumentException e) {
dateParsee = new java.sql.Date(0);
try {
dateParsee = formatDateObs.parse(date);
} catch (IllegalArgumentException e) {
dateParsee = new java.sql.Date(0);
}
return dateParsee;
return dateParsee;
}
 
public static List<String> parserMotsCles(String motsClesTexte) {
String[] tabMotsCle = motsClesTexte.split(",");
List<String> motsClesParses = new ArrayList<String>();
264,10 → 275,10
for (int i = 0; i < tabMotsCle.length; i++) {
motsClesParses.add(tabMotsCle[i]);
}
 
return motsClesParses;
}
 
public static String getIdAvecPadding(String id) {
int maxZeros = 9 - id.length();
for (int i = 0; i < maxZeros; i++) {
275,25 → 286,25
}
return id;
}
 
public static Utilisateur parserUtilisateurJson(JSONValue valeurJson) {
 
JSONObject utilisateurJson = valeurJson.isObject();
boolean connecteUtilisateur = utilisateurJson.get("connecte").isBoolean().booleanValue();
String idUtilisateur = utilisateurJson.get("id_utilisateur").isString().stringValue();
 
Utilisateur utilisateur;
if(connecteUtilisateur) {
 
if (connecteUtilisateur) {
String courrielUtilisateur = utilisateurJson.get("courriel").isString().stringValue();
String nomUtilisateur = utilisateurJson.get("nom").isString().stringValue();
String prenomUtilisateur = utilisateurJson.get("prenom").isString().stringValue();
 
utilisateur = new Utilisateur(idUtilisateur, prenomUtilisateur, nomUtilisateur, courrielUtilisateur);
} else {
utilisateur = new Utilisateur(idUtilisateur);
}
 
return utilisateur;
}
}
/trunk/src/org/tela_botanica/del/client/vues/rechercheobservations/resultats/observationdeterminations/LignePropositionPresenteur.java
43,6 → 43,9
 
public void chargerPropositionDetermination() {
int nbCommentaires = propositionDetermination.getTotalCommentaires();
if (propositionDetermination.getCommentaire() != null && propositionDetermination.getCommentaire() != "") {
nbCommentaires += 1;
}
int nbVotes = propositionDetermination.getVotesDeterminations().size();
vue.setNbCommentaires(nbCommentaires);
vue.setNbVotes(nbVotes);
52,13 → 55,10
vue.getZoneNbVotes().addClickHandler(new ClickHandler() {
@Override
public void onClick(ClickEvent event) {
int nbVotes = propositionDetermination.getVotesDeterminations().size();
if (nbVotes > 0) {
FenetreOverlaySimplePresenteur fenetreOverlaySimplePresenteur = new FenetreOverlaySimplePresenteur(new FenetreOverlayDefilanteVue());
DetailListeVotesDeterminationPresenteur detailListeVotesDeterminationPresenteur = new DetailListeVotesDeterminationPresenteur(new DetailListeVotesDeterminationVue());
fenetreOverlaySimplePresenteur.ouvrirFenetreModale(detailListeVotesDeterminationPresenteur);
detailListeVotesDeterminationPresenteur.afficherVotes(propositionDetermination);
}
FenetreOverlaySimplePresenteur fenetreOverlaySimplePresenteur = new FenetreOverlaySimplePresenteur(new FenetreOverlayDefilanteVue());
DetailListeVotesDeterminationPresenteur detailListeVotesDeterminationPresenteur = new DetailListeVotesDeterminationPresenteur(new DetailListeVotesDeterminationVue());
fenetreOverlaySimplePresenteur.ouvrirFenetreModale(detailListeVotesDeterminationPresenteur);
detailListeVotesDeterminationPresenteur.afficherVotes(propositionDetermination);
}
});
 
65,13 → 65,10
vue.getZoneNbCommentaires().addClickHandler(new ClickHandler() {
@Override
public void onClick(ClickEvent event) {
int nbCommentaires = propositionDetermination.getTotalCommentaires();
if (nbCommentaires > 0) {
FenetreOverlaySimplePresenteur fenetreOverlaySimplePresenteur = new FenetreOverlaySimplePresenteur(new FenetreOverlayDefilanteVue());
DetailCommentairePresenteur detailCommentairePresenteur = new DetailCommentairePresenteur(new DetailCommentaireVue(), propositionDetermination);
fenetreOverlaySimplePresenteur.ouvrirFenetreModale(detailCommentairePresenteur);
detailCommentairePresenteur.afficherCommentaires();
}
FenetreOverlaySimplePresenteur fenetreOverlaySimplePresenteur = new FenetreOverlaySimplePresenteur(new FenetreOverlayDefilanteVue());
DetailCommentairePresenteur detailCommentairePresenteur = new DetailCommentairePresenteur(new DetailCommentaireVue(), propositionDetermination);
fenetreOverlaySimplePresenteur.ouvrirFenetreModale(detailCommentairePresenteur);
detailCommentairePresenteur.afficherCommentaires();
}
});
}
/trunk/src/org/tela_botanica/del/client/services/rest/async/CommentaireCallback.java
12,7 → 12,7
//TODO: voir si l'on fusionne les classes de commentaire et proposition callback qui sont tout à fait semblables
// pour ne pas dire identiques
public enum ModeRequete {
AJOUT, MODIFICATION, SUPPRESSION
AJOUT, MODIFICATION, SUPPRESSION, LECTURE
}
protected ModeRequete mode;
43,17 → 43,20
case SUPPRESSION:
codeAttendu = 200;
break;
case LECTURE:
codeAttendu = 200;
break;
default:
codeAttendu = 500;
break;
}
if (statusCode == codeAttendu) {
String id = UtilitairesServiceResultat.parserRetourAjoutCommentaire(JSONParser.parseStrict(response.getText()).isObject());
surRetour(id);
} else {
surErreur("Erreur " + statusCode + ": " + response.getText());
}
//if (statusCode == codeAttendu) {
//String id = UtilitairesServiceResultat.parserRetourAjoutCommentaire(JSONParser.parseStrict(response.getText()).isObject());
surRetour(response.getText());
//} else {
//surErreur("Erreur " + statusCode + ": " + response.getText());
//}
}
 
@Override
/trunk/src/org/tela_botanica/del/client/services/rest/CommentaireServiceConcret.java
60,4 → 60,17
"&auteur.courriel="+URL.encodeQueryString(commentaire.getContributeur().getAdresseEmail());
return chaineRequete;
}
 
public void chargerCommentaires(PropositionDetermination propositionDetermination, CommentaireCallback commentaireCallback) {
String urlService = baseUrl+"commentaires/?masque.proposition="+propositionDetermination.getId();
RequestBuilder rb = new RequestBuilder(RequestBuilder.GET, urlService);
commentaireCallback.setMode(ModeRequete.LECTURE);
try {
rb.sendRequest(null, commentaireCallback);
} catch (Exception e) {
//TODO: quoi faire si la requete est mal formée coté client avant d'être envoyée ?
}
}
}
/trunk/src/org/tela_botanica/del/client/composants/commentaires/DetailCommentaireVue.ui.xml
11,5 → 11,6
<g:HTMLPanel ui:field="panneauChargement" styleName="{style.chargement}">
<g:Image url="./img/wait.gif"></g:Image>
</g:HTMLPanel>
<g:HTMLPanel ui:field="aucuneDonnees" visible="false"><g:Label text="{constants.aucunCommentaireEffectue}"></g:Label></g:HTMLPanel>
</g:HTMLPanel>
</ui:UiBinder>
/trunk/src/org/tela_botanica/del/client/composants/commentaires/DetailCommentairePresenteur.java
1,14 → 1,15
package org.tela_botanica.del.client.composants.commentaires;
 
import java.util.HashMap;
import java.util.List;
 
import org.tela_botanica.del.client.composants.presenteur.Presenteur;
import org.tela_botanica.del.client.modeles.Commentaire;
import org.tela_botanica.del.client.modeles.PropositionDetermination;
import org.tela_botanica.del.client.modeles.VoteDetermination;
import org.tela_botanica.del.client.services.rest.VoteDeterminationServiceConcret;
import org.tela_botanica.del.client.services.rest.async.VoteDeterminationCallback;
import org.tela_botanica.del.client.services.rest.CommentaireServiceConcret;
import org.tela_botanica.del.client.services.rest.async.CommentaireCallback;
import org.tela_botanica.del.client.utils.UtilitairesServiceResultat;
 
import com.google.gwt.json.client.JSONParser;
import com.google.gwt.user.client.Window;
import com.google.gwt.user.client.ui.HasWidgets;
import com.google.gwt.user.client.ui.IsWidget;
21,6 → 22,8
void stopChargement();
 
void startChargement();
 
public void afficherAucuneDonnees();
}
 
private Vue vue;
38,17 → 41,19
 
public void afficherCommentaires() {
vue.startChargement();
VoteDeterminationServiceConcret voteService = new VoteDeterminationServiceConcret();
voteService.consulterVotesPourPropositionDetermination(propositionDetermination, new VoteDeterminationCallback() {
CommentaireServiceConcret commentaireService = new CommentaireServiceConcret();
commentaireService.chargerCommentaires(propositionDetermination, new CommentaireCallback() {
 
@Override
public void surRetour(String messageRetour) {
 
HashMap<String, VoteDetermination> votesComplets = UtilitairesServiceResultat.parserRetourListeVotesDetermination(messageRetour, propositionDetermination);
if (votesComplets != null) {
propositionDetermination.setVotesDeterminations(UtilitairesServiceResultat.parserRetourListeVotesDetermination(messageRetour, propositionDetermination));
List<Commentaire> commentaires = UtilitairesServiceResultat.parserCommentaires(JSONParser.parseStrict(messageRetour).isObject().get("resultats").isObject(), propositionDetermination.getObservation());
propositionDetermination.setListeCommentaires(commentaires);
int nbCommentaires = propositionDetermination.getTotalCommentaires();
if (nbCommentaires > 0) {
vue.afficherCommentairesProposition(propositionDetermination);
vue.stopChargement();
} else {
vue.afficherAucuneDonnees();
vue.stopChargement();
}
 
/trunk/src/org/tela_botanica/del/client/composants/commentaires/DetailCommentaireVue.java
23,7 → 23,7
};
 
@UiField
HTMLPanel titre;
HTMLPanel titre, aucuneDonnees;
 
@UiField
Panel panneauChargement;
84,5 → 84,10
public void stopChargement() {
panneauChargement.setVisible(false);
}
@Override
public void afficherAucuneDonnees() {
aucuneDonnees.setVisible(true);
}
 
}