Subversion Repositories eFlore/Applications.cel

Rev

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