Subversion Repositories eFlore/Applications.cel

Rev

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