Subversion Repositories eFlore/Applications.cel

Rev

Rev 31 | 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
 
5 aperonnet 3
 
30 jpm 4
import org.tela_botanica.client.CarnetEnLigneMediateur;
2 aperonnet 5
import org.tela_botanica.client.interfaces.IdVue;
6
import org.tela_botanica.client.interfaces.Rafraichissable;
7
import org.tela_botanica.client.interfaces.VueListable;
8
import org.tela_botanica.client.observation.ObservationMediateur;
9
import org.tela_botanica.client.vues.ArbreMotsClesFiltreVue;
10
import org.tela_botanica.client.vues.BarreOutilsVue;
11
import org.tela_botanica.client.vues.BarreRechercheFiltreVue;
12
import org.tela_botanica.client.vues.GalerieImageVue;
13
import org.tela_botanica.client.vues.ListeImageVue;
14
import org.tela_botanica.client.vues.MenuImageVue;
5 aperonnet 15
import org.tela_botanica.client.vues.MiniListeObservationVue;
2 aperonnet 16
import org.tela_botanica.client.vues.PanneauFiltresVues;
17
import org.tela_botanica.client.vues.PanneauMetadonneesVue;
18
import org.tela_botanica.client.vues.ZoomImageVue;
19
 
30 jpm 20
import com.google.gwt.core.client.JavaScriptObject;
2 aperonnet 21
import com.google.gwt.user.client.DOM;
22
import com.google.gwt.user.client.Element;
23
import com.google.gwt.user.client.Event;
24
import com.google.gwt.user.client.Window;
25
import com.gwtext.client.core.EventObject;
26
import com.gwtext.client.core.Ext;
27
import com.gwtext.client.core.ExtElement;
28
import com.gwtext.client.core.RegionPosition;
29
import com.gwtext.client.data.Record;
30
import com.gwtext.client.data.Store;
31
import com.gwtext.client.data.Tree;
5 aperonnet 32
import com.gwtext.client.dd.DragData;
33
import com.gwtext.client.dd.DragSource;
30 jpm 34
import com.gwtext.client.widgets.BoxComponent;
35
import com.gwtext.client.widgets.Component;
36
import com.gwtext.client.widgets.Container;
2 aperonnet 37
import com.gwtext.client.widgets.DataView;
38
import com.gwtext.client.widgets.Panel;
39
import com.gwtext.client.widgets.TabPanel;
31 jpm 40
import com.gwtext.client.widgets.event.ComponentListenerAdapter;
41
import com.gwtext.client.widgets.event.ContainerListener;
42
import com.gwtext.client.widgets.event.ContainerListenerAdapter;
30 jpm 43
import com.gwtext.client.widgets.event.PanelListener;
44
import com.gwtext.client.widgets.event.PanelListenerAdapter;
5 aperonnet 45
import com.gwtext.client.widgets.grid.GridDragData;
2 aperonnet 46
import com.gwtext.client.widgets.layout.BorderLayout;
47
import com.gwtext.client.widgets.layout.BorderLayoutData;
48
import com.gwtext.client.widgets.layout.FitLayout;
49
import com.gwtext.client.widgets.menu.BaseItem;
50
import com.gwtext.client.widgets.menu.Item;
51
import com.gwtext.client.widgets.menu.Menu;
52
import com.gwtext.client.widgets.menu.event.MenuListenerAdapter;
53
import com.gwtext.client.widgets.tree.TreeEditor;
54
import com.gwtext.client.widgets.tree.TreeNode;
55
 
56
/**
5 aperonnet 57
 * Mediateur gérant les interactions entre vues et les echanges de données C'est
58
 * un singleton.
59
 *
2 aperonnet 60
 * @author aurelien
5 aperonnet 61
 *
2 aperonnet 62
 */
