Subversion Repositories eFlore/Archives.cel-v2

Rev

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

Rev Author Line No. Line
7 aperonnet 1
package org.tela_botanica.client.image;
2
 
25 aperonnet 3
import java.util.HashMap;
16 aperonnet 4
import java.util.Iterator;
31 aperonnet 5
import java.util.Vector;
16 aperonnet 6
 
7 aperonnet 7
import org.tela_botanica.client.interfaces.Rafraichissable;
19 aperonnet 8
import org.tela_botanica.client.modeles.ImageAsynchroneDAO;
16 aperonnet 9
import org.tela_botanica.client.modeles.ImageCarnet;
12 aperonnet 10
import org.tela_botanica.client.modeles.ImageUploaderAsynchroneDAO;
19 aperonnet 11
import org.tela_botanica.client.modeles.ListeImageCarnet;
7 aperonnet 12
import org.tela_botanica.client.modeles.ListeImageAsynchroneDAO;
28 aperonnet 13
import org.tela_botanica.client.modeles.MotsClesAsynchroneDAO;
31 aperonnet 14
import org.tela_botanica.client.modeles.NombreImageAsynchroneDAO;
7 aperonnet 15
 
30 aperonnet 16
import com.google.gwt.json.client.JSONArray;
17
import com.google.gwt.json.client.JSONObject;
31 aperonnet 18
import com.gwtext.client.core.Ext;
19
import com.gwtext.client.core.ExtElement;
20 aperonnet 20
import com.gwtext.client.data.ArrayReader;
21
import com.gwtext.client.data.FieldDef;
22
import com.gwtext.client.data.IntegerFieldDef;
23
import com.gwtext.client.data.MemoryProxy;
25 aperonnet 24
import com.gwtext.client.data.Node;
28 aperonnet 25
import com.gwtext.client.data.NodeTraversalCallback;
20 aperonnet 26
import com.gwtext.client.data.RecordDef;
27
import com.gwtext.client.data.Store;
28
import com.gwtext.client.data.StringFieldDef;
28 aperonnet 29
import com.gwtext.client.data.Tree;
25 aperonnet 30
import com.gwtext.client.widgets.tree.TreeNode;
20 aperonnet 31
 
12 aperonnet 32
/**
33
 * Modèle d'accès aux données pour les images.
34
 * C'est un singleton
35
 * @author aurelien
36
 *
37
 */
20 aperonnet 38
public class ImageModele implements Rafraichissable {
7 aperonnet 39
 
31 aperonnet 40
	/**
41
	 * Booleen indiquant si le médiateur est instancié (l'instance doit être unique donc le booleen est static)
42
	 */
12 aperonnet 43
	private static boolean estInstancie = false ;
31 aperonnet 44
	/**
45
	 * Le médiateur associé au modèle
46
	 */
7 aperonnet 47
	private ImageMediateur iMediateur = null ;
31 aperonnet 48
	/**
49
	 * La liste des image affichées en cours
50
	 */
19 aperonnet 51
	private ListeImageCarnet cacheImage = new ListeImageCarnet(0) ;
31 aperonnet 52
	/**
53
	 * Table de correspondance entre les mots clés et leurs identifiants
54
	 */
28 aperonnet 55
	private HashMap motsCles = new HashMap(0) ;
31 aperonnet 56
	/**
57
	 * Le store contenant les données à afficher, que le modèle transmet au médiateur quand il le demande
58
	 */
20 aperonnet 59
	private Store st = null ;
31 aperonnet 60
	/**
61
	 * Arbre des mots clés
62
	 */
30 aperonnet 63
	private com.gwtext.client.data.Tree arbreMotsCles =  new Tree() ;
25 aperonnet 64
 
31 aperonnet 65
	/**
66
	 * Numéro de page en cours
67
	 */
68
	private int pageEncours = 0 ;
69
	/**
70
	 * Nombre de pages totales
71
	 */
72
	private int pageMax = 1 ;
73
	/**
74
	 * Taille de page (par défaut 50)
75
	 */
76
	private int taillePage = 50 ;
77
	/**
78
	 * Nombre d'éléments total correspondant à la requete
79
	 */
80
	private int nbElements = 0 ;
81
 
82
	/**
83
	 * Retourne une instance de manière unique
84
	 * @param im le médiateur à associer
85
	 * @return l'instance du modèle
86
	 */
12 aperonnet 87
	static ImageModele Instance(ImageMediateur im)
88
	{
31 aperonnet 89
		// si le modèle n'est pas encore instancié
12 aperonnet 90
		if(!estInstancie)
91
		{
31 aperonnet 92
			// on en crée un nouveau
12 aperonnet 93
			return new ImageModele(im);
94
		}
95
		else
96
		{
31 aperonnet 97
			// sinon on renvoit null, interdisant explicitement la création d'un autre exemplaire
12 aperonnet 98
			return null ;
99
		}
100
	}
101
 
31 aperonnet 102
	/**
103
	 * Le constructeur est privé et seule la méthode instance y accède
35 aperonnet 104
	 * @param im le médiateur à associer
31 aperonnet 105
	 */
12 aperonnet 106
	private ImageModele(ImageMediateur im) {
7 aperonnet 107
 
108
		iMediateur = im ;
109
	}
110
 
31 aperonnet 111
	/**
112
	 * Accesseur pour le médiateur
35 aperonnet 113
	 * @return le médiateur associé
31 aperonnet 114
	 */
18 aperonnet 115
	public ImageMediateur getIMediateur()
116
	{
117
		return iMediateur ;
118
	}
119
 
30 aperonnet 120
	/**
121
	 * Appelle le DAO asynchrone pour obtenir la liste des images
122
	 * @param r le rafraichissable auxquel on enverra les données
123
	 */
7 aperonnet 124
	public void obtenirPhotoGalerie(Rafraichissable r)
125
	{
31 aperonnet 126
		// on rassemble les critères
127
		String[][] criteres = {{"ci_ce_utilisateur", ""+getIMediateur().getIdentifiant()} } ;
128
		// on les crée un DAO auquel on les transmet et qui demande le nombre d'images correspondantes (pour les pages)
129
		NombreImageAsynchroneDAO niaDAO = new NombreImageAsynchroneDAO() ;
35 aperonnet 130
		niaDAO.setIModele(this) ;
31 aperonnet 131
		niaDAO.obtenirNombreImages(this, criteres) ;
132
 
133
		// ensuite on demande la page correspondante avec les mêmes critères
134
		String[][] criteres2 = { {"ci_limite" ,""+taillePage },{"ci_numero_page",""+pageEncours} } ;
135
		// et on crée un DAO auquel on les transmet et qui envoie une requete pour recevoir les images
7 aperonnet 136
		ListeImageAsynchroneDAO liaDAO = new ListeImageAsynchroneDAO();
31 aperonnet 137
		liaDAO.ObtenirListeImages(this, criteres2);
7 aperonnet 138
	}
12 aperonnet 139
 
30 aperonnet 140
	/**
141
	 * Appelle le DAO d'upload qui va choisir la methode d'upload adaptée
142
	 * et lancer l'interface appropriée
143
	 */
12 aperonnet 144
	public void uploaderImages()
145
	{
18 aperonnet 146
		ImageUploaderAsynchroneDAO IuADaO = new ImageUploaderAsynchroneDAO() ;
35 aperonnet 147
		IuADaO.setIModele(this) ;
18 aperonnet 148
		IuADaO.choisirMethodeUpload() ;
12 aperonnet 149
	}
16 aperonnet 150
 
30 aperonnet 151
	/**
152
	 * Met à jour la liste des images à partir d'un objet
153
	 * @param o la nouvelle liste d'image
154
	 */
16 aperonnet 155
	public void rafraichirListeImage(Object o)
156
	{
19 aperonnet 157
		cacheImage = (ListeImageCarnet)o ;
16 aperonnet 158
	}
159
 
30 aperonnet 160
	/**
161
	 * Met à jour l'arbre des mots clés à partir d'un objet
162
	 * @param o le nouvel arbre de mots clés
163
	 */
25 aperonnet 164
	public void rafraichirArbreMotsCles(Object o)
165
	{
28 aperonnet 166
		arbreMotsCles = (com.gwtext.client.data.Tree)o ;
25 aperonnet 167
	}
168
 
30 aperonnet 169
	/**
170
	 * Met à jour la table de correspondance mots clés / ids
171
	 * à partir d'un objet
172
	 * @param o la nouvelle table des mots clés
173
	 */
25 aperonnet 174
	public void rafraichirMotsCles(Object o)
175
	{
28 aperonnet 176
		motsCles = (HashMap)o ;
25 aperonnet 177
	}
178
 
30 aperonnet 179
	/**
180
	 * Va chercher les métadonnées associées à une image dans la liste
181
	 * des images chargée dans le modèle
182
	 * @param r le rafraichissable auquel on enverra les informations
183
	 * @param id l'identifiant de l'image
184
	 */
16 aperonnet 185
	public void obtenirMetadonnees(Rafraichissable r, String id)
30 aperonnet 186
	{
25 aperonnet 187
		ImageCarnet im = (ImageCarnet)cacheImage.get(id) ;
16 aperonnet 188
 
30 aperonnet 189
		Object meta[] = new Object[3] ;
190
		meta[0] = im.getMetadonnesExif() ;
191
		meta[1] = im.getMetadonnesIptc() ;
192
		meta[2] = im.getInfoGenerales() ;
193
 
194
		r.rafraichir(meta,false) ;
16 aperonnet 195
	}
18 aperonnet 196
 
30 aperonnet 197
	/**
198
	 * Va chercher les mots clés associés à une image dans la liste
199
	 * des images chargée dans le modèle
200
	 * @param r le rafraichissable auquel on enverra les informations
201
	 * @param id l'identifiant de l'image
202
	 */
25 aperonnet 203
	public void obtenirMotsClesId(Rafraichissable r, String id)
30 aperonnet 204
	{
25 aperonnet 205
		ImageCarnet im = (ImageCarnet)cacheImage.get(id) ;
206
		String motsClesId = im.getMotsCles() ;
207
		String[] motsClesIdTab = motsClesId.split(",") ;
208
 
209
		r.rafraichir(motsClesIdTab, false) ;
210
	}
211
 
30 aperonnet 212
	/**
213
	 * Met à jour la liste des images en local et appelle le DAO de mise
214
	 * à jour pour les commentaires et la date des images selectionnées
215
	 * @param commentaires le commentaire à appliquer
216
	 * @param date la date à appliquer
217
	 * @param ids les identifiants des images selectionnées
218
	 */
18 aperonnet 219
	public void mettreAJourCacheImage(String commentaires, String date, String ids[])
220
	{
25 aperonnet 221
			for (int i = 0; i < ids.length; i++)
222
			{
18 aperonnet 223
				String key = ids[i] ;
224
				ImageCarnet ic = (ImageCarnet)cacheImage.get(key) ;
225
				ic.miseAJourInfoGenerales(commentaires, date) ;
28 aperonnet 226
				mettreAjourBaseDeDonneesImageCarnet(ic) ;
18 aperonnet 227
			}
228
	}
19 aperonnet 229
 
30 aperonnet 230
	/**
231
	 * Ajoute un nouveau mot clés à la liste des mots clés locale
232
	 * @param text le mot clé
233
	 * @param id l'identifiant du mot clé
234
	 */
25 aperonnet 235
	public void mettreAjourMotsClesId(String text, String id)
236
	{
28 aperonnet 237
				 motsCles.put(id, text) ;
25 aperonnet 238
	}
239
 
30 aperonnet 240
	/**
241
	 * Appelle le DAO chargé de mettre à jour la base de données avec
242
	 * les toutes les informations des images modifiées par l'utilisateur
243
	 */
28 aperonnet 244
	public void mettreAJourBaseDeDonneesListeImageCarnet()
245
	{
19 aperonnet 246
		ListeImageAsynchroneDAO liDaO = new ListeImageAsynchroneDAO();
35 aperonnet 247
		liDaO.setIModele(this);
19 aperonnet 248
 
249
		liDaO.SynchroniserBaseDeDonnees(cacheImage);
250
	}
251
 
30 aperonnet 252
	/**
253
	 * Appelle le DAO chargé de mettre à jour la base de données avec
254
	 * les toutes les informations d'une image donnée
255
	 * @param ic l'image à synchroniser avec la base
256
	 */
28 aperonnet 257
	public void mettreAjourBaseDeDonneesImageCarnet(ImageCarnet ic)
19 aperonnet 258
	{
259
		ImageAsynchroneDAO iaDaO = new ImageAsynchroneDAO();
260
		iaDaO.SynchroniserBaseDeDonnees(ic) ;
261
	}
7 aperonnet 262
 
30 aperonnet 263
	/**
264
	 * Supprime les images données du cache local et appelle le DAO
265
	 * qui les supprime de la base de données
266
	 * @param ids les identifiants des images selectionnées
267
	 */
268
	public void supprimerImages(String[] ids)
269
	{
20 aperonnet 270
		String rids[] = new String[ids.length] ;
271
		ListeImageAsynchroneDAO liDao = new ListeImageAsynchroneDAO() ;
35 aperonnet 272
		liDao.setIModele(this);
20 aperonnet 273
 
30 aperonnet 274
		for (int i = 0; i < ids.length; i++)
275
		{
20 aperonnet 276
			String key = ids[i] ;
277
			ImageCarnet ic = (ImageCarnet)cacheImage.get(key) ;
278
			rids[i] = ic.getId() ;
31 aperonnet 279
 
280
			cacheImage.remove(key) ;
20 aperonnet 281
		}
282
 
283
		if(rids.length != 0)
31 aperonnet 284
		{
20 aperonnet 285
			liDao.supprimerBaseDeDonnees(rids);
30 aperonnet 286
		}
20 aperonnet 287
	}
288
 
30 aperonnet 289
	/**
290
	 * Met à jour les données locales suivant le type des nouvelles données
291
	 * et appelle le médiateur pour le notifier de la mise à jour
292
	 */
293
	public void rafraichir(Object nouvelleDonnees, boolean repandreRafraichissement)
294
	{
31 aperonnet 295
		// si l'on a reçu une liste d'images
30 aperonnet 296
		if(nouvelleDonnees instanceof ListeImageCarnet)
297
		{
298
				ListeImageCarnet data = (ListeImageCarnet) nouvelleDonnees ;
299
				Object[][] photoData = new Object[data.size()][7];
300
				int i = 0 ;
31 aperonnet 301
				// on la parse et on récupère les informations quiç nous interessent
30 aperonnet 302
				for (Iterator it = data.keySet().iterator(); it.hasNext();)
303
				{
304
					ImageCarnet im = (ImageCarnet) data.get(it.next());
305
					photoData[i][0] = im.getOrdre() ;
306
					photoData[i][1] = im.getDate() ;
307
					photoData[i][2] = im.getIptcCity() ;
308
					photoData[i][3] = im.getMake()+" "+im.getModel() ;
309
					photoData[i][4] = im.getSUrl() ;
310
					photoData[i][5] = im.getMUrl() ;
311
					photoData[i][6] = im.getUrl() ;
312
 
313
					i++ ;
314
				}
20 aperonnet 315
 
31 aperonnet 316
				// creation du store qui les contient
30 aperonnet 317
				FieldDef defNumImage = new IntegerFieldDef("num_image");
318
				FieldDef defDatImage = new StringFieldDef("dat_image");
319
				FieldDef defLieImage = new StringFieldDef("lie_image");
320
				FieldDef defAppImage = new StringFieldDef("app_image");
321
				FieldDef defUrlImageS = new StringFieldDef("url_image_S");
322
				FieldDef defUrlImageM = new StringFieldDef("url_image_M");
323
				FieldDef defUrlImage = new StringFieldDef("url_image");
324
				FieldDef[] defTab = {defNumImage,defDatImage,defLieImage,defAppImage,defUrlImageS,defUrlImageM,defUrlImage};
325
				RecordDef rd = new RecordDef(defTab) ;
25 aperonnet 326
 
30 aperonnet 327
				final MemoryProxy dataProxy = new MemoryProxy(photoData);
328
				final ArrayReader reader = new ArrayReader(rd);
329
 
330
				final Store photoStore = new Store(dataProxy, reader);
331
 
332
				rafraichirListeImage(nouvelleDonnees);
333
 
334
				st = photoStore ;
31 aperonnet 335
				st.load() ;
336
 
337
				// par défaut le store est trié sur le numéro d'image
338
				st.sort("num_image") ;
339
 
20 aperonnet 340
 
31 aperonnet 341
				// si on doit répandre les données, on notifie le médiateur qui les distribuera à son tour
30 aperonnet 342
				if(repandreRafraichissement)
343
				{
344
					getIMediateur().synchroniserDonneesZoomListeGalerie(st, this) ;
345
				}
346
		}
347
 
31 aperonnet 348
		// si on reçoit un tableau JSON
30 aperonnet 349
		if(nouvelleDonnees instanceof JSONArray)
350
		{
31 aperonnet 351
			// alors on a reçu les informations sur les mots clés
30 aperonnet 352
			JSONArray reponse = (JSONArray)nouvelleDonnees ;
25 aperonnet 353
 
30 aperonnet 354
			final int taillemax = reponse.size();
25 aperonnet 355
 
31 aperonnet 356
			// si le tableau est vide
30 aperonnet 357
			if(taillemax == 0)
25 aperonnet 358
			{
31 aperonnet 359
				// on crée un arbre vide
30 aperonnet 360
				TreeNode root = new TreeNode() ;
361
				root.setId("racine") ;
362
				root.setText("Tags") ;
363
				root.setIcon("tela.png") ;
364
				String[] usObj = {"Tags","racine"} ;
365
				root.setUserObject(usObj) ;
366
				arbreMotsCles.setRootNode(root) ;
25 aperonnet 367
			}
30 aperonnet 368
 
31 aperonnet 369
			// pour chacun des élements du tableau
30 aperonnet 370
			for (int j = 0; j < taillemax ; j++)
371
			{
31 aperonnet 372
				// on extrait les élements du tableau
30 aperonnet 373
				if(reponse.get(j).isObject() != null)
374
				{
375
					JSONObject noeud = (JSONObject)reponse.get(j) ;
376
 
377
					String id_noeud = noeud.get("cmc_id_mot_cle_utilisateur").isString().stringValue() ;
378
					String mot_cle = noeud.get("cmc_mot_cle").isString().stringValue() ;
379
					String parent = noeud.get("cmc_id_parent").isString().stringValue() ;
380
 
381
					String[] usObj = {mot_cle, id_noeud} ;
382
 
31 aperonnet 383
					// et on construit l'arbre à partir de la racine (qui est toujoursl e premier élément)
30 aperonnet 384
					if(id_noeud.equals("racine"))
385
					{
386
						TreeNode root = new TreeNode() ;
387
						root.setId(id_noeud) ;
388
						root.setText(mot_cle) ;
389
						root.setIcon("tela.png") ;
390
						root.setUserObject(usObj) ;
391
						arbreMotsCles.setRootNode(root) ;
392
					}
393
					else
394
					{
31 aperonnet 395
						// et en ajoutant les noeuds un à un (qui sont renvoyé dans l'ordre hierarchique de leur niveau
396
						// ce qui permet de les traiter séquentiellement)
30 aperonnet 397
						TreeNode node = new TreeNode() ;
398
						node.setId(id_noeud) ;
399
						node.setText(mot_cle) ;
400
						node.setChecked(false) ;
401
						Node parentNode = arbreMotsCles.getNodeById(parent) ;
402
						node.setIcon("tela.png") ;
403
						node.setUserObject(usObj) ;
404
						parentNode.appendChild(node) ;
405
					}
406
				}
31 aperonnet 407
			}
408
				// enfin on met à jour l'arbre des mots clés contenu dans le modèle
30 aperonnet 409
				rafraichirArbreMotsCles(arbreMotsCles) ;
31 aperonnet 410
				// et on notifie le médiateur de la mise à jour en lui passant une copie des données
411
				getIMediateur().rafraichirArbreMotsCles(arbreMotsCles) ;
412
		}
413
 
414
		// Si on reçoit un tableau d'entiers
415
		// c'est un tableau d'un seul entier qui est le nombre d'images correspondant aux critères
416
		if(nouvelleDonnees instanceof int[])
417
		{
418
			int[] pages = (int[])nouvelleDonnees ;
419
 
420
			// on calcule le nombre de pages nécessaires et on les met à jour dans le modèle
421
			pageMax  = calculerNbPages(pages[0]) ;
422
			nbElements = pages[0] ;
423
 
424
			// et on notifie de le mediateur du changement des valeurs
425
			getIMediateur().changerPageMaxEtCourante(pageMax,pageEncours,taillePage,pages[0]) ;
426
		}
25 aperonnet 427
	}
20 aperonnet 428
 
30 aperonnet 429
	/**
430
	 * Affiche les paires / valeur de tous les mots clés stockés
431
	 */
25 aperonnet 432
	public void afficherMotsCles()
433
	{
28 aperonnet 434
		for(Iterator it = motsCles.keySet().iterator() ; it.hasNext() ;)
20 aperonnet 435
		{
25 aperonnet 436
			String key = (String)it.next() ;
28 aperonnet 437
			String valeur = (String)motsCles.get(key) ;
25 aperonnet 438
			System.out.println("clé : "+key+" valeur : "+valeur);
20 aperonnet 439
		}
25 aperonnet 440
	}
441
 
30 aperonnet 442
	/**
443
	 * Met à jour les mots clés associés à une image et appelle le DAO pour synchroniser la base de données
444
	 * @param ids les identifiants des images selectionnées
445
	 * @param motsClesEnCours les mots clés à appliquer aux images
446
	 * @param arbreMC l'arbre de mots clés en cours
447
	 */
448
	public void mettreAjourMotsCles(String[] ids, String motsClesEnCours, com.gwtext.client.data.Tree arbreMC)
449
	{
450
		for (int i = 0; i < ids.length; i++)
451
		{
25 aperonnet 452
			if(cacheImage.containsKey(ids[i]))
453
			{
454
				ImageCarnet ic = (ImageCarnet)cacheImage.get(ids[i]) ;
455
				ic.mettreAjourMotsCles(motsClesEnCours) ;
30 aperonnet 456
 
457
				ImageAsynchroneDAO imgDao = new ImageAsynchroneDAO() ;
458
				imgDao.SynchroniserMotsClesImageBaseDeDonnees(ic) ;
25 aperonnet 459
			}
460
		}
461
 
28 aperonnet 462
		rafraichirArbreMotsCles(arbreMC) ;
25 aperonnet 463
	}
28 aperonnet 464
 
30 aperonnet 465
 
466
	/**
467
	 * Appelle le DAO des mots clés pour obtenir l'arbre complet stocké dans la base de données
468
	 */
469
	public void initialiserArbreMotsCles()
470
	{
471
		MotsClesAsynchroneDAO MCDao = new MotsClesAsynchroneDAO() ;
35 aperonnet 472
		MCDao.setIModele(this) ;
30 aperonnet 473
 
474
		MCDao.obtenirListeMotsCles(this) ;
475
	}
476
 
477
	/**
478
	 * Envoie l'arbre des mots clés stocké localement à l'élément rafrachissable donné, qui le demande
479
	 * @param r le rafraichissable demandeur de l'arbre
480
	 */
481
	public void obtenirArbreMotCle(Rafraichissable r)
482
	{
483
		r.rafraichir(arbreMotsCles, false) ;
484
	}
28 aperonnet 485
 
30 aperonnet 486
	/**
487
	 * Ajoute un mot clé à l'arbre des mots clés local et appelle le DAO qui fait la mise
488
	 * à jour de l'arbre des mots clés dans la base
489
	 * @param n le nouveau noeud contenant le mot clé
490
	 * @param arbreMC l'arbre des mots cles en cours
491
	 */
492
	public void ajouterMotCleDansArbre(TreeNode n, com.gwtext.client.data.Tree arbreMC)
493
	{
28 aperonnet 494
		MotsClesAsynchroneDAO MCDao = new MotsClesAsynchroneDAO() ;
35 aperonnet 495
		MCDao.setIModele(this) ;
28 aperonnet 496
 
497
		String[] usObj = (String[])n.getUserObject() ;
498
		String motCle = usObj[0] ;
499
		String id = usObj[1] ;
30 aperonnet 500
		String parentId = "" ;
501
 
28 aperonnet 502
		if(!id.equals("racine"))
503
		{
504
			String[] parentUsObj = (String[])n.getParentNode().getUserObject() ;
505
			parentId = parentUsObj[1] ;
506
		}
507
		else
508
		{
509
			parentId = "racine" ;
510
		}
511
 
512
		rafraichirArbreMotsCles(arbreMC) ;
513
 
514
		String nouveauMotCle = "&motcle="+motCle+"&id="+id+"&parent="+parentId ;
30 aperonnet 515
		MCDao.ajouterBaseDeDonnees(nouveauMotCle) ;
28 aperonnet 516
	}
517
 
30 aperonnet 518
	/**
519
	 * Supprime un noeud de l'arbre des mots clés et appelle le DAO qui va supprimer
520
	 * les mots clés associés dans la base
521
	 * @param n le noeud à supprimer
522
	 * @param arbreMC l'arbre des mots clés en cours
523
	 */
524
	public void supprimerMotCleDansArbre(TreeNode n, Tree arbreMC)
525
	{
28 aperonnet 526
 
527
		MotsClesAsynchroneDAO MCDao = new MotsClesAsynchroneDAO() ;
35 aperonnet 528
		MCDao.setIModele(this) ;
28 aperonnet 529
 
530
		String[] usObj = (String[])n.getUserObject() ;
531
		String motCle = usObj[0] ;
532
		String id = usObj[1] ;
533
 
534
		String motCleASupprimer = id ;
535
 
536
		MCDao.supprimerBaseDeDonnees(id) ;
537
 
538
	}
539
 
30 aperonnet 540
	/**
541
	 * Modifie le noeud donné dans l'arbre des mots clés en cours et appelle le DAO
542
	 * qui synchronise la modification dans la base de données
543
	 * @param n le noeud modifié
544
	 * @param arbreMC l'arbre des mots clés en cours
545
	 */
546
	public void modifierMotCleDansArbre(TreeNode n, Tree arbreMC)
547
	{
28 aperonnet 548
 
549
		MotsClesAsynchroneDAO MCDao = new MotsClesAsynchroneDAO() ;
35 aperonnet 550
		MCDao.setIModele(this) ;
28 aperonnet 551
 
552
		String[] usObj = (String[])n.getUserObject() ;
553
		String motCle = usObj[0] ;
554
		String id = usObj[1] ;
30 aperonnet 555
		String parentId = "" ;
556
 
28 aperonnet 557
		if(!id.equals("racine"))
558
		{
559
			String[] parentUsObj = (String[])n.getParentNode().getUserObject() ;
560
			parentId = parentUsObj[1] ;
561
		}
562
		else
563
		{
564
			parentId = "racine" ;
565
		}
566
 
567
		rafraichirArbreMotsCles(arbreMC) ;
568
 
30 aperonnet 569
		String motCleModifie = "&motcle="+motCle+"&id="+id+"&parent="+parentId ;
28 aperonnet 570
		MCDao.modifierBaseDeDonnees(motCleModifie) ;
571
 
572
	}
573
 
30 aperonnet 574
	/**
575
	 * Deplace un noeud dans l'arbre des mots cles et appelle le DAO qui reorganise l'arbre
576
	 * dans la base de donnees suivant le changement
577
	 * @param n le noeud deplace (et son sous arbre associe)
578
	 * @param arbreMC l'arbre des mots cles en cours
579
	 */
28 aperonnet 580
	public void deplacerMotCleDansArbre(TreeNode n, Tree arbreMC)
581
	{
582
		MotsClesAsynchroneDAO MCDao = new MotsClesAsynchroneDAO() ;
35 aperonnet 583
		MCDao.setIModele(this) ;
28 aperonnet 584
 
585
		String[] usObj = (String[])n.getUserObject() ;
586
		String motCle = usObj[0] ;
587
		String id = usObj[1] ;
30 aperonnet 588
		String parentId = "" ;
28 aperonnet 589
		if(!id.equals("racine"))
590
		{
591
			String[] parentUsObj = (String[])n.getParentNode().getUserObject() ;
592
			parentId = parentUsObj[1] ;
593
		}
594
		else
595
		{
596
			parentId = "racine" ;
597
		}
598
 
599
		rafraichirArbreMotsCles(arbreMC) ;
600
 
30 aperonnet 601
		String motCleModifie = "&motcle="+motCle+"&id="+id+"&parent="+parentId ;
28 aperonnet 602
		MCDao.deplacerBaseDeDonnees(motCleModifie) ;
603
	}
604
 
31 aperonnet 605
	/**
606
	 * Change le numéro de la page en cours et envoie une demande de mise à jour des données
607
	 * @param nouvellePageCourante la nouvelle page à afficher
608
	 */
609
	public void changerNumeroPage(int nouvellePageCourante)
610
	{
611
			pageEncours = nouvellePageCourante ;
612
			obtenirPhotoGalerie(this) ;
613
	}
614
 
615
	/**
616
	 * Calcule le nombre de pages nécessaires pour afficher un nombre d'élements donnés en fonction de la taille de page
617
	 * en cours
618
	 * @param nbElements le nombre d'élements total
619
	 * @return le nombre de pages
620
	 */
621
	public int calculerNbPages(int nbElements)
622
	{
623
		// A cause de la betise de java pour les conversion implicite on fait quelques conversions manuellement
624
		// pour eviter qu'il arrondisse mal la division
625
		// nombre de pages = (nombre d'element / taille de la page) arrondie à l'entier superieur
626
		double nPage = (1.0*nbElements)/(1.0*taillePage) ;
627
		double nPageRound = Math.ceil(nPage) ;
628
		Double nPageInt = new Double(nPageRound) ;
629
 
630
		// on convertit en entier
631
		return nPageInt.intValue() ;
632
	}
633
 
634
	/**
635
	 * Recalcule la page en cours lors du changement du nombre d'élements
636
	 * @param nbElements le nombre d'élements total
637
	 * @return la nouvelle page encours
638
	 */
639
	public int calculerPageCourante(int nbElements)
640
	{
641
		// on calcule le nombre de page
642
		int nouvelNbPages = calculerNbPages(nbElements) ;
643
		// la nouvelle page en cours
644
		double nPageCourante = (1.0*pageEncours)/(1.0*pageMax) * (1.0*nouvelNbPages) ;
645
 
646
		// on arrondit au supérieur
647
		double nPageRound = Math.ceil(nPageCourante) ;
648
		Double nPageInt = new Double(nPageRound) ;
649
 
650
		// on convertit en entier
651
		return nPageInt.intValue() ;
652
	}
653
 
654
	/**
655
	 * Change la taille de page et recalcule la page encours
656
	 * @param nouvelleTaillePage la nouvelle taille de page à utiliser
657
	 */
658
	public void changerTaillePage(int nouvelleTaillePage)
659
	{
660
		taillePage = nouvelleTaillePage ;
661
		pageEncours = calculerPageCourante(nbElements) ;
662
		obtenirPhotoGalerie(this) ;
663
	}
664
 
35 aperonnet 665
	/**
666
	 * Notifie le mediateur que l'upload ou le download est termine et qu'il faut rafraichir les vues avec les nouvelles données
667
	 */
668
	public void requeteTerminee()
669
	{
670
		getIMediateur().rafraichirToutesVues() ;
671
	}
672
 
673
	/**
674
	 * Obtient l'identifiant de l'utilisateur auprès du médiateur
675
	 * @return id de l'utilisateur
676
	 */
677
	public String getIdentifiant() {
678
 
679
		return getIMediateur().getIdentifiant() ;
680
	}
681
 
682
	public String[] obtenirTailleImage(String id) {
683
 
684
		return  ((ImageCarnet)cacheImage.get(id)).getTailleImage() ;
685
 
686
	}
687
 
7 aperonnet 688
}