Subversion Repositories eFlore/Applications.cel

Rev

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