Subversion Repositories eFlore/Applications.cel

Rev

Details | Last modification | View Log | RSS feed

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