Subversion Repositories eFlore/Applications.cel

Rev

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