Subversion Repositories eFlore/Applications.del

Rev

Rev 447 | Rev 462 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
359 benjamin 1
package org.tela_botanica.del.client.modeles;
2
 
392 aurelien 3
import java.util.ArrayList;
4
import java.util.Date;
359 benjamin 5
import java.util.List;
6
 
392 aurelien 7
import com.google.gwt.i18n.client.DateTimeFormat;
8
import com.google.gwt.json.client.JSONArray;
9
import com.google.gwt.json.client.JSONObject;
10
import com.google.gwt.json.client.JSONValue;
11
 
359 benjamin 12
public class ObservationServiceResultat {
13
 
14
	private List<Observation> observations;
15
 
16
	private int nbTotalObservationsPourLaRecherche;
17
 
392 aurelien 18
	public ObservationServiceResultat(JSONValue retourJson) {
19
		//TODO ajouter vérifications plus précises
20
		double total = retourJson.isObject().get("total").isNumber().doubleValue();
21
		nbTotalObservationsPourLaRecherche = (int) total;
22
		JSONArray tableauObs = retourJson.isObject().get("contenu").isArray();
23
 
24
		observations = new ArrayList<Observation>();
25
 
26
		int nbResultats = tableauObs.size();
27
		for (int i = 0; i < nbResultats; i++) {
28
 
29
			JSONObject observationJson = tableauObs.get(i).isObject();
30
			Observation observation = new Observation();
31
 
32
			observation.setAuteur(observationJson.get("prenom_utilisateur").isString().stringValue()+
33
						" "+observationJson.get("nom_utilisateur").isString().stringValue());
449 gduche 34
			observation.setDateReleve(observationJson.get("date_observation").isString().stringValue());
35
			observation.setDateTransmission(observationJson.get("date_transmission").isString().stringValue());
392 aurelien 36
			observation.setFamille(observationJson.get("famille").isString().stringValue());
37
			observation.setId(observationJson.get("id_observation").isString().stringValue());
38
			observation.setLocalite(observationJson.get("ce_zone_geo").isString().stringValue());
447 gduche 39
			observation.setLieuDit(observationJson.get("lieudit").isString().stringValue());
40
			observation.setMilieu(observationJson.get("milieu").isString().stringValue());
392 aurelien 41
			observation.setNomRetenu(observationJson.get("nom_ret").isString().stringValue());
447 gduche 42
			observation.setCommentaire(observationJson.get("commentaire").isString().stringValue());
43
			observation.ajouterMotsClef(observationJson.get("mots_cles_texte").isString().stringValue());
392 aurelien 44
			observation.setNumNomenclatural(observationJson.get("nom_ret_nn").isString().stringValue());
45
			observation.setMotsClefs(parserMotsCles(observationJson.get("mots_cles_texte").isString().stringValue()));
46
 
47
			PropositionDetermination propositionDetermination = new PropositionDetermination();
48
			propositionDetermination.setContributeur(observationJson.get("prenom_utilisateur").isString().stringValue()+
49
					" "+observationJson.get("nom_utilisateur").isString().stringValue());
50
			java.util.Date datePropDeter = parserDateObservation(observationJson.get("date_observation").isString().stringValue());
51
			propositionDetermination.setDate(datePropDeter);
52
			propositionDetermination.setEspece(observationJson.get("nom_ret").isString().stringValue());
53
			observation.addImageCelValidationData(propositionDetermination);
54
 
55
			JSONArray tableauImagesObs = observationJson.get("images").isArray();
56
			List<Image> imagesPourObs = new ArrayList<Image>();
57
 
58
			int nbImages = tableauImagesObs.size();
59
			for (int j = 0; j < nbImages; j++) {
60
				JSONObject imageJson = tableauImagesObs.get(j).isObject();
61
				Image image = new Image();
62
				String idImage = "1"+imageJson.get("id_image").isString().stringValue();
63
				image.setIdImage(idImage);
64
				image.setUrlFormat("http://www.tela-botanica.org/appli:cel-img:"+getIdAvecPadding(idImage)+"%s%.jpg");
65
				image.setUrl("http://www.tela-botanica.org/appli:cel-img:"+getIdAvecPadding(idImage)+"CRS.jpg");
66
				image.setMiniature("http://www.tela-botanica.org/appli:cel-img:"+getIdAvecPadding(idImage)+"XS.jpg");
67
				image.setObservation(observation);
68
				imagesPourObs.add(image);
69
			}
70
 
71
			observation.setImages(imagesPourObs);
72
			observations.add(observation);
73
		}
74
	}
75
 
359 benjamin 76
	public List<Observation> getObservations() {
77
		return observations;
78
	}
79
 
80
	public void setObservations(List<Observation> observations) {
81
		this.observations = observations;
82
	}
83
 
84
	public int getNbTotalObservationsPourLaRecherche() {
85
		return nbTotalObservationsPourLaRecherche;
86
	}
87
 
88
	public void setNbTotalObservationsPourLaRecherche(int nbTotalObservationsPourLaRecherche) {
89
		this.nbTotalObservationsPourLaRecherche = nbTotalObservationsPourLaRecherche;
90
	}
392 aurelien 91
 
92
	private String getIdAvecPadding(String id) {
359 benjamin 93
 
392 aurelien 94
		int maxZeros = 9 - id.length();
95
 
96
		for (int i = 0; i < maxZeros; i++) {
97
			id = "0" + id;
98
		}
99
 
100
		return id;
101
	}
359 benjamin 102
 
392 aurelien 103
	private Date parserDateObservation(String date) {
104
		Date dateParsee = new Date();
105
		DateTimeFormat formatDateObs = DateTimeFormat.getFormat("yyyy-MM-dd HH:mm:ss");
106
        try{
107
          dateParsee = formatDateObs.parse(date);
108
        } catch (IllegalArgumentException e) {
109
        	dateParsee = new java.sql.Date(0);
110
		}
111
        return dateParsee;
112
	}
113
 
114
	private List<String> parserMotsCles(String motsClesTexte) {
115
		String[] tabMotsCle = motsClesTexte.split(",");
116
		List<String> motsClesParses = new ArrayList<String>();
117
		for (int i = 0; i < tabMotsCle.length; i++) {
118
			motsClesParses.add(tabMotsCle[i]);
119
		}
120
 
121
		return motsClesParses;
122
	}
123
 
124
 
359 benjamin 125
}