Subversion Repositories eFlore/Applications.cel

Rev

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