Subversion Repositories eFlore/Applications.cel

Rev

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

Rev Author Line No. Line
2 aperonnet 1
package org.tela_botanica.client.image;
2
 
3
import java.util.HashMap;
4
import java.util.Iterator;
5 aperonnet 5
import java.util.Vector;
2 aperonnet 6
 
7
import org.tela_botanica.client.interfaces.Rafraichissable;
8
import org.tela_botanica.client.modeles.Configuration;
9
import org.tela_botanica.client.modeles.ImageAsynchroneDAO;
10
import org.tela_botanica.client.modeles.ImageCarnet;
11
import org.tela_botanica.client.modeles.ImageUploaderAsynchroneDAO;
5 aperonnet 12
import org.tela_botanica.client.modeles.LienImageAsynchroneDAO;
2 aperonnet 13
import org.tela_botanica.client.modeles.ListeImageAsynchroneDAO;
14
import org.tela_botanica.client.modeles.ListeImageCarnet;
99 jpm 15
import org.tela_botanica.client.modeles.ListeObservation;
413 aurelien 16
import org.tela_botanica.client.modeles.ListeObservationAsynchroneDAO;
2 aperonnet 17
import org.tela_botanica.client.modeles.MotsClesAsynchroneDAO;
18
import org.tela_botanica.client.modeles.NombreImageAsynchroneDAO;
413 aurelien 19
import org.tela_botanica.client.modeles.NombreObservationAsynchroneDAO;
2 aperonnet 20
 
21
import com.google.gwt.json.client.JSONArray;
22
import com.google.gwt.json.client.JSONObject;
400 aurelien 23
import com.google.gwt.user.client.Window;
2 aperonnet 24
import com.gwtext.client.data.ArrayReader;
25
import com.gwtext.client.data.FieldDef;
26
import com.gwtext.client.data.IntegerFieldDef;
27
import com.gwtext.client.data.MemoryProxy;
28
import com.gwtext.client.data.Node;
29
import com.gwtext.client.data.RecordDef;
30
import com.gwtext.client.data.Store;
31
import com.gwtext.client.data.StringFieldDef;
32
import com.gwtext.client.data.Tree;
33
import com.gwtext.client.widgets.tree.TreeNode;
34
 
35
/**
5 aperonnet 36
 * Modèle d'accès aux données pour les images. C'est un singleton
37
 *
2 aperonnet 38
 * @author aurelien
5 aperonnet 39
 *
2 aperonnet 40
 */
41
public class ImageModele implements Rafraichissable {
5 aperonnet 42
 
2 aperonnet 43
	/**
5 aperonnet 44
	 * Booleen indiquant si le médiateur est instancié (l'instance doit être
45
	 * unique donc le booleen est static)
2 aperonnet 46
	 */
5 aperonnet 47
	private static boolean estInstancie = false;
48
 
2 aperonnet 49
	/**
50
	 * le modèle lui même
51
	 */
5 aperonnet 52
	private static ImageModele thisModele = null;
53
 
2 aperonnet 54
	/**
55
	 * Le médiateur associé au modèle
56
	 */
5 aperonnet 57
	private ImageMediateur iMediateur = null;
58
 
2 aperonnet 59
	/**
60
	 * La configuration en cours
61
	 */
5 aperonnet 62
	private Configuration config = null;
63
 
2 aperonnet 64
	/**
65
	 * La liste des image affichées en cours
66
	 */
5 aperonnet 67
	private ListeImageCarnet cacheImage = new ListeImageCarnet(0);
2 aperonnet 68
	/**
69
	 * Table de correspondance entre les mots clés et leurs identifiants
70
	 */
5 aperonnet 71
	private HashMap<String, String> motsCles = new HashMap<String, String>(0);
2 aperonnet 72
	/**
5 aperonnet 73
	 * Le store contenant les données à afficher, que le modèle transmet au
74
	 * médiateur quand il le demande
2 aperonnet 75
	 */
5 aperonnet 76
	private Store st = null;
2 aperonnet 77
	/**
78
	 * Arbre des mots clés
79
	 */
5 aperonnet 80
	private com.gwtext.client.data.Tree arbreMotsCles = new Tree();
81
 
2 aperonnet 82
	/**
83
	 * Numéro de page en cours
84
	 */
5 aperonnet 85
	private int pageEncours = 0;
2 aperonnet 86
	/**
87
	 * Nombre de pages totales
88
	 */
5 aperonnet 89
	private int pageMax = 1;
2 aperonnet 90
	/**
91
	 * Taille de page (par défaut 50)
92
	 */
5 aperonnet 93
	private int taillePage = 50;
2 aperonnet 94
	/**
95
	 * Nombre d'éléments total correspondant à la requete
96
	 */
5 aperonnet 97
	private int nbElements = 0;
98
 
2 aperonnet 99
	/**
5 aperonnet 100
	 * "Presse papier" pour les images qui permet de garder en mémoire une
101
	 * sélection
102
	 */
103
	private Vector<String> selectionImages = new Vector<String>(0);
104
 
105
	/**
2 aperonnet 106
	 * Retourne une instance de manière unique
5 aperonnet 107
	 *
108
	 * @param im
109
	 *            le médiateur à associer
2 aperonnet 110
	 * @return l'instance du modèle
111
	 */
5 aperonnet 112
	static ImageModele Instance(ImageMediateur im) {
2 aperonnet 113
		// si le modèle n'est pas encore instancié
5 aperonnet 114
		if (!estInstancie) {
2 aperonnet 115
			// on en crée un nouveau
5 aperonnet 116
			estInstancie = true;
2 aperonnet 117
			thisModele = new ImageModele(im);
118
		}
5 aperonnet 119
 
2 aperonnet 120
		// sinon on retourne le "pointeur" vers le modèle lui-même
5 aperonnet 121
		return thisModele;
2 aperonnet 122
 
123
	}
5 aperonnet 124
 
2 aperonnet 125
	/**
126
	 * Le constructeur est privé et seule la méthode instance y accède
5 aperonnet 127
	 *
128
	 * @param im
129
	 *            le médiateur à associer
2 aperonnet 130
	 */
131
	private ImageModele(ImageMediateur im) {
5 aperonnet 132
 
133
		iMediateur = im;
134
		config = new Configuration();
2 aperonnet 135
	}
5 aperonnet 136
 
2 aperonnet 137
	/**
138
	 * Accesseur pour le médiateur
5 aperonnet 139
	 *
2 aperonnet 140
	 * @return le médiateur associé
141
	 */
5 aperonnet 142
	public ImageMediateur getIMediateur() {
143
		return iMediateur;
2 aperonnet 144
	}
5 aperonnet 145
 
2 aperonnet 146
	/**
147
	 * Appelle le DAO asynchrone pour obtenir la liste des images
5 aperonnet 148
	 *
149
	 * @param r
150
	 *            le rafraichissable auxquel on enverra les données
2 aperonnet 151
	 */
5 aperonnet 152
	public void obtenirNombrePhotoGalerie(Rafraichissable r) {
153
 
154
		String valeursFiltres[][] = getIMediateur().renvoyerFiltres();
155
 
156
		int tailleFiltres = valeursFiltres.length;
157
 
158
		String[][] criteres = new String[tailleFiltres + 1][2];
159
 
160
		String[] utilisateur = { "ci_ce_utilisateur",
161
				"" + getIMediateur().getIdentifiant() };
162
		criteres[0] = utilisateur;
163
 
164
 
165
		for (int i = 0; i < valeursFiltres.length; i++) {
166
 
167
			criteres[i + 1] = valeursFiltres[i];
168
		}
169
 
170
		// on les crée un DAO auquel on les transmet et qui demande le nombre
171
		// d'images correspondantes (pour les pages)
172
		NombreImageAsynchroneDAO niaDAO = new NombreImageAsynchroneDAO(this);
173
		niaDAO.obtenirNombreImages(this, criteres);
174
	}
175
 
2 aperonnet 176
	public void obtenirPhotoGalerie(Rafraichissable r)
177
	{
5 aperonnet 178
		String valeursFiltres[][] = getIMediateur().renvoyerFiltres();
2 aperonnet 179
 
5 aperonnet 180
		int tailleFiltres = valeursFiltres.length;
2 aperonnet 181
 
5 aperonnet 182
		String[][] criteres2 = new String[tailleFiltres + 2][2];
2 aperonnet 183
 
5 aperonnet 184
		String[] limite = { "ci_limite", "" + taillePage };
185
		String[] taillePage = { "ci_numero_page", "" + pageEncours };
2 aperonnet 186
 
5 aperonnet 187
		criteres2[0] = limite;
188
		criteres2[1] = taillePage;
189
 
190
		for (int i = 0; i < valeursFiltres.length; i++) {
191
			criteres2[i + 2] = valeursFiltres[i];
2 aperonnet 192
		}
193
 
5 aperonnet 194
		// et on crée un DAO auquel on les transmet et qui envoie une requete
195
		// pour recevoir les images
2 aperonnet 196
		ListeImageAsynchroneDAO liaDAO = new ListeImageAsynchroneDAO(this);
5 aperonnet 197
		liaDAO.ObtenirListeImages(this, criteres2);
2 aperonnet 198
	}
5 aperonnet 199
 
2 aperonnet 200
	/**
5 aperonnet 201
	 * Appelle le DAO d'upload qui va choisir la methode d'upload adaptée et
202
	 * lancer l'interface appropriée
2 aperonnet 203
	 */
204
	@SuppressWarnings("static-access")
142 aurelien 205
	public void uploaderImages(boolean multiple) {
5 aperonnet 206
		ImageUploaderAsynchroneDAO IuADaO = new ImageUploaderAsynchroneDAO(this);
142 aurelien 207
		if(multiple) {
208
			IuADaO.appelerUploadMultiple();
209
		}
210
		else
211
		{
212
			IuADaO.appelerUploadSimple();
213
		}
2 aperonnet 214
	}
5 aperonnet 215
 
2 aperonnet 216
	/**
217
	 * Met à jour la liste des images à partir d'un objet
5 aperonnet 218
	 *
219
	 * @param o
220
	 *            la nouvelle liste d'image
2 aperonnet 221
	 */
5 aperonnet 222
	public void rafraichirListeImage(Object o) {
223
		cacheImage = (ListeImageCarnet) o;
2 aperonnet 224
	}
5 aperonnet 225
 
2 aperonnet 226
	/**
227
	 * Met à jour l'arbre des mots clés à partir d'un objet
5 aperonnet 228
	 *
229
	 * @param o
230
	 *            le nouvel arbre de mots clés
2 aperonnet 231
	 */
5 aperonnet 232
	public void rafraichirArbreMotsCles(Object o) {
233
		arbreMotsCles = (com.gwtext.client.data.Tree) o;
2 aperonnet 234
	}
5 aperonnet 235
 
2 aperonnet 236
	/**
5 aperonnet 237
	 * Met à jour la table de correspondance mots clés / ids à partir d'un objet
238
	 *
239
	 * @param o
240
	 *            la nouvelle table des mots clés
2 aperonnet 241
	 */
242
	@SuppressWarnings("unchecked")
5 aperonnet 243
	public void rafraichirMotsCles(Object o) {
244
		if (o instanceof HashMap) {
245
			motsCles = (HashMap<String, String>) o;
2 aperonnet 246
		}
247
	}
5 aperonnet 248
 
2 aperonnet 249
	/**
5 aperonnet 250
	 * Va chercher les métadonnées associées à une image dans la liste des
251
	 * images chargée dans le modèle
252
	 *
253
	 * @param r
254
	 *            le rafraichissable auquel on enverra les informations
255
	 * @param id
256
	 *            l'identifiant de l'image
2 aperonnet 257
	 */
5 aperonnet 258
	public void obtenirMetadonnees(Rafraichissable r, String id) {
259
		ImageCarnet im = (ImageCarnet) cacheImage.get(id);
260
 
261
		Object meta[] = new Object[3];
262
		meta[0] = im.getMetadonnesExif();
263
		meta[1] = im.getMetadonnesIptc();
264
		meta[2] = im.getInfoGenerales();
265
 
266
		r.rafraichir(meta, false);
2 aperonnet 267
	}
5 aperonnet 268
 
2 aperonnet 269
	/**
5 aperonnet 270
	 * Va chercher les mots clés associés à une image dans la liste des images
271
	 * chargée dans le modèle
272
	 *
273
	 * @param r
274
	 *            le rafraichissable auquel on enverra les informations
275
	 * @param id
276
	 *            l'identifiant de l'image
2 aperonnet 277
	 */
5 aperonnet 278
	public void obtenirMotsClesId(Rafraichissable r, String id) {
279
		ImageCarnet im = cacheImage.get(id);
280
		String motsClesId = im.getMotsCles();
281
		String[] motsClesIdTab = motsClesId.split(",");
282
 
283
		r.rafraichir(motsClesIdTab, false);
2 aperonnet 284
	}
5 aperonnet 285
 
2 aperonnet 286
	/**
5 aperonnet 287
	 * Met à jour la liste des images en local et appelle le DAO de mise à jour
288
	 * pour les commentaires et la date des images selectionnées
289
	 *
290
	 * @param commentaires
291
	 *            le commentaire à appliquer
292
	 * @param date
293
	 *            la date à appliquer
294
	 * @param ids
295
	 *            les identifiants des images selectionnées
2 aperonnet 296
	 */
5 aperonnet 297
	public void mettreAJourCacheImage(String commentaires, String date,
298
			String note, String ids[]) {
299
		for (int i = 0; i < ids.length; i++) {
300
			String key = ids[i];
301
			ImageCarnet ic = cacheImage.get(key);
302
			ic.miseAJourInfoGenerales(commentaires, date, note);
303
			mettreAjourBaseDeDonneesImageCarnet(ic);
304
		}
305
 
2 aperonnet 306
	}
5 aperonnet 307
 
2 aperonnet 308
	/**
309
	 * Ajoute un nouveau mot clés à la liste des mots clés locale
5 aperonnet 310
	 *
311
	 * @param text
312
	 *            le mot clé
313
	 * @param id
314
	 *            l'identifiant du mot clé
2 aperonnet 315
	 */
5 aperonnet 316
	public void mettreAjourMotsClesId(String text, String id) {
317
		motsCles.put(id, text);
2 aperonnet 318
	}
5 aperonnet 319
 
2 aperonnet 320
	/**
5 aperonnet 321
	 * Appelle le DAO chargé de mettre à jour la base de données avec les toutes
322
	 * les informations des images modifiées par l'utilisateur
2 aperonnet 323
	 */
5 aperonnet 324
	public void mettreAJourBaseDeDonneesListeImageCarnet() {
2 aperonnet 325
		ListeImageAsynchroneDAO liDaO = new ListeImageAsynchroneDAO(this);
5 aperonnet 326
 
2 aperonnet 327
		liDaO.SynchroniserBaseDeDonnees(cacheImage);
328
	}
5 aperonnet 329
 
2 aperonnet 330
	/**
5 aperonnet 331
	 * Appelle le DAO chargé de mettre à jour la base de données avec les toutes
332
	 * les informations d'une image donnée
333
	 *
334
	 * @param ic
335
	 *            l'image à synchroniser avec la base
2 aperonnet 336
	 */
5 aperonnet 337
	public void mettreAjourBaseDeDonneesImageCarnet(ImageCarnet ic) {
2 aperonnet 338
		ImageAsynchroneDAO iaDaO = new ImageAsynchroneDAO(this);
5 aperonnet 339
		iaDaO.SynchroniserBaseDeDonnees(ic);
2 aperonnet 340
	}
341
 
342
	/**
5 aperonnet 343
	 * Supprime les images données du cache local et appelle le DAO qui les
344
	 * supprime de la base de données
345
	 *
346
	 * @param ids
347
	 *            les identifiants des images selectionnées
2 aperonnet 348
	 */
5 aperonnet 349
	public void supprimerImages(String[] ids) {
350
		String rids[] = new String[ids.length];
351
		ListeImageAsynchroneDAO liDao = new ListeImageAsynchroneDAO(this);
352
 
353
		for (int i = 0; i < ids.length; i++) {
354
			String key = ids[i];
355
			ImageCarnet ic = cacheImage.get(key);
356
			rids[i] = ic.getId();
357
 
358
			cacheImage.remove(key);
2 aperonnet 359
		}
5 aperonnet 360
 
361
		if (rids.length != 0) {
2 aperonnet 362
			liDao.supprimerBaseDeDonnees(rids);
5 aperonnet 363
		}
2 aperonnet 364
	}
365
 
366
	/**
5 aperonnet 367
	 * Met à jour les données locales suivant le type des nouvelles données et
368
	 * appelle le médiateur pour le notifier de la mise à jour
2 aperonnet 369
	 */
5 aperonnet 370
	public void rafraichir(Object nouvelleDonnees,
371
			boolean repandreRafraichissement) {
2 aperonnet 372
		// si l'on a reçu une liste d'images
5 aperonnet 373
		if (nouvelleDonnees instanceof ListeImageCarnet) {
374
			ListeImageCarnet data = (ListeImageCarnet) nouvelleDonnees;
400 aurelien 375
			Object[][] photoData = new Object[data.size()][13];
5 aperonnet 376
			int i = 0;
2 aperonnet 377
 
5 aperonnet 378
			if (data.size() == 0) {
379
				pageEncours = 0;
380
			}
381
 
382
			// on la parse et on récupère les informations quiç nous interessent
383
			for (Iterator<String> it = data.keySet().iterator(); it.hasNext();) {
384
				ImageCarnet im = data.get(it.next());
385
				photoData[i][0] = im.getOrdre();
212 aurelien 386
				photoData[i][1] = im.getNomOriginal();
387
				photoData[i][2] = im.getDate();
388
				photoData[i][3] = im.getIptcCity();
389
				photoData[i][4] = im.getMake() + " " + im.getModel();
390
				photoData[i][5] = im.getSUrl();
391
				photoData[i][6] = im.getMUrl();
392
				photoData[i][7] = im.getLUrl();
393
				photoData[i][8] = im.getNote();
394
				photoData[i][9] = im.getId();
395
				photoData[i][10] = im.getTailleImage()[1];
396
				photoData[i][11] = im.getTailleImage()[0];
400 aurelien 397
				photoData[i][12] = im.getIdsObsAssociees();
5 aperonnet 398
 
399
				i++;
400
			}
401
 
402
			// creation du store qui les contient
403
			FieldDef defNumImage = new IntegerFieldDef("num_image");
212 aurelien 404
			FieldDef defNomImage = new StringFieldDef("nom_original");
5 aperonnet 405
			FieldDef defDatImage = new StringFieldDef("dat_image");
406
			FieldDef defLieImage = new StringFieldDef("lie_image");
407
			FieldDef defAppImage = new StringFieldDef("app_image");
408
			FieldDef defUrlImageS = new StringFieldDef("url_image_S");
409
			FieldDef defUrlImageM = new StringFieldDef("url_image_M");
410
			FieldDef defUrlImage = new StringFieldDef("url_image");
411
			FieldDef defNoteImage = new IntegerFieldDef("note_image");
412
			FieldDef defIdImage = new IntegerFieldDef("id_image");
140 aurelien 413
			FieldDef defTailleX = new IntegerFieldDef("taille_x");
414
			FieldDef defTailleY = new IntegerFieldDef("taille_y");
400 aurelien 415
			FieldDef defObsAssociees = new StringFieldDef("obs_associees");
212 aurelien 416
			FieldDef[] defTab = { defNumImage,defNomImage, defDatImage, defLieImage,
5 aperonnet 417
					defAppImage, defUrlImageS, defUrlImageM, defUrlImage,
400 aurelien 418
					defNoteImage, defIdImage, defTailleX, defTailleY, defObsAssociees };
5 aperonnet 419
			RecordDef rd = new RecordDef(defTab);
420
 
421
			final MemoryProxy dataProxy = new MemoryProxy(photoData);
422
			final ArrayReader reader = new ArrayReader(rd);
423
 
424
			final Store photoStore = new Store(dataProxy, reader);
425
 
426
			rafraichirListeImage(nouvelleDonnees);
427
 
428
			st = photoStore;
429
			st.load();
430
 
431
			// par défaut le store est trié sur le numéro d'image
432
			st.sort("num_image");
433
 
434
			// si on doit répandre les données, on notifie le médiateur qui les
435
			// distribuera à son tour
436
			if (repandreRafraichissement) {
437
				getIMediateur().synchroniserDonneesZoomListeGalerie(st, this);
438
			}
2 aperonnet 439
		}
5 aperonnet 440
 
2 aperonnet 441
		// si on reçoit un tableau JSON
5 aperonnet 442
		if (nouvelleDonnees instanceof JSONArray) {
2 aperonnet 443
			// alors on a reçu les informations sur les mots clés
5 aperonnet 444
			JSONArray reponse = (JSONArray) nouvelleDonnees;
445
 
2 aperonnet 446
			final int taillemax = reponse.size();
5 aperonnet 447
 
2 aperonnet 448
			// si le tableau est vide
5 aperonnet 449
			if (taillemax == 0) {
2 aperonnet 450
				// on crée un arbre vide
5 aperonnet 451
				TreeNode root = new TreeNode();
452
				root.setId("racine");
453
				root.setText("Tags");
454
				String[] usObj = { "Tags", "racine" };
455
				root.setUserObject(usObj);
456
				arbreMotsCles.setRootNode(root);
2 aperonnet 457
			}
5 aperonnet 458
 
2 aperonnet 459
			// pour chacun des élements du tableau
5 aperonnet 460
			for (int j = 0; j < taillemax; j++) {
2 aperonnet 461
				// on extrait les élements du tableau
5 aperonnet 462
				if (reponse.get(j).isObject() != null) {
463
					JSONObject noeud = (JSONObject) reponse.get(j);
464
 
465
					String id_noeud = noeud.get("cmc_id_mot_cle_utilisateur")
466
							.isString().stringValue();
467
					String mot_cle = noeud.get("cmc_mot_cle").isString()
468
							.stringValue();
469
					String parent = noeud.get("cmc_id_parent").isString()
470
							.stringValue();
471
 
472
					String[] usObj = { mot_cle, id_noeud };
473
 
474
					// et on construit l'arbre à partir de la racine (qui est
475
					// toujoursl e premier élément)
476
					if (id_noeud.equals("racine")) {
477
						TreeNode root = new TreeNode();
478
						root.setId(id_noeud);
479
						root.setText(mot_cle);
480
						root.setUserObject(usObj);
481
						arbreMotsCles.setRootNode(root);
482
					} else {
483
						// et en ajoutant les noeuds un à un (qui sont renvoyé
484
						// dans l'ordre hierarchique de leur niveau
2 aperonnet 485
						// ce qui permet de les traiter séquentiellement)
5 aperonnet 486
						TreeNode node = new TreeNode();
487
						node.setId(id_noeud);
488
						node.setText(mot_cle);
489
						node.setChecked(false);
490
						Node parentNode = arbreMotsCles.getNodeById(parent);
491
						node.setUserObject(usObj);
492
						parentNode.appendChild(node);
2 aperonnet 493
					}
494
				}
5 aperonnet 495
			}
496
			// enfin on met à jour l'arbre des mots clés contenu dans le modèle
497
			rafraichirArbreMotsCles(arbreMotsCles);
498
			// et on notifie le médiateur de la mise à jour en lui passant une
499
			// copie des données
500
			getIMediateur().rafraichirArbreMotsCles(arbreMotsCles);
2 aperonnet 501
		}
5 aperonnet 502
 
2 aperonnet 503
		// Si on reçoit un tableau d'entiers
5 aperonnet 504
		// c'est un tableau d'un seul entier qui est le nombre d'images
505
		// correspondant aux critères
506
		if (nouvelleDonnees instanceof int[]) {
507
			int[] pages = (int[]) nouvelleDonnees;
508
 
509
			// on calcule le nombre de pages nécessaires et on les met à jour
510
			// dans le modèle
511
			pageMax = calculerNbPages(pages[0]);
512
			nbElements = pages[0];
513
 
514
			// et on notifie de le mediateur du changement des valeurs
515
			getIMediateur().changerPageMaxEtCourante(pageMax, pageEncours,
516
					taillePage, pages[0]);
2 aperonnet 517
 
5 aperonnet 518
			obtenirPhotoGalerie(this) ;
2 aperonnet 519
		}
99 jpm 520
 
521
		if(nouvelleDonnees instanceof ListeObservation) {
522
 
158 aurelien 523
			getIMediateur().rafraichirMiniListeObservations((ListeObservation)nouvelleDonnees) ;
99 jpm 524
		}
158 aurelien 525
 
526
		if(nouvelleDonnees instanceof Tree) {
527
			rafraichirArbreMotsCles(nouvelleDonnees);
528
			getIMediateur().rafraichirArbreMotsCles((Tree)nouvelleDonnees);
529
		}
2 aperonnet 530
	}
5 aperonnet 531
 
2 aperonnet 532
	/**
533
	 * Affiche les paires / valeur de tous les mots clés stockés
534
	 */
5 aperonnet 535
	public void afficherMotsCles() {
536
		for (Iterator<String> it = motsCles.keySet().iterator(); it.hasNext();) {
537
			String key = it.next();
538
			String valeur = (String) motsCles.get(key);
539
			System.out.println("clé : " + key + " valeur : " + valeur);
2 aperonnet 540
		}
541
	}
542
 
543
	/**
5 aperonnet 544
	 * Met à jour les mots clés associés à une image et appelle le DAO pour
545
	 * synchroniser la base de données
546
	 *
547
	 * @param ids
548
	 *            les identifiants des images selectionnées
549
	 * @param motsClesEnCours
550
	 *            les mots clés à appliquer aux images
551
	 * @param arbreMC
552
	 *            l'arbre de mots clés en cours
2 aperonnet 553
	 */
5 aperonnet 554
	public void mettreAjourMotsCles(String[] ids, String motsClesEnCours,
555
			com.gwtext.client.data.Tree arbreMC) {
556
		for (int i = 0; i < ids.length; i++) {
557
			if (cacheImage.containsKey(ids[i])) {
558
				ImageCarnet ic = (ImageCarnet) cacheImage.get(ids[i]);
559
				ic.mettreAjourMotsCles(motsClesEnCours);
560
 
561
				ImageAsynchroneDAO imgDao = new ImageAsynchroneDAO(this);
562
				imgDao.SynchroniserMotsClesImageBaseDeDonnees(ic);
2 aperonnet 563
			}
564
		}
5 aperonnet 565
 
566
		rafraichirArbreMotsCles(arbreMC);
2 aperonnet 567
	}
5 aperonnet 568
 
2 aperonnet 569
	/**
5 aperonnet 570
	 * Appelle le DAO des mots clés pour obtenir l'arbre complet stocké dans la
571
	 * base de données
2 aperonnet 572
	 */
5 aperonnet 573
	public void initialiserArbreMotsCles() {
137 aurelien 574
 
575
			MotsClesAsynchroneDAO MCDao = new MotsClesAsynchroneDAO(this);
576
			MCDao.obtenirListeMotsCles(this);
2 aperonnet 577
	}
5 aperonnet 578
 
2 aperonnet 579
	/**
5 aperonnet 580
	 * Envoie l'arbre des mots clés stocké localement à l'élément rafrachissable
581
	 * donné, qui le demande
582
	 *
583
	 * @param r
584
	 *            le rafraichissable demandeur de l'arbre
2 aperonnet 585
	 */
5 aperonnet 586
	public void obtenirArbreMotCle(Rafraichissable r) {
137 aurelien 587
			r.rafraichir(arbreMotsCles, false);
2 aperonnet 588
	}
589
 
590
	/**
5 aperonnet 591
	 * Ajoute un mot clé à l'arbre des mots clés local et appelle le DAO qui
592
	 * fait la mise à jour de l'arbre des mots clés dans la base
593
	 *
594
	 * @param n
595
	 *            le nouveau noeud contenant le mot clé
596
	 * @param arbreMC
597
	 *            l'arbre des mots cles en cours
2 aperonnet 598
	 */
5 aperonnet 599
	public void ajouterMotCleDansArbre(TreeNode n,
600
			com.gwtext.client.data.Tree arbreMC) {
601
		MotsClesAsynchroneDAO MCDao = new MotsClesAsynchroneDAO(this);
602
 
603
		String[] usObj = (String[]) n.getUserObject();
604
		String motCle = usObj[0];
605
		String id = usObj[1];
606
		String parentId = "";
607
 
608
		if (!id.equals("racine")) {
609
			String[] parentUsObj = (String[]) n.getParentNode().getUserObject();
610
			parentId = parentUsObj[1];
611
		} else {
612
			parentId = "racine";
2 aperonnet 613
		}
5 aperonnet 614
 
615
		rafraichirArbreMotsCles(arbreMC);
616
 
617
		String nouveauMotCle = "&identifiant=" + getIdentifiant() + "&motcle="
618
				+ motCle + "&id=" + id + "&parent=" + parentId;
619
		MCDao.ajouterBaseDeDonnees(nouveauMotCle);
2 aperonnet 620
	}
621
 
622
	/**
5 aperonnet 623
	 * Supprime un noeud de l'arbre des mots clés et appelle le DAO qui va
624
	 * supprimer les mots clés associés dans la base
625
	 *
626
	 * @param n
627
	 *            le noeud à supprimer
628
	 * @param arbreMC
629
	 *            l'arbre des mots clés en cours
2 aperonnet 630
	 */
5 aperonnet 631
	public void supprimerMotCleDansArbre(TreeNode n, Tree arbreMC) {
632
 
633
		MotsClesAsynchroneDAO MCDao = new MotsClesAsynchroneDAO(this);
634
 
635
		String[] usObj = (String[]) n.getUserObject();
636
		String id = usObj[1];
637
 
638
		MCDao.supprimerBaseDeDonnees(id);
639
 
2 aperonnet 640
	}
641
 
642
	/**
5 aperonnet 643
	 * Modifie le noeud donné dans l'arbre des mots clés en cours et appelle le
644
	 * DAO qui synchronise la modification dans la base de données
645
	 *
646
	 * @param n
647
	 *            le noeud modifié
648
	 * @param arbreMC
649
	 *            l'arbre des mots clés en cours
2 aperonnet 650
	 */
5 aperonnet 651
	public void modifierMotCleDansArbre(TreeNode n, Tree arbreMC) {
652
 
653
		MotsClesAsynchroneDAO MCDao = new MotsClesAsynchroneDAO(this);
654
 
655
		String[] usObj = (String[]) n.getUserObject();
656
		String motCle = usObj[0];
657
		String id = usObj[1];
658
		String parentId = "";
659
 
660
		if (!id.equals("racine")) {
661
			String[] parentUsObj = (String[]) n.getParentNode().getUserObject();
662
			parentId = parentUsObj[1];
663
		} else {
664
			parentId = "racine";
2 aperonnet 665
		}
5 aperonnet 666
 
667
		rafraichirArbreMotsCles(arbreMC);
668
 
669
		String motCleModifie = "&motcle=" + motCle + "&id=" + id + "&parent="
670
				+ parentId;
671
		MCDao.modifierBaseDeDonnees(motCleModifie);
672
 
2 aperonnet 673
	}
5 aperonnet 674
 
2 aperonnet 675
	/**
5 aperonnet 676
	 * Deplace un noeud dans l'arbre des mots cles et appelle le DAO qui
677
	 * reorganise l'arbre dans la base de donnees suivant le changement
678
	 *
679
	 * @param n
680
	 *            le noeud deplace (et son sous arbre associe)
681
	 * @param arbreMC
682
	 *            l'arbre des mots cles en cours
2 aperonnet 683
	 */
5 aperonnet 684
	public void deplacerMotCleDansArbre(TreeNode n, Tree arbreMC) {
685
		MotsClesAsynchroneDAO MCDao = new MotsClesAsynchroneDAO(this);
686
 
687
		String[] usObj = (String[]) n.getUserObject();
688
		String motCle = usObj[0];
689
		String id = usObj[1];
690
		String parentId = "";
691
		if (!id.equals("racine")) {
692
			String[] parentUsObj = (String[]) n.getParentNode().getUserObject();
693
			parentId = parentUsObj[1];
694
		} else {
695
			parentId = "racine";
2 aperonnet 696
		}
5 aperonnet 697
 
698
		rafraichirArbreMotsCles(arbreMC);
699
 
700
		String motCleModifie = "&motcle=" + motCle + "&id=" + id + "&parent="
701
				+ parentId;
702
		MCDao.deplacerBaseDeDonnees(motCleModifie);
2 aperonnet 703
	}
5 aperonnet 704
 
2 aperonnet 705
	/**
5 aperonnet 706
	 * Change le numéro de la page en cours et envoie une demande de mise à jour
707
	 * des données
708
	 *
709
	 * @param nouvellePageCourante
710
	 *            la nouvelle page à afficher
2 aperonnet 711
	 */
5 aperonnet 712
	public void changerNumeroPage(int nouvellePageCourante) {
713
		pageEncours = nouvellePageCourante;
714
		obtenirNombrePhotoGalerie(this);
2 aperonnet 715
	}
5 aperonnet 716
 
2 aperonnet 717
	/**
5 aperonnet 718
	 * Calcule le nombre de pages nécessaires pour afficher un nombre d'élements
719
	 * donnés en fonction de la taille de page en cours
720
	 *
721
	 * @param nbElements
722
	 *            le nombre d'élements total
723
	 * @return le nombre de pages
2 aperonnet 724
	 */
5 aperonnet 725
	public int calculerNbPages(int nbElements) {
726
		// A cause de la betise de java pour les conversion implicite on fait
727
		// quelques conversions manuellement
2 aperonnet 728
		// pour eviter qu'il arrondisse mal la division
5 aperonnet 729
		// nombre de pages = (nombre d'element / taille de la page) arrondie à
730
		// l'entier superieur
731
		double nPage = (1.0 * nbElements) / (1.0 * taillePage);
732
		double nPageRound = Math.ceil(nPage);
733
		Double nPageInt = new Double(nPageRound);
734
 
2 aperonnet 735
		// on convertit en entier
5 aperonnet 736
		return nPageInt.intValue();
2 aperonnet 737
	}
5 aperonnet 738
 
2 aperonnet 739
	/**
740
	 * Recalcule la page en cours lors du changement du nombre d'élements
5 aperonnet 741
	 *
742
	 * @param nbElements
743
	 *            le nombre d'élements total
2 aperonnet 744
	 * @return la nouvelle page encours
745
	 */
5 aperonnet 746
	public int calculerPageCourante(int nbElements) {
2 aperonnet 747
		// on calcule le nombre de page
5 aperonnet 748
		int nouvelNbPages = calculerNbPages(nbElements);
2 aperonnet 749
		// la nouvelle page en cours
5 aperonnet 750
		double nPageCourante = (1.0 * pageEncours) / (1.0 * pageMax)
751
				* (1.0 * nouvelNbPages);
752
 
2 aperonnet 753
		// on arrondit au supérieur
5 aperonnet 754
		double nPageRound = Math.ceil(nPageCourante);
755
		Double nPageInt = new Double(nPageRound);
756
 
2 aperonnet 757
		// on convertit en entier
5 aperonnet 758
		return Math.abs(nPageInt.intValue());
2 aperonnet 759
	}
5 aperonnet 760
 
2 aperonnet 761
	/**
5 aperonnet 762
	 * Change la taille de page et recalcule la page encours
763
	 *
764
	 * @param nouvelleTaillePage
765
	 *            la nouvelle taille de page à utiliser
2 aperonnet 766
	 */
5 aperonnet 767
	public void changerTaillePage(int nouvelleTaillePage) {
768
		taillePage = nouvelleTaillePage;
769
		pageEncours = calculerPageCourante(nbElements);
770
		obtenirNombrePhotoGalerie(this);
2 aperonnet 771
	}
5 aperonnet 772
 
2 aperonnet 773
	/**
5 aperonnet 774
	 * Notifie le mediateur que l'upload ou le download est termine et qu'il
775
	 * faut rafraichir les vues avec les nouvelles données
2 aperonnet 776
	 */
5 aperonnet 777
	public void requeteTerminee() {
778
		getIMediateur().demasquerChargement();
779
		getIMediateur().rafraichirToutesVues();
2 aperonnet 780
	}
781
 
782
	/**
783
	 * Obtient l'identifiant de l'utilisateur auprès du médiateur
5 aperonnet 784
	 *
2 aperonnet 785
	 * @return id de l'utilisateur
786
	 */
787
	public String getIdentifiant() {
5 aperonnet 788
 
789
		return getIMediateur().getIdentifiant();
2 aperonnet 790
	}
791
 
792
	/**
793
	 * renvoie la taille d'une image grâce à son identifiant
5 aperonnet 794
	 *
795
	 * @param id
796
	 *            l'identifiant de l'image
2 aperonnet 797
	 * @return un tableau contenant la longueur et la hauteur de l'image
798
	 */
799
	public String[] obtenirTailleImage(String id) {
5 aperonnet 800
 
801
		return (cacheImage.get(id)).getTailleImage();
802
 
2 aperonnet 803
	}
804
 
805
	/**
5 aperonnet 806
	 * Suivant l'id d'une image donnée, fais une demande au modèle pour qu'il
2 aperonnet 807
	 * renvoie la note associée au rafrachissable qui la demande
5 aperonnet 808
	 *
809
	 * @param r
810
	 *            le rafraichissable demandeur de l'information
811
	 * @param id
812
	 *            l'identifiant del'image
2 aperonnet 813
	 */
814
	public void obtenirNote(Rafraichissable r, String id) {
5 aperonnet 815
 
816
		r.rafraichir((cacheImage.get(id)).getNote(), true);
817
 
2 aperonnet 818
	}
5 aperonnet 819
 
2 aperonnet 820
	/**
821
	 * Accesseur pour la configuration en cours d'utilisation
5 aperonnet 822
	 *
2 aperonnet 823
	 * @return la configuration
824
	 */
825
	public Configuration getConfig() {
5 aperonnet 826
 
827
		return config;
828
	}
829
 
830
	/**
831
	 * Ajoute des images à la selection en cours
832
	 *
833
	 * @param ids
834
	 *            les identifiants des images à ajouter
835
	 */
836
	public void ajouterImagesSelection(String[] ids) {
837
 
838
		for (int i = 0; i < ids.length; i++) {
142 aurelien 839
 
840
			String idImg = cacheImage.get(ids[i]).getId();
841
			selectionImages.add(idImg);
5 aperonnet 842
		}
843
	}
844
 
173 aurelien 845
	public int getCompteSelection() {
846
		return selectionImages.size();
847
	}
848
 
5 aperonnet 849
	/**
850
	 * Vide la selection en cours
851
	 */
852
	public void viderSelection() {
853
		selectionImages.clear();
854
	}
855
 
856
	public String renvoyerSelection() {
857
 
858
		String selection = "";
2 aperonnet 859
 
5 aperonnet 860
		if(selectionImages.size() <= 0)
861
		{
862
			selection += "-255" ;
863
		}
864
		else
865
		{
866
			for (Iterator<String> it = selectionImages.iterator(); it.hasNext();) {
867
 
868
				String idEncours = it.next();
869
				selection += idEncours + ",";
870
			}
871
		}
872
 
873
		return selection;
2 aperonnet 874
	}
5 aperonnet 875
 
876
	public void lierImagesObervations(String idsObs, String idsImg) {
877
 
878
		LienImageAsynchroneDAO lienDAO = new LienImageAsynchroneDAO(this) ;
879
		lienDAO.lierImageBaseDeDonnees(idsImg, idsObs) ;
880
 
881
	}
882
 
81 jpm 883
	public void obtenirLiaisonObservations(ImageMediateur imageMediateur,
884
			String id) {
885
 
886
		String imgId = cacheImage.get(id).getId() ;
887
 
888
		LienImageAsynchroneDAO lienDao = new LienImageAsynchroneDAO(this) ;
889
		lienDao.obtenirLiaisonsImagesObservations(this, imgId) ;
890
 
891
	}
892
 
104 jpm 893
	public void supprimerLiaisonImages(String idImg, String idObs) {
894
 
895
		idImg = cacheImage.get(idImg).getId() ;
896
 
897
		LienImageAsynchroneDAO lienDAO = new LienImageAsynchroneDAO(this) ;
898
		lienDAO.supprimerLienImageObservation(idImg, idObs) ;
899
	}
900
 
413 aurelien 901
	public void obtenirMiniListeObservations(Rafraichissable r, String[] critere, int taillePage, int numeroPage) {
902
 
903
		String[][] criteres = {{critere[0],critere[1]},{"limite",""+taillePage},{"numero_page",""+numeroPage}} ;
904
 
905
		// et on crée un DAO auquel on les transmet et qui envoie une requete pour recevoir les images
906
		ListeObservationAsynchroneDAO loaDAO = new ListeObservationAsynchroneDAO(this);
907
		loaDAO.obtenirListeObservation(r, iMediateur.getIdentifiant(), criteres);
908
 
909
	}
910
 
911
	public void obtenirNombreMiniListeObservations(Rafraichissable r, String[] critere) {
912
 
913
		String[][] criteres = {{critere[0],critere[1]}} ;
914
 
915
		// et on crée un DAO auquel on les transmet et qui envoie une requete pour recevoir les images
916
		NombreObservationAsynchroneDAO noaDAO = new NombreObservationAsynchroneDAO(this);
917
		noaDAO.obtenirNombreObservation(r, iMediateur.getIdentifiant(), criteres);
918
 
919
	}
920
 
2 aperonnet 921
}