63
public class ImageMediateur {
5 aperonnet 64
 
2 aperonnet 65
	/**
5 aperonnet 66
	 * le mediateur des observations qui lie la partie images au carnet
2 aperonnet 67
	 */
30 jpm 68
	private CarnetEnLigneMediateur cMediateur = null;
5 aperonnet 69
 
31 jpm 70
 
71
	private static ImageMediateur thisMediateur = null ;
2 aperonnet 72
	/**
73
	 * booleen qui verifie l'unicite de l'instance (donc static)
74
	 */
5 aperonnet 75
	private static boolean estInstancie = false;
76
 
2 aperonnet 77
	/**
78
	 * modele de données
79
	 */
5 aperonnet 80
	private ImageModele iModele = null;
81
 
2 aperonnet 82
	/**
5 aperonnet 83
	 * L'identifiant utilisateur. Par défaut, il vaut 0
2 aperonnet 84
	 */
5 aperonnet 85
	private String identifiant = "0";
2 aperonnet 86
 
87
	/**
88
	 * panneau principal des images (onglet "images")
89
	 */
31 jpm 90
	private Panel panneauPrincipalImage = null ;
5 aperonnet 91
 
2 aperonnet 92
	/**
93
	 * panneau a onglet pour la liste, la galerie et la vue en grand
5 aperonnet 94
	 */
95
	private TabPanel ongletsImage = null;
96
 
2 aperonnet 97
	/**
98
	 * panneau de filtrage
99
	 */
5 aperonnet 100
	private PanneauFiltresVues filtres = null;
101
 
2 aperonnet 102
	/**
103
	 * conteneur du panneau a onglets
104
	 */
5 aperonnet 105
	private Panel panneauMenuEtOngletsImage = null;
106
 
2 aperonnet 107
	/**
108
	 * galerie de miniature
109
	 */
5 aperonnet 110
	private GalerieImageVue galerieImage = null;
111
 
2 aperonnet 112
	/**
113
	 * liste détaillée des images
114
	 */
5 aperonnet 115
	private ListeImageVue listeImage = null;
116
 
2 aperonnet 117
	/**
118
	 * vue agrandie de la l'image selectionnée
119
	 */
5 aperonnet 120
	private ZoomImageVue zoomImage = null;
121
 
2 aperonnet 122
	/**
123
	 * panneau a onglets affichant les métadonnées et les mots clés
124
	 */
5 aperonnet 125
	private PanneauMetadonneesVue metadonneesIptcExif = null;
126
 
2 aperonnet 127
	/**
128
	 * panneau conteneur pour le panneau a onglet des metadonnées
129
	 */
130
	private final Panel detailsEtMotsCles = new Panel("Détails et mots clés");
5 aperonnet 131
 
2 aperonnet 132
	/**
133
	 * menu contextuel de manipulation des images
134
	 */
5 aperonnet 135
	private MenuImageVue menuImageVue = null;
136
 
2 aperonnet 137
	/**
138
	 * barre d'outils
139
	 */
5 aperonnet 140
	private BarreOutilsVue barreOutilsVue = null;
141
 
2 aperonnet 142
	/**
143
	 * l'indice du dernier onglet sélectionné
144
	 */
5 aperonnet 145
	private int dernierIndexOnglet = 0;
146
 
2 aperonnet 147
	/**
148
	 * booleen explicitant s'il y a une selection en cours
149
	 */
5 aperonnet 150
	private boolean selection = false;
151
 
2 aperonnet 152
	/**
153
	 * Filtre pour les mots cles
154
	 */
5 aperonnet 155
	private ArbreMotsClesFiltreVue filtreMotsCles = null;
156
 
2 aperonnet 157
	/**
158
	 * Filtre pour les commentaires
159
	 */
5 aperonnet 160
	private BarreRechercheFiltreVue filtreCommentaires = null;
2 aperonnet 161
 
162
	/**
163
	 * constructeur privé (on accède a la classe par la méthode getInstance)
164
	 */
5 aperonnet 165
	private ImageMediateur() {
30 jpm 166
 
167
				initialiser() ;
5 aperonnet 168
 
30 jpm 169
	}
5 aperonnet 170
 
30 jpm 171
	/**
172
	 * constructeur avec paramètres privé (on accède a la classe par la méthode
173
	 * getInstance)
174
	 *
175
	 * @param cm
176
	 *            le médiateur du carnet à associer à la partie image
177
	 */
178
	private ImageMediateur(CarnetEnLigneMediateur cm) {
179
 
180
		cMediateur = cm;
31 jpm 181
		initialiser() ;
5 aperonnet 182
 
30 jpm 183
	}
5 aperonnet 184
 
30 jpm 185
	/**
186
	 * Change la valeur du booleen de selection
187
	 *
188
	 * @param selection
189
	 *            la nouvelle valeur du booléen
190
	 */
191
	public void setSelection(boolean selection) {
192
		this.selection = selection;
193
	}
5 aperonnet 194
 
30 jpm 195
	/**
196
	 * renvoie la valeur du booleen de selection
197
	 *
198
	 * @return la valeur du booleen de selection
199
	 */
200
	public boolean isSelection() {
201
		return selection;
202
	}
5 aperonnet 203
 
30 jpm 204
	/**
205
	 * Retourne une instance de manière unique
206
	 *
207
	 * @return l'instance unique du médiateur
208
	 */
209
	public static ImageMediateur Instance() {
31 jpm 210
		if (!estInstancie && thisMediateur == null) {
211
			// on en crée un nouveau
30 jpm 212
			estInstancie = true;
31 jpm 213
			thisMediateur = new ImageMediateur();
30 jpm 214
		}
31 jpm 215
		// sinon on retourne le "pointeur" vers le médiateur lui-même
216
		return thisMediateur;
2 aperonnet 217
	}
5 aperonnet 218
 
2 aperonnet 219
	/**
30 jpm 220
	 * Retourne une instance de manière unique en lui associant un médiateur
221
	 * pour les observations
5 aperonnet 222
	 *
31 jpm 223
	 * @param cm le médiateur de carnet à associer
30 jpm 224
	 * @return l'instance unique du médiateur
2 aperonnet 225
	 */
30 jpm 226
	public static ImageMediateur Instance(CarnetEnLigneMediateur cm) {
31 jpm 227
		if (!estInstancie && thisMediateur == null) {
228
			// on en crée un nouveau
30 jpm 229
			estInstancie = true;
31 jpm 230
			thisMediateur = new ImageMediateur(cm);
30 jpm 231
		}
31 jpm 232
		// sinon on retourne le "pointeur" vers le médiateur lui-même
233
		return thisMediateur;
30 jpm 234
	}
235
 
236
	private void initialiser()
237
	{
2 aperonnet 238
		// quelques variables de position pour les borderlayouts
239
		final BorderLayoutData regionNord = new BorderLayoutData(
5 aperonnet 240
				RegionPosition.NORTH);
241
 
2 aperonnet 242
		final BorderLayoutData regionCentre = new BorderLayoutData(
5 aperonnet 243
				RegionPosition.CENTER);
2 aperonnet 244
 
245
		final BorderLayoutData regionEst = new BorderLayoutData(
246
				RegionPosition.EAST);
247
		regionEst.setSplit(true);
5 aperonnet 248
 
2 aperonnet 249
		final BorderLayoutData regionOuest = new BorderLayoutData(
250
				RegionPosition.WEST);
251
		regionOuest.setSplit(true);
31 jpm 252
 
253
		panneauPrincipalImage = new Panel("Images") ;
36 jpm 254
		panneauPrincipalImage.setSize(cMediateur.getPanneauPrincipalCarnetEnLigne().getWidth(), cMediateur.getPanneauPrincipalCarnetEnLigne().getHeight()) ;
31 jpm 255
		panneauPrincipalImage.setLayout(new BorderLayout()) ;
2 aperonnet 256
 
257
		// on crée un modèle
258
		iModele = ImageModele.Instance(this);
259
		// et on demande l'arbre des mots clés
5 aperonnet 260
		iModele.initialiserArbreMotsCles();
261
 
2 aperonnet 262
		// on gère la mise en page du panneau principal
5 aperonnet 263
 
2 aperonnet 264
		// on crée le panneau des filtres
5 aperonnet 265
		filtres = new PanneauFiltresVues(this);
36 jpm 266
		//filtres.setWidth(200);
5 aperonnet 267
 
2 aperonnet 268
		// le panneau à onglet qui contient les trois vues
269
		ongletsImage = new TabPanel();
5 aperonnet 270
 
2 aperonnet 271
		// la galerie
5 aperonnet 272
		galerieImage = new GalerieImageVue(this);
273
 
2 aperonnet 274
		// la liste des images
275
		Panel panneauListeImage = new Panel("Liste");
276
		listeImage = new ListeImageVue(this);
36 jpm 277
		//panneauListeImage.setLayout(new FitLayout());
2 aperonnet 278
		panneauListeImage.add(listeImage);
5 aperonnet 279
 
2 aperonnet 280
		// le panneau zoom
281
		zoomImage = new ZoomImageVue(this);
5 aperonnet 282
 
2 aperonnet 283
		// on ajoute les panneaux au panneau à onglets
284
		ongletsImage.add(galerieImage);
5 aperonnet 285
		ongletsImage.add(panneauListeImage);
2 aperonnet 286
		ongletsImage.add(zoomImage);
5 aperonnet 287
 
2 aperonnet 288
		// on crée les menu et la barre de vue
5 aperonnet 289
		menuImageVue = new MenuImageVue(this);
290
		barreOutilsVue = new BarreOutilsVue(this);
291
 
2 aperonnet 292
		// on initialise le volet qui contient les mots clés
293
		detailsEtMotsCles.setWidth("25%");
294
		detailsEtMotsCles.setAnimCollapse(true);
295
		detailsEtMotsCles.setTitleCollapse(true);
296
		detailsEtMotsCles.setCollapsible(true);
5 aperonnet 297
 
2 aperonnet 298
		// on crée le panneau conteneur des métadonnées et infos
5 aperonnet 299
		metadonneesIptcExif = new PanneauMetadonneesVue(this);
2 aperonnet 300
		// et on l'inclut dans le volet approprié
5 aperonnet 301
		detailsEtMotsCles.add(metadonneesIptcExif);
302
 
31 jpm 303
		panneauMenuEtOngletsImage = new Panel() ;
304
		panneauMenuEtOngletsImage.setLayout(new BorderLayout()) ;
5 aperonnet 305
		// on ajoute la barre de vue au nord du panneau qui contient menu et
306
		// onglets d'images
307
		panneauMenuEtOngletsImage.add(barreOutilsVue, regionNord);
2 aperonnet 308
		// les onglets au centre
5 aperonnet 309
		panneauMenuEtOngletsImage.add(ongletsImage, regionCentre);
31 jpm 310
 
36 jpm 311
		// et le panneau de métadonnées et d'info sur le coté droit
312
		panneauPrincipalImage.add(detailsEtMotsCles, regionEst);
313
 
5 aperonnet 314
		// on ajoute le panneau qui contient le menu et les onglets d'images au
315
		// centre
316
		panneauPrincipalImage.add(panneauMenuEtOngletsImage, regionCentre);
31 jpm 317
 
2 aperonnet 318
		// on ajoute les filtres au panneau gauche
31 jpm 319
		panneauPrincipalImage.add(filtres,regionOuest) ;
320
 
5 aperonnet 321
		// filtres.setCollapsed(false) ;
31 jpm 322
		thisMediateur = this ;
323
 
324
		setIdentifiant(""+"aurelien".hashCode());
325
 
326
		panneauPrincipalImage.addListener(new ContainerListenerAdapter() {
327
 
328
			public void onShow(Component component)
329
			{
330
				changerUtilisateur() ;
331
			}
332
 
333
		}) ;
334
 
2 aperonnet 335
	}
5 aperonnet 336
 
2 aperonnet 337
	/**
338
	 * Renvoie l'identifiant de l'utilisateur en cours
5 aperonnet 339
	 *
2 aperonnet 340
	 * @return l'identifiant de l'utilisateur
341
	 */
5 aperonnet 342
	public String getIdentifiant() {
343
		return identifiant;
2 aperonnet 344
	}
5 aperonnet 345
 
346
	/**
347
	 * . Setteur pour l'identifiant de l'utilisateur en cours
348
	 *
349
	 * @param id
350
	 *            le nouvel identifiant utilisateur
2 aperonnet 351
	 */
5 aperonnet 352
	public void setIdentifiant(String id) {
353
		identifiant = id;
2 aperonnet 354
	}
5 aperonnet 355
 
2 aperonnet 356
	/**
5 aperonnet 357
	 * Appelle les fonctions de chargement de données, suit généralement un
358
	 * appel à setIdentifiant, pour obtenir l'arbre des mots clés et les images
359
	 * du nouvel utilisateur
2 aperonnet 360
	 */
5 aperonnet 361
	public void changerUtilisateur() {
362
		getIModele().initialiserArbreMotsCles();
363
		obtenirPhotoGalerie(getGalerieImage());
2 aperonnet 364
	}
365
 
366
	/**
367
	 * Accesseur pour le modèle associé au médiateur
5 aperonnet 368
	 *
2 aperonnet 369
	 * @return le modèle associé
370
	 */
371
	public ImageModele getIModele() {
372
		return iModele;
373
	}
374
 
375
	/**
376
	 * Accesseur pour le panneau principal
5 aperonnet 377
	 *
2 aperonnet 378
	 * @return le panneau principal
379
	 */
380
	public Panel getPanneauPrincipalImage() {
381
		return panneauPrincipalImage;
382
	}
383
 
384
	/**
385
	 * Accesseur pour le panneau à onglets
5 aperonnet 386
	 *
2 aperonnet 387
	 * @return le panneau à onglets
388
	 */
389
	public TabPanel getOngletsImage() {
390
		return ongletsImage;
391
	}
392
 
393
	/**
5 aperonnet 394
	 * Accesseur pour la galerie d'images
395
	 *
2 aperonnet 396
	 * @return la galerie d'image
397
	 */
398
	public GalerieImageVue getGalerieImage() {
399
		return galerieImage;
400
	}
401
 
402
	public ListeImageVue getListeImage() {
403
		return listeImage;
404
	}
405
 
406
	/**
407
	 * Accesseur pour le panneau "zoom"
5 aperonnet 408
	 *
2 aperonnet 409
	 * @return le panneau zoom
410
	 */
411
	public ZoomImageVue getZoomImage() {
412
		return zoomImage;
413
	}
414
 
415
	/**
416
	 * Accesseur pour le panneau détails et mot clés
5 aperonnet 417
	 *
2 aperonnet 418
	 * @return le panneau détails et mots clés
419
	 */
420
	public Panel getDetailsEtMotsCles() {
421
		return detailsEtMotsCles;
422
	}
5 aperonnet 423
 
2 aperonnet 424
	/**
425
	 * Accesseur pour le booleen d'instanciation
5 aperonnet 426
	 *
2 aperonnet 427
	 * @return le booleen d'instanciation
428
	 */
429
	public static boolean isEstInstancie() {
430
		return estInstancie;
431
	}
432
 
433
	/**
434
	 * Accesseur pour la panneau contenant le menu et les onglets images
5 aperonnet 435
	 *
2 aperonnet 436
	 * @return le panneauMenuEtOngletsImage
437
	 */
438
	public Panel getPanneauMenuEtOngletsImage() {
439
		return panneauMenuEtOngletsImage;
440
	}
441
 
442
	/**
443
	 * Accesseur pour le menu image
5 aperonnet 444
	 *
2 aperonnet 445
	 * @return the menuImageVue
446
	 */
447
	public MenuImageVue getMenuImageVue() {
448
		return menuImageVue;
449
	}
450
 
451
	/**
452
	 * Accesseur pour la barre d'outils
5 aperonnet 453
	 *
2 aperonnet 454
	 * @return the barreOutilsVue
455
	 */
456
	public BarreOutilsVue getBarreOutilsVue() {
457
		return barreOutilsVue;
458
	}
459
 
460
	/**
461
	 * Accesseur pour le panneau infos et métadonnées
5 aperonnet 462
	 *
2 aperonnet 463
	 * @return the metadonneesIptcExif
464
	 */
465
	public PanneauMetadonneesVue getMetadonneesIptcExif() {
466
		return metadonneesIptcExif;
467
	}
468
 
469
	/**
470
	 * Renvoie l'index du dernier onglet sélectionné
5 aperonnet 471
	 *
2 aperonnet 472
	 * @return l'index du dernier onglet
473
	 */
474
	public int getDernierIndexOnglet() {
475
		return dernierIndexOnglet;
476
	}
5 aperonnet 477
 
2 aperonnet 478
	/**
479
	 * Accesseur pour l'arbre des filtres
5 aperonnet 480
	 *
2 aperonnet 481
	 * @return l'arbre pour filtrer les mots clés
482
	 */
5 aperonnet 483
	public ArbreMotsClesFiltreVue getFiltreMotsCles() {
484
		return filtreMotsCles;
2 aperonnet 485
	}
5 aperonnet 486
 
2 aperonnet 487
	/**
488
	 * Accesseur pour la barre de recherche
5 aperonnet 489
	 *
2 aperonnet 490
	 * @return la barre de recherche pour filtrer les commentaires
491
	 */
5 aperonnet 492
	public BarreRechercheFiltreVue getFiltreCommentaires() {
493
		return filtreCommentaires;
2 aperonnet 494
	}
5 aperonnet 495
 
2 aperonnet 496
	/**
497
	 * Renvoie la vue sélectionné par l'utilisateur
5 aperonnet 498
	 *
2 aperonnet 499
	 * @return la vue selectionnée par l'utilisateur
500
	 */
5 aperonnet 501
	public VueListable getVueSelectionnee() {
502
		Panel active = ongletsImage.getActiveTab();
503
		if (active != zoomImage) {
504
			if (active == galerieImage) {
505
				return galerieImage;
506
			} else {
507
				return listeImage;
2 aperonnet 508
			}
5 aperonnet 509
 
510
		} else {
511
			if (dernierIndexOnglet == 0) {
512
				return galerieImage;
513
			} else {
514
				return listeImage;
2 aperonnet 515
			}
5 aperonnet 516
 
2 aperonnet 517
		}
518
 
519
	}
5 aperonnet 520
 
2 aperonnet 521
	/**
522
	 * Renvoie l'identifiant de la vue en cours
5 aperonnet 523
	 *
2 aperonnet 524
	 * @return l'identifiant de la vue en cours de visualisation
525
	 */
5 aperonnet 526
	public String getIdVueSelectionnee() {
527
		Panel active = ongletsImage.getActiveTab();
528
		if (active != zoomImage) {
529
			if (active == galerieImage) {
530
				return galerieImage.getId();
531
			} else {
532
				return listeImage.getId();
2 aperonnet 533
			}
5 aperonnet 534
 
535
		} else {
536
			if (dernierIndexOnglet == 0) {
537
				return galerieImage.getId();
538
			} else {
539
				return listeImage.getId();
2 aperonnet 540
			}
5 aperonnet 541
 
2 aperonnet 542
		}
543
 
544
	}
5 aperonnet 545
 
2 aperonnet 546
	/**
5 aperonnet 547
	 * Met a jour les données provenant du modèle et synchronise les vues entre
548
	 * elles
549
	 *
550
	 * @param o
551
	 *            données de mises a jour pour les vues
552
	 * @param r
553
	 *            le refraichissable qui a demandé la mise a jour
2 aperonnet 554
	 */
5 aperonnet 555
	public void synchroniserDonneesZoomListeGalerie(Object o, Rafraichissable r) {
556
 
557
		if (o instanceof Store) {
558
 
559
			Store li = (Store) o;
560
 
561
			if (li.getCount() <= 0) {
562
				aucuneSelection();
563
			} else {
564
				selection();
2 aperonnet 565
			}
5 aperonnet 566
 
2 aperonnet 567
		}
5 aperonnet 568
 
569
		if (r != getGalerieImage()) {
570
			getGalerieImage().rafraichir(o, false);
2 aperonnet 571
		}
5 aperonnet 572
		if (r != getZoomImage()) {
573
			getZoomImage().rafraichir(o, false);
2 aperonnet 574
		}
5 aperonnet 575
		if (r != getListeImage()) {
576
			getListeImage().rafraichir(o, false);
2 aperonnet 577
		}
5 aperonnet 578
 
579
		aucuneSelection();
580
		demasquerChargement();
2 aperonnet 581
	}
5 aperonnet 582
 
2 aperonnet 583
	/**
584
	 * envoie au modèle une demande de mise a jour
5 aperonnet 585
	 *
586
	 * @param r
587
	 *            la vue demandeuse de mise a jour
2 aperonnet 588
	 */
5 aperonnet 589
	public void obtenirPhotoGalerie(Rafraichissable r) {
590
		masquerChargement();
591
		getIModele().obtenirNombrePhotoGalerie(r);
2 aperonnet 592
	}
5 aperonnet 593
 
2 aperonnet 594
	/**
595
	 * demande au modèle les métadonnées associées a une image
5 aperonnet 596
	 *
597
	 * @param r
598
	 *            la vue demandeuse de mise a jour
599
	 * @param id
600
	 *            l'identifiant de l'image
2 aperonnet 601
	 */
5 aperonnet 602
	public void obtenirMetadonnees(Rafraichissable r, String id) {
603
		getIModele().obtenirMetadonnees(r, id);
2 aperonnet 604
	}
5 aperonnet 605
 
2 aperonnet 606
	/**
607
	 * demande au modèle les ids des mots clés associés a une image
5 aperonnet 608
	 *
609
	 * @param r
610
	 *            la vue demandeuse de mise a jour
611
	 * @param id
612
	 *            l'identifiant de l'image
2 aperonnet 613
	 */
5 aperonnet 614
	public void obtenirMotsClesId(Rafraichissable r, String id) {
615
		getIModele().obtenirMotsClesId(r, id);
2 aperonnet 616
	}
5 aperonnet 617
 
2 aperonnet 618
	/**
5 aperonnet 619
	 * Envoie au modèle une demande pour obtenir l'arbre des mots clés
620
	 *
621
	 * @param r
622
	 *            le raffraichissable qui a demandé la mise à jour
2 aperonnet 623
	 */
5 aperonnet 624
	public void obtenirArbreMotsCles(Rafraichissable r) {
625
		getIModele().obtenirArbreMotCle(r);
2 aperonnet 626
	}
5 aperonnet 627
 
2 aperonnet 628
	/**
629
	 * envoie au modèle une demande de mise a jour des informations modifiables
630
	 * associées a une image
5 aperonnet 631
	 *
632
	 * @param commentaires
633
	 *            le commentaire de l'image
634
	 * @param date
635
	 *            la date modifiée par l'utilisateur
2 aperonnet 636
	 */
5 aperonnet 637
	public void mettreAJourInfo(String commentaires, String date, String note) {
638
		String ids[] = getVueSelectionnee().getIdSelectionnees();
639
 
640
		getIModele().mettreAJourCacheImage(commentaires, date, note, ids);
641
		getListeImage().mettreAjourInfos(commentaires, date, note);
2 aperonnet 642
	}
5 aperonnet 643
 
2 aperonnet 644
	/**
5 aperonnet 645
	 * Met à jour l'arbre des mots clés affichés dans le volet de droite à
646
	 * partir de l'arbre passé en paramètre
647
	 *
648
	 * @param arbreMC
649
	 *            le nouvel arbre des mots clés
2 aperonnet 650
	 */
5 aperonnet 651
	public void rafraichirArbreMotsCles(Tree arbreMC) {
652
		metadonneesIptcExif.getPanneauMotsCles().rafraichir(arbreMC, false);
653
		filtres.getMotsClesFiltre().rafraichir(arbreMC, false);
2 aperonnet 654
	}
5 aperonnet 655
 
2 aperonnet 656
	/**
5 aperonnet 657
	 * envoie au modèle une demande pour lancer le formulaire ou l'application
658
	 * d'upload
2 aperonnet 659
	 */
5 aperonnet 660
	public void uploaderImages() {
661
		getIModele().uploaderImages();
2 aperonnet 662
	}
5 aperonnet 663
 
2 aperonnet 664
	/**
5 aperonnet 665
	 * Envoie une demande au modèle pour obtenir toutes les données annexes de
666
	 * l'image (métadonnées, note, etc ...), on y centralise tous les appels a
667
	 * obtenirQuelqueChose
668
	 *
669
	 * @param imgNum
670
	 *            l'identifiant de l'image
2 aperonnet 671
	 */
5 aperonnet 672
	public void obtenirDonnes(String imgNum) {
673
		obtenirMetadonnees(metadonneesIptcExif, imgNum);
674
		obtenirMotsClesId(metadonneesIptcExif.getPanneauMotsCles(), imgNum);
675
		obtenirNote(metadonneesIptcExif.getNoteVue(), imgNum);
2 aperonnet 676
	}
5 aperonnet 677
 
2 aperonnet 678
	/**
679
	 * Envoie une demande au modèle pour obtenir la note associée à une image
5 aperonnet 680
	 *
681
	 * @param noteVue
682
	 *            le rafraichissable à qui est destiné cette information
683
	 * @param imgNum
684
	 *            l'identifiant de l'image
2 aperonnet 685
	 */
686
	private void obtenirNote(Rafraichissable r, String imgNum) {
5 aperonnet 687
 
688
		getIModele().obtenirNote(r, imgNum);
2 aperonnet 689
	}
690
 
691
	/**
5 aperonnet 692
	 * est appelé lors d'un clic de souris sur une vignette dans la galerie le
693
	 * médiateur gère alors les conséquences
694
	 *
695
	 * @param index
696
	 *            l'index du noeud dans la galerie
697
	 * @param node
698
	 *            le noeud selectionné
699
	 * @param e
700
	 *            l'object source de l'évenement
2 aperonnet 701
	 */
5 aperonnet 702
	public void clicGalerieImage(int index, Element node, EventObject e) {
703
		Record rd = getGalerieImage().getDView().getRecord(node);
2 aperonnet 704
		String imgUrl = rd.getAsString("url_image");
5 aperonnet 705
		String imgNum = rd.getAsString("num_image");
706
		String[] imgXY = getIModele().obtenirTailleImage(
707
				rd.getAsString("num_image"));
708
		String[] infosImage = { imgUrl, imgXY[0], imgXY[1], imgNum };
709
 
710
		getZoomImage().rafraichir(infosImage, false);
711
		dernierIndexOnglet = 0;
712
 
713
		if (DOM.eventGetType(e.getBrowserEvent()) == Event.ONDBLCLICK) {
714
 
2 aperonnet 715
			getOngletsImage().setActiveTab(2);
716
		}
5 aperonnet 717
 
718
		obtenirDonnes(imgNum);
719
 
2 aperonnet 720
	}
5 aperonnet 721
 
2 aperonnet 722
	/**
5 aperonnet 723
	 * est appelé lors d'un clic de souris sur un enregistrement de la liste le
724
	 * médiateur gère alors les conséquences
725
	 *
726
	 * @param rowIndex
727
	 *            le numéro de ligne selectionné
2 aperonnet 728
	 */
5 aperonnet 729
	public void clicListeImage(int rowIndex) {
730
		Record rd = getListeImage().getSelectionModel().getSelected();
2 aperonnet 731
		String imgUrl = rd.getAsString("url_image");
732
		String imgNum = rd.getAsString("num_image");
5 aperonnet 733
		String[] imgXY = getIModele().obtenirTailleImage(
734
				rd.getAsString("num_image"));
735
		String[] infosImage = { imgUrl, imgXY[0], imgXY[1], imgNum };
736
 
737
		getZoomImage().rafraichir(infosImage, false);
738
 
739
		dernierIndexOnglet = 1;
740
 
741
		obtenirDonnes(imgNum);
2 aperonnet 742
	}
5 aperonnet 743
 
2 aperonnet 744
	/**
745
	 * gestion du double clic dans la liste
5 aperonnet 746
	 *
2 aperonnet 747
	 * @param rowIndex
748
	 */
5 aperonnet 749
	public void doubleClicListeImage(int rowIndex) {
750
		clicListeImage(rowIndex);
2 aperonnet 751
		getOngletsImage().setActiveTab(2);
752
	}
5 aperonnet 753
 
2 aperonnet 754
	/**
755
	 * envoie une demande de mise a jour des données au modèle
756
	 */
5 aperonnet 757
	public void rafraichirToutesVues() {
2 aperonnet 758
		obtenirPhotoGalerie(getIModele());
759
	}
5 aperonnet 760
 
2 aperonnet 761
	/**
762
	 * montre le menu au coordonnées indiquées
5 aperonnet 763
	 *
764
	 * @param e
765
	 *            l'objet source de l'évenement
2 aperonnet 766
	 */
5 aperonnet 767
	public void montrerContextMenu(EventObject e) {
768
		menuImageVue.showAt(e.getXY());
2 aperonnet 769
	}
5 aperonnet 770
 
2 aperonnet 771
	/**
772
	 * appelé lors du double clic sur l'image agrandie
773
	 */
5 aperonnet 774
	public void doubleClicZoomImage() {
2 aperonnet 775
		getOngletsImage().setActiveTab(dernierIndexOnglet);
776
	}
5 aperonnet 777
 
2 aperonnet 778
	/**
779
	 * appelé lors du clic sur un des boutons de la zone zoom
5 aperonnet 780
	 *
781
	 * @param arg
782
	 *            le nom du bouton qui a cliqué
2 aperonnet 783
	 */
5 aperonnet 784
	public void clicBoutonZoomImage(String arg) {
785
 
786
		Store st;
787
		int selected;
788
		int storeIndex;
789
		Record nRec = null;
790
 
2 aperonnet 791
		// tout d'abord on obtient les index selectionnés suivant la vue
5 aperonnet 792
		if (getVueSelectionnee() == galerieImage) {
2 aperonnet 793
			DataView dv = getGalerieImage().getDView();
794
			st = getGalerieImage().getSt();
5 aperonnet 795
 
796
			if (st.getCount() <= 0) {
797
				return;
2 aperonnet 798
			}
5 aperonnet 799
 
2 aperonnet 800
			selected = st.indexOf(dv.getSelectedRecords()[0]);
801
			storeIndex = dv.indexOf(selected);
5 aperonnet 802
		} else {
803
			st = listeImage.getSt();
804
 
805
			if (st.getCount() <= 0) {
806
				return;
2 aperonnet 807
			}
5 aperonnet 808
 
809
			selected = st.indexOf(listeImage.getSelectionModel().getSelected());
810
			storeIndex = selected;
2 aperonnet 811
		}
5 aperonnet 812
 
813
		if (arg.equals("prev")) {
2 aperonnet 814
			// si la photo séléctionnée est la première, on passe a la
815
			// dernière
816
			if (selected == 0) {
5 aperonnet 817
				storeIndex = st.getCount() - 1;
2 aperonnet 818
				nRec = st.getAt(storeIndex);
5 aperonnet 819
 
820
			} else {
821
				storeIndex = storeIndex - 1;
2 aperonnet 822
				nRec = st.getAt(storeIndex);
823
			}
5 aperonnet 824
 
2 aperonnet 825
		}
5 aperonnet 826
 
827
		if (arg.equals("suiv")) {
2 aperonnet 828
			// si la photo selectionnée est la dernière on passe a la
829
			// première
830
			if (selected == st.getCount() - 1) {
5 aperonnet 831
 
832
				storeIndex = 0;
2 aperonnet 833
				nRec = st.getAt(0);
5 aperonnet 834
			} else {
835
				storeIndex = storeIndex + 1;
2 aperonnet 836
				nRec = st.getAt(storeIndex);
837
			}
838
		}
5 aperonnet 839
 
840
		if (nRec != null) {
841
			String imgUrl = nRec.getAsString("url_image");
842
			String imgNum = nRec.getAsString("num_image");
843
			String[] imgXY = getIModele().obtenirTailleImage(
844
					nRec.getAsString("num_image"));
845
			String[] infosImage = { imgUrl, imgXY[0], imgXY[1], imgNum };
846
			getZoomImage().rafraichir(infosImage, false);
847
 
848
			if (getGalerieImage().isRendered()) {
2 aperonnet 849
				getGalerieImage().getDView().select(storeIndex);
850
			}
5 aperonnet 851
 
852
			if (getListeImage().isRendered()) {
853
				getListeImage().getSelectionModel().selectRecords(nRec);
2 aperonnet 854
			}
5 aperonnet 855
 
856
			obtenirDonnes(imgNum);
2 aperonnet 857
		}
858
	}
859
 
860
	/**
861
	 * synchronise la selection entre la galerie et la liste
5 aperonnet 862
	 *
863
	 * @param string
864
	 *            le nom de la vue qui doit être synchronisee
2 aperonnet 865
	 */
866
	public void synchroniserSelection(String string) {
5 aperonnet 867
 
868
		if (string.equals("galerie") && getDernierIndexOnglet() != 2) {
869
			Record[] sel = getGalerieImage().getDView().getSelectedRecords();
870
			getListeImage().selectionnerEnregistrements(sel);
2 aperonnet 871
		}
5 aperonnet 872
 
873
		if (string.equals("liste") && getDernierIndexOnglet() != 0) {
874
 
875
			Record[] sel = getListeImage().getSelectionModel().getSelections();
876
			int[] ids = new int[sel.length];
877
 
878
			for (int i = 0; i < sel.length; i++) {
879
 
880
				ids[i] = getGalerieImage().getSt().indexOf(sel[i]);
881
			}
882
 
883
			getGalerieImage().selectionnerImages(ids);
2 aperonnet 884
		}
5 aperonnet 885
 
2 aperonnet 886
	}
887
 
888
	/**
5 aperonnet 889
	 * fait une demande de suppression des images (en local et en distant) des
890
	 * images selectionnees
2 aperonnet 891
	 */
892
	public void supprimerImages() {
5 aperonnet 893
 
894
		String[] ids = null;
895
 
896
		if (dernierIndexOnglet == 0) {
897
			ids = getGalerieImage().getIdSelectionnees();
898
		} else {
899
			ids = getListeImage().getIdSelectionnees();
900
		}
901
 
902
		if (ids.length > 0) {
903
 
904
			if (com.google.gwt.user.client.Window
905
					.confirm("Supprimer les images selectionnees ?")) {
906
				masquerChargement();
907
				getIModele().supprimerImages(ids);
908
				aucuneSelection();
2 aperonnet 909
			}
5 aperonnet 910
		} else {
911
			Window.alert("Impossible de supprimer : aucune image selectionnee");
2 aperonnet 912
		}
5 aperonnet 913
 
2 aperonnet 914
	}
915
 
916
	/**
5 aperonnet 917
	 * desactive les onglets de metadonnees et de zoom (dans le cas ou rien
918
	 * n'est selectionne)
2 aperonnet 919
	 */
920
	public void aucuneSelection() {
5 aperonnet 921
 
922
		if (getListeImage().getSelectionModel().getCount() <= 0
923
				&& getGalerieImage().getDView().getSelectionCount() <= 0) {
924
			getZoomImage().disable();
925
			getMetadonneesIptcExif().desactiverPanneau();
926
			getZoomImage().desactiverPanneau();
927
			setSelection(false);
2 aperonnet 928
		}
5 aperonnet 929
 
2 aperonnet 930
	}
5 aperonnet 931
 
2 aperonnet 932
	/**
5 aperonnet 933
	 * reactive les onglet metadonnees et zoom (lors d'une selection alors qu'il
934
	 * n'y en avait pas)
2 aperonnet 935
	 */
936
	public void selection() {
5 aperonnet 937
 
938
		if (!isSelection()) {
939
			getMetadonneesIptcExif().activerPanneau();
940
			getZoomImage().activerPanneau();
941
			getZoomImage().enable();
2 aperonnet 942
			setSelection(true);
943
		}
944
	}
945
 
946
	/**
5 aperonnet 947
	 * Fait apparaitre le menu contextuel de l'arbre des mots clés au niveau
948
	 * d'un noeud donné
949
	 *
950
	 * @param n
951
	 *            le noeud ou le menu doit apparaitre
952
	 * @param ev
953
	 *            l'objet contenant les données sur l'évenement
954
	 * @param te
955
	 *            l'éditeur associé à l'arbre qui permet de modifier les
956
	 *            libellés des noeuds
2 aperonnet 957
	 */
5 aperonnet 958
	public void montrerContextMenuArbre(final TreeNode n, EventObject ev,
959
			final TreeEditor te) {
960
		Menu mn = new Menu();
961
		final com.gwtext.client.widgets.menu.Item ajoutN = new Item(
962
				"Ajouter mot cle");
963
		final com.gwtext.client.widgets.menu.Item suppN = new Item(
964
				"Supprimer mot cle");
965
 
2 aperonnet 966
		mn.addItem(ajoutN);
967
		mn.addItem(suppN);
5 aperonnet 968
 
2 aperonnet 969
		mn.addListener(new MenuListenerAdapter() {
5 aperonnet 970
 
971
			public void onItemClick(BaseItem item, EventObject e) {
972
				if (item.equals(suppN)) {
973
					getMetadonneesIptcExif().getPanneauMotsCles()
974
							.supprimerNoeud(n);
2 aperonnet 975
				}
5 aperonnet 976
				if (item.equals(ajoutN)) {
977
					getMetadonneesIptcExif().getPanneauMotsCles().ajouterNoeud(
978
							n);
2 aperonnet 979
				}
980
			}
981
		});
5 aperonnet 982
 
2 aperonnet 983
		mn.showAt(ev.getXY());
5 aperonnet 984
 
2 aperonnet 985
	}
5 aperonnet 986
 
2 aperonnet 987
	/**
5 aperonnet 988
	 * Appelle le modèle pour mettre à jour la paire mot-clé / identifiant du
989
	 * mot clé
990
	 *
991
	 * @param text
992
	 *            le texte du mot clé
993
	 * @param id
994
	 *            l'identifiant du mot clé
2 aperonnet 995
	 */
996
	public void mettreAjourMotsClesId(String text, String id) {
5 aperonnet 997
 
998
		getIModele().mettreAjourMotsClesId(text, id);
999
 
2 aperonnet 1000
	}
1001
 
1002
	/**
5 aperonnet 1003
	 * Récupère les identifiants des images selectionnés et appelle le modèle
1004
	 * pour qu'il mette à jour les associations mots clés/images
1005
	 *
1006
	 * @param motsClesEnCours
1007
	 *            les mots clés à associer aux images selectionnés séparés par
1008
	 *            une ','
1009
	 * @param arbreMC
1010
	 *            l'arbre des mots clés à mettre à jour
2 aperonnet 1011
	 */
1012
	public void mettreAjourMotsCles(String motsClesEnCours, Tree arbreMC) {
5 aperonnet 1013
 
1014
		String[] ids = getGalerieImage().getIdSelectionnees();
1015
		getIModele().mettreAjourMotsCles(ids, motsClesEnCours, arbreMC);
1016
 
2 aperonnet 1017
	}
5 aperonnet 1018
 
2 aperonnet 1019
	/**
5 aperonnet 1020
	 * Appelle le médiateur pour qu'il ajoute un mot clé dans l'arbre des mots
1021
	 * clés
1022
	 *
1023
	 * @param n
1024
	 *            le noeud à ajouter à l'arbre
1025
	 * @param arbreMC
1026
	 *            le nouvel arbre de mots clés à mettre à jour
2 aperonnet 1027
	 */
5 aperonnet 1028
	public void ajouterMotCleDansArbre(TreeNode n, Tree arbreMC) {
1029
		getIModele().ajouterMotCleDansArbre(n, arbreMC);
1030
		filtres.getMotsClesFiltre().rafraichir(n, false);
1031
 
2 aperonnet 1032
	}
1033
 
1034
	/**
5 aperonnet 1035
	 * Appelle le médiateur pour qu'il supprime un mot clé et son sous arbre
1036
	 * dans l'arbre des mots clés
1037
	 *
1038
	 * @param n
1039
	 *            le noeud à supprimer
1040
	 * @param arbreMC
1041
	 *            le nouvel arbre de mots clés à mettre à jour
2 aperonnet 1042
	 */
1043
	public void supprimerMotCleDansArbre(TreeNode n, Tree arbreMC) {
5 aperonnet 1044
 
1045
		getIModele().supprimerMotCleDansArbre(n, arbreMC);
1046
		filtres.getMotsClesFiltre().rafraichir(n.getId(), false);
1047
 
2 aperonnet 1048
	}
1049
 
1050
	/**
5 aperonnet 1051
	 * Appelle le médiateur pour qu'il modifie un mot clé dans l'arbre des mots
1052
	 * clés
1053
	 *
1054
	 * @param n
1055
	 *            le noeud à modifier
1056
	 * @param arbreMC
1057
	 *            le nouvel arbre de mots clés à mettre à jour
2 aperonnet 1058
	 */
5 aperonnet 1059
	public void modifierMotCleDansArbre(TreeNode n, Tree arbreMC) {
1060
 
1061
		getIModele().modifierMotCleDansArbre(n, arbreMC);
1062
		filtres.getMotsClesFiltre().rafraichir(n, false);
1063
 
2 aperonnet 1064
	}
5 aperonnet 1065
 
2 aperonnet 1066
	/**
5 aperonnet 1067
	 * Appelle le médiateur pour qu'il déplace un mot clé et son sous arbre dans
1068
	 * l'arbre des mots clés
1069
	 *
1070
	 * @param n
1071
	 *            le noeud à déplacer
1072
	 * @param arbreMC
1073
	 *            le nouvel arbre de mots clés à mettre à jour
2 aperonnet 1074
	 */
5 aperonnet 1075
	public void deplacerMotCleDansArbre(TreeNode n, Tree arbreMC) {
1076
 
1077
		getIModele().deplacerMotCleDansArbre(n, arbreMC);
1078
		filtres.getMotsClesFiltre().rafraichir(n, false);
2 aperonnet 1079
	}
1080
 
1081
	/**
1082
	 * initialise les mots clés cochés par rapport aux images sélectionnées
1083
	 */
1084
	public void initialiserMotsCleCoches() {
5 aperonnet 1085
 
1086
		obtenirMotsClesId(metadonneesIptcExif.getPanneauMotsCles(),
1087
				getGalerieImage().getIdSelectionnees()[0]);
2 aperonnet 1088
	}
1089
 
1090
	/**
1091
	 * Appelle le modèle pour lui demander les données d'une page à afficher
5 aperonnet 1092
	 *
1093
	 * @param pageCourante
1094
	 *            le numéro de page à affciher
2 aperonnet 1095
	 */
1096
	public void changerNumeroPage(int pageCourante) {
5 aperonnet 1097
 
2 aperonnet 1098
		// on met le mesage d'attente
5 aperonnet 1099
		masquerChargement();
1100
 
2 aperonnet 1101
		// on appelle le modèle
5 aperonnet 1102
		getIModele().changerNumeroPage(pageCourante);
1103
 
2 aperonnet 1104
		// et met à jour les numéros de page dans les barre d'outils
1105
		getGalerieImage().getToolBarVue().changerPageCourante(pageCourante);
1106
		getListeImage().getToolBarVue().changerPageCourante(pageCourante);
1107
	}
5 aperonnet 1108
 
2 aperonnet 1109
	/**
1110
	 * Appelle le modèle pour qu'il change la taille de page utilisée
5 aperonnet 1111
	 *
1112
	 * @param nouvelleTaillePage
1113
	 *            la nouvelle taille de page
2 aperonnet 1114
	 */
5 aperonnet 1115
	public void changerTaillePage(int nouvelleTaillePage) {
2 aperonnet 1116
		// on met le message d'attente
5 aperonnet 1117
		masquerChargement();
1118
 
1119
		// on appelle le modèle
1120
		getIModele().changerTaillePage(nouvelleTaillePage);
1121
 
2 aperonnet 1122
		// et on met à jour la taille de page dans les barres d'outils
5 aperonnet 1123
		getGalerieImage().getToolBarVue().selectionnerTaillePage(
1124
				nouvelleTaillePage);
1125
		getListeImage().getToolBarVue().selectionnerTaillePage(
1126
				nouvelleTaillePage);
2 aperonnet 1127
	}
1128
 
1129
	/**
1130
	 * Met à jour les barre d'outils avec des nouvelles valeurs
5 aperonnet 1131
	 *
1132
	 * @param pageMax
1133
	 *            le nombre de pages
1134
	 * @param pageEncours
1135
	 *            la page en cours
1136
	 * @param taillePage
1137
	 *            la taille de page
1138
	 * @param nbElement
1139
	 *            le nombre d'élements par page
2 aperonnet 1140
	 */
5 aperonnet 1141
	public void changerPageMaxEtCourante(int pageMax, int pageEncours,
1142
			int taillePage, int nbElement) {
1143
 
1144
		int[] pages = { pageMax, pageEncours, taillePage, nbElement };
1145
		getGalerieImage().getToolBarVue().rafraichir(pages, false);
1146
		getListeImage().getToolBarVue().rafraichir(pages, false);
1147
 
2 aperonnet 1148
	}
5 aperonnet 1149
 
2 aperonnet 1150
	/**
5 aperonnet 1151
	 * Recherche l'élement actuellement affiché et affiche son message de
1152
	 * chargement
2 aperonnet 1153
	 */
5 aperonnet 1154
	public void masquerChargement() {
1155
		ExtElement masked = Ext.get(getIdVueSelectionnee());
1156
 
1157
		if (masked != null && !masked.isMasked()) {
1158
			masked.mask("Chargement", true);
1159
		}
2 aperonnet 1160
	}
5 aperonnet 1161
 
2 aperonnet 1162
	/**
5 aperonnet 1163
	 * Recherche l'élement actuellement affiché et retire son message de
1164
	 * chargement si l'était affiché
2 aperonnet 1165
	 */
5 aperonnet 1166
	public void demasquerChargement() {
1167
		ExtElement masked = Ext.get(getIdVueSelectionnee());
1168
		if (masked != null && masked.isMasked()) {
1169
			masked.unmask();
1170
		}
2 aperonnet 1171
	}
1172
 
5 aperonnet 1173
	public void afficherMenuId() {
1174
		IdVue i = new IdVue(this);
1175
		i.show();
2 aperonnet 1176
	}
5 aperonnet 1177
 
2 aperonnet 1178
	/**
5 aperonnet 1179
	 * C'est dans cette fonction que doivent être renvoyé les valeurs des
1180
	 * filtres sous forme de tableau [nom, valeur]
1181
	 *
2 aperonnet 1182
	 * @return Les noms et valeurs des filtres
1183
	 */
5 aperonnet 1184
	public String[][] renvoyerFiltres() {
1185
		String[][] valeursFiltres = filtres.renvoyerValeursAFiltrer();
2 aperonnet 1186
 
5 aperonnet 1187
		for (int i = 0; i < valeursFiltres.length; i++) {
1188
 
1189
			if(valeursFiltres[i].equals(null))
1190
			{
1191
				Window.alert("Le filtre "+i+" est nul") ;
1192
			}
1193
			else
1194
			{
1195
				if(valeursFiltres[i][0].equals(null))
1196
				{
1197
					Window.alert("Le nom du filtre "+i+" est nul") ;
1198
				}
1199
 
1200
				if(valeursFiltres[i][1].equals(null))
1201
				{
1202
					Window.alert("La valeur du filtre "+i+" est nulle") ;
1203
				}
1204
			}
1205
		}
1206
 
1207
		return valeursFiltres;
2 aperonnet 1208
	}
5 aperonnet 1209
 
2 aperonnet 1210
	/**
5 aperonnet 1211
	 * Indique si les filtres ont changés depuis la dernière requête (il faut
1212
	 * faire un OR sur le résultat de toutes les fonctions renvoyerEtatFiltre
1213
	 * s'il y a plus d'un filtre)
1214
	 *
1215
	 * @return true si au moins un des filtres a changé, false sinon
2 aperonnet 1216
	 */
5 aperonnet 1217
	public boolean getEtatFiltres() {
2 aperonnet 1218
		return (filtres.renvoyerEtatFiltre());
1219
	}
5 aperonnet 1220
 
2 aperonnet 1221
	/**
1222
	 * Accesseur pour le panneau de droite contenant les filtres
5 aperonnet 1223
	 *
2 aperonnet 1224
	 * @return le panneau contenant les filtres
1225
	 */
5 aperonnet 1226
	public PanneauFiltresVues getPanneauFiltres() {
1227
		return filtres;
2 aperonnet 1228
	}
5 aperonnet 1229
 
1230
	/**
1231
	 * ajoute les images séléctionnées dans la vue courante au tampon
1232
	 */
1233
	public void ajouterImagesSelection() {
1234
		String[] ids = getVueSelectionnee().getIdSelectionnees();
1235
		String id = "";
1236
		for (int i = 0; i < ids.length; i++) {
1237
			id += " - " + ids[i];
1238
		}
1239
		getIModele().ajouterImagesSelection(ids);
1240
 
1241
		Window.alert(ids.length + " image(s) ajoutées au tampon ");
1242
 
1243
	}
2 aperonnet 1244
 
5 aperonnet 1245
	/**
1246
	 * Affiche les ids des images contenues dans le tampon
1247
	 */
1248
	public void afficherIdSelectionImages() {
2 aperonnet 1249
 
5 aperonnet 1250
		Window.alert("Contenu du tampon : " + getIModele().renvoyerSelection());
2 aperonnet 1251
 
5 aperonnet 1252
	}
1253
 
1254
	/**
1255
	 * Renvoie les ids des images contenues dans le tampon en une seule string
1256
	 * @return une string de la forme id1, id2, id3
1257
	 */
1258
	public String renvoyerSelection() {
1259
		return getIModele().renvoyerSelection();
1260
	}
1261
 
1262
	/**
1263
	 * Vide le tampon d'images
1264
	 */
1265
	public void viderSelection() {
2 aperonnet 1266
 
5 aperonnet 1267
		getIModele().viderSelection();
1268
		Window.alert("Le tampon a été vidé ");
1269
 
1270
	}
1271
 
1272
	/**
1273
	 * Fonction appelée lors du drag 'n drop d'une image sur une observation
1274
	 * @param source la source du drag
1275
	 * @param e l'objet sur lequel on a fait le drop
1276
	 * @param data les données
1277
	 * @return une booleen indiquant le succès ou l'échec de l'opération
1278
	 */
1279
	public boolean lierImagesDD(DragSource source, EventObject e, DragData data) {
1280
 
1281
		// on peut convertir directement les données car on a testé avant le type de données
1282
		GridDragData gdd = (GridDragData)data ;
1283
		// les ids des images sont initialisées
1284
  		String idsImg = "" ;
1285
 
1286
  		// on obtient la liste des selections dans la source
1287
  		Record[] aLier =  gdd.getSelections() ;
1288
  		for (int i = 0; i < aLier.length; i++)
1289
  		{
1290
			// on les concatènes en une seule chaine
1291
  			idsImg += aLier[i].getAsString("id_image")+"," ;
1292
		}
1293
 
1294
  		MiniListeObservationVue mv = getMetadonneesIptcExif().getMiniListeObservation() ;
1295
  		// on cherche quel est la ligne sur laquelle on a fait le drop dans la la liste des observations
1296
  		int index = mv.getView().findRowIndex(e) ;
1297
  		Record rddrop = mv.getStore().getRecordAt(index) ;
1298
 
1299
  		// SI l'enregistrement existe bel et bien
1300
  		if(rddrop != null)
1301
  		{
1302
  			String idObs = rddrop.getAsString("id_obs")+"," ;
1303
  			// on lie les observations
1304
  			lierImagesObservation(idObs, idsImg) ;
1305
  		}
1306
 
1307
  		return true ;
1308
	}
1309
 
1310
	/**
1311
	 * Fonction appelée lors du drag 'n drop d'une observation sur une image
1312
	 * @param source la source du drag
1313
	 * @param e l'objet sur lequel on a fait le drop
1314
	 * @param data les données
1315
	 * @return une booleen indiquant le succès ou l'échec de l'opération
1316
	 */
1317
	public boolean lierObsDD(DragSource source, EventObject e, DragData data, String idDest) {
1318
 
1319
		// on peut convertir directement les données car on a testé avant le type de données
1320
		GridDragData gdd = (GridDragData)data ;
1321
		// les ids des images sont initialisées
1322
  		String idsObs = "" ;
1323
 
1324
  		// on obtient la liste des selections dans la source
1325
  		Record[] aLier =  gdd.getSelections() ;
1326
  		for (int i = 0; i < aLier.length; i++)
1327
  		{
1328
  			// on les concatènes en une seule chaine
1329
  			idsObs += aLier[i].getAsString("id_obs")+"," ;
1330
		}
1331
 
1332
  		Record rddrop = null ;
1333
 
1334
  		// si la destination est la galerie d'images
1335
  		if(idDest.equals(getGalerieImage().getId()))
1336
  		{
1337
  			GalerieImageVue gv = getGalerieImage() ;
1338
 
1339
  			// alors l'élément sur lequel on a fait le drop n'est pas le bon
1340
  			int index = gv.getDView().indexOf(e.getTarget()) ;
1341
  			Element el = e.getTarget() ;
1342
 
1343
  			// alors on cherche son parent tant que celui-ci n'est pas présent dans la dataview
1344
  			while(index == -1 && el != null)
1345
  			{
1346
  				index = gv.getDView().indexOf(el) ;
1347
  				el = (Element) el.getParentElement() ;
1348
  			}
1349
 
1350
  			// si on l'a trouvé, on obtient l'enregistrement qui correspond
1351
  			if(index != -1)
1352
  			{
1353
  				rddrop = gv.getSt().getAt(index) ;
1354
  			}
2 aperonnet 1355
 
5 aperonnet 1356
  		}
1357
 
1358
  		// si la destination est la liste d'images
1359
  		if(idDest.equals(getListeImage().getId()))
1360
  		{
1361
  			// on obtient directement l'enregistrement correspondant à l'élément sur lequel on a fait le drop
1362
  			ListeImageVue lv = getListeImage() ;
1363
  			int index = lv.getView().findRowIndex(e) ;
1364
  			rddrop = lv.getSt().getAt(index) ;
1365
  		}
1366
 
1367
  		// si on a bien obtenu un enregistrement
1368
  		if(rddrop != null)
1369
  		{
1370
  			// on récupère l'id de l'image et alors on appelle la fonction de liaison
1371
  			String idImg = rddrop.getAsString("id_image")+"," ;
1372
  			lierImagesObservation(idsObs, idImg) ;
1373
 
1374
  			return true ;
1375
  		}
1376
 
1377
 
1378
  		// si la destination est l'image zoomée
1379
  		if(idDest.equals(getZoomImage().getId()))
1380
  		{
1381
  			// on obtient directement l'id correspondant
1382
  			ZoomImageVue zv = getZoomImage() ;
1383
  			String idImg = zv.getIdImage() ;
1384
  			lierImagesObservation(idsObs, idImg) ;
1385
 
1386
  			return true ;
1387
  		}
1388
 
1389
  		return false ;
1390
 
2 aperonnet 1391
	}
1392
 
5 aperonnet 1393
	/**
1394
	 * Lie une ou plusieurs images à une ou plusieurs observations
1395
	 * @param idsObs les identifiants des observations séparés par des ","
1396
	 * @param idsImg les identifiants des images séparés par des ","
1397
	 */
1398
	public void lierImagesObservation(String idsObs, String idsImg)
1399
	{
1400
		// TODO: faire une vraie liaison dans la base de données avec des vraies observations
1401
		getIModele().lierImagesObervations(idsObs,idsImg) ;
1402
		//Window.alert("Les observations suivantes : "+idsObs+" seront liées aux images suivantes : "+idsImg) ;
1403
	}
2 aperonnet 1404
 
1405
}