Subversion Repositories eFlore/Applications.cel

Rev

Rev 68 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
12 david 1
package org.tela_botanica.client.vues;
2
 
3
 
46 david 4
import java.util.Iterator;
5
 
6
import org.tela_botanica.client.modeles.ListeObservation;
7
import org.tela_botanica.client.modeles.Observation;
12 david 8
import org.tela_botanica.client.observation.ObservationMediateur;
59 david 9
import org.tela_botanica.client.interfaces.ListePaginable;
12 david 10
import org.tela_botanica.client.interfaces.Rafraichissable;
11
import org.tela_botanica.client.interfaces.VueListable;
12
 
70 david 13
import com.google.gwt.user.client.Window;
41 jpm 14
import com.gwtext.client.core.EventObject;
12 david 15
import com.gwtext.client.core.Ext;
16
import com.gwtext.client.core.ExtElement;
46 david 17
import com.gwtext.client.data.ArrayReader;
12 david 18
import com.gwtext.client.data.FieldDef;
46 david 19
import com.gwtext.client.data.MemoryProxy;
12 david 20
import com.gwtext.client.data.Record;
21
import com.gwtext.client.data.RecordDef;
22
import com.gwtext.client.data.Store;
23
import com.gwtext.client.data.StringFieldDef;
24
import com.gwtext.client.widgets.Component;
25
import com.gwtext.client.widgets.event.ContainerListenerAdapter;
41 jpm 26
import com.gwtext.client.widgets.grid.CellMetadata;
12 david 27
import com.gwtext.client.widgets.grid.ColumnConfig;
28
import com.gwtext.client.widgets.grid.ColumnModel;
29
import com.gwtext.client.widgets.grid.GridPanel;
41 jpm 30
import com.gwtext.client.widgets.grid.Renderer;
31
import com.gwtext.client.widgets.grid.event.GridRowListenerAdapter;
12 david 32
 
33
/**
34
 * Liste d'observation composée de ligne d'observation
35
 * l'interface rafraichissable et l'interface vueListable
36
 *
37
 * @author David Delon 2008
38
 */
39
public class ListeObservationVue extends GridPanel implements Rafraichissable,
59 david 40
		VueListable, ListePaginable {
12 david 41
 
42
	/**
43
	 * Le médiateur associé à la vue
44
	 */
45
	private ObservationMediateur	observationMediateur		= null;
46
 
47
 
48
	/**
49
	 * Config de colonne
50
	 */
51
	private ColumnConfig	etatObservation;
52
	/**
53
	 * Config de colonne
54
	 */
55
	private ColumnConfig	nomSaisiObservation;
56
	/**
57
	 * Config de colonne
58
	 */
59
	private ColumnConfig	nomRetenuObservation;
60
	/**
61
	 * Config de colonne
62
	 */
63
	private ColumnConfig	lieuObservation;
64
	/**
65
	 * Config de colonne
66
	 */
67
	private ColumnConfig	dateObservation;
68
	/**
69
	 * Config de colonne
70
	 */
71
	private ColumnConfig	ordreObservation;
72
	/**
73
	 * Modele de colonnes
74
	 */
75
	private ColumnModel		modeleColonnes;
76
 
77
	/**
78
	 * Store qui contient les données à afficher
79
	 */
80
	private Store			st				= null;
81
 
82
 
83
	/**
84
	 * Barre de pagination
85
	 */
59 david 86
	private BarrePaginationVue bt = null ;
12 david 87
 
46 david 88
 
89
 
12 david 90
	/**
46 david 91
	 * Numéro de page en cours
92
	 */
93
	private int pageEncours = 0 ;
94
	/**
95
	 * Nombre de pages totales
96
	 */
97
	private int pageMax = 1 ;
98
	/**
99
	 * Taille de page (par défaut 20)
100
	 */
101
	private int taillePage = 20 ;
102
	/**
103
	 * Nombre d'éléments total correspondant à la requete
104
	 */
105
	private int nbElements = 0 ;
106
 
107
 
108
 
109
	/**
12 david 110
	 * Constructeur sans arguments (privé car ne doit pas être utilisé)
111
	 */
59 david 112
	@SuppressWarnings("unused")
12 david 113
	private ListeObservationVue()
114
	{
115
		super() ;
116
	}
117
 
118
	/**
119
	 * Constructeur avec argument
120
	 * @param im le médiateur à associer
121
	 */
122
	public ListeObservationVue(ObservationMediateur obs) {
123
 
124
		this.observationMediateur = obs;
125
 
126
		setHeader(true);
53 david 127
 
12 david 128
 
129
		// on place la barre de pagination
59 david 130
		bt = new BarrePaginationVue(this);
131
		bt.setLabelElement("Observations");
132
		bt.setTaillePageParDefaut(20);
60 jpm 133
		bt.setIntervallesPages(new String[] {"400","200",  "100" , "50" , "20"}) ;
12 david 134
		this.setBottomToolbar(bt) ;
135
 
136
		// on construit le modèle de colonnes
137
 
138
		// Le store suivant est ensuite remplacé par le store contenant les données obtenus depuis le serveur (cf rafraichir)
139
 
41 jpm 140
		Renderer colRend = new Renderer() {
141
 
142
			public String render(Object value, CellMetadata cellMetadata,
143
					Record record, int rowIndex, int colNum, Store store) {
144
 
145
				if(value == null || value.equals("null") || value.equals("000null") || value.equals("0000-00-00 00:00:00")) {
146
 
147
					return "" ;
148
				}
149
				else
150
				{
151
 
152
				}
153
 
154
				return value.toString() ;
155
			}
156
 
157
		} ;
12 david 158
 
42 jpm 159
		etatObservation = new ColumnConfig("Transmis", "etat_observation", 60, true, new Renderer() {
41 jpm 160
 
161
			public String render(Object value, CellMetadata cellMetadata,
162
					Record record, int rowIndex, int colNum, Store store) {
163
				if(value.equals("1"))
164
				{
165
					return "<input type=\"checkbox\" checked =\"checked\" disabled=\"disabled\" />" ;
166
				}
167
				else
168
				{
169
					return "" ;
170
				}
171
			}
172
 
173
		});
174
		nomSaisiObservation = new ColumnConfig("Nom saisi", "nomSaisi_observation", 200, true, colRend);
175
		nomRetenuObservation = new ColumnConfig("Nom retenu", "nomRetenu_observation", 200, true, colRend);
176
		lieuObservation = new ColumnConfig("Lieu", "lieu_observation", 200, true, colRend);
42 jpm 177
		dateObservation = new ColumnConfig("Date", "date_observation", 120, true, colRend);
41 jpm 178
		ordreObservation = new ColumnConfig("Ordre", "ordre_observation", 50, true, colRend);
42 jpm 179
 
12 david 180
 
181
		// on associe le modèle de colonnes
182
 
183
		ColumnConfig[] cm = {etatObservation, nomSaisiObservation, nomRetenuObservation, lieuObservation, dateObservation, ordreObservation};
184
 
185
		modeleColonnes = new ColumnModel(cm);
186
 
187
		this.setColumnModel(modeleColonnes);
188
 
189
		this.setAutoScroll(true);
190
		this.setEnableColumnResize(true);
191
 
46 david 192
		//temp dd viewport desactive ajout de ces 2 lignes
53 david 193
	//	this.setAutoWidth(true);
46 david 194
		// temp
195
 
12 david 196
		// creation du store
52 david 197
 
12 david 198
		FieldDef defEtatObservation = new StringFieldDef("etat_observation");
199
		FieldDef defNomSaisiObservation = new StringFieldDef("nomSaisi_observation");
200
		FieldDef defNomRetenuObservation = new StringFieldDef("nomRetenu_observation");
201
		FieldDef defLieuObservation = new StringFieldDef("lieu_observation");
202
		FieldDef defDateObservation = new StringFieldDef("date_observation");
203
		FieldDef defOrdreObservation = new StringFieldDef("ordre_observation");
204
 
205
 
206
		FieldDef[] defTab = { defEtatObservation, defNomSaisiObservation, defNomRetenuObservation,
207
				defLieuObservation, defDateObservation, defOrdreObservation };
208
 
209
		RecordDef rd = new RecordDef(defTab);
210
		st = new Store(rd);
211
 
212
		// on associe le store
213
 
214
		this.setStore(st);
215
		this.getView().setAutoFill(true);
42 jpm 216
		this.getView().setForceFit(true) ;
12 david 217
 
218
		// on crée un masque de chargement qui s'affichera lors des mises à jour
219
		this.setLoadMask("Chargement");
220
 
221
		// on ajoute les listeners
222
		ajouterListeners();
223
 
224
 
225
	}
226
 
227
 
228
	/**
229
	 * Ajoute les listeners pour la gestion des évènements
230
	 */
231
	private void ajouterListeners() {
232
		this.addListener(new ContainerListenerAdapter() {
233
 
234
 
235
			public void onHide(Component component) {
236
 
237
			}
238
 
239
 
240
			public void onRender(Component component) {
241
 
242
			}
243
 
244
 
245
			public void onShow(Component component) {
42 jpm 246
 
12 david 247
			}
248
 
249
		});
250
 
41 jpm 251
 
252
		this.addGridRowListener(new GridRowListenerAdapter() {
12 david 253
 
254
			// gestion du clic sur une ligne
41 jpm 255
			public void onRowClick(GridPanel grid, int rowIndex,
256
					EventObject e) {
12 david 257
				// on notifie le médiateur et on lui passe le nuémro de ligne
54 david 258
				observationMediateur.clicListeObservation(rowIndex);
41 jpm 259
 
12 david 260
			}
41 jpm 261
 
12 david 262
			// gestion du clic droit
263
			public void onRowContextMenu(GridPanel grid, int rowIndex,
264
					EventObject e) {
265
				// on stoppe l'évenement pour empecher le navigateur d'afficher son propre menu
266
				e.stopEvent() ;
267
				// on notifie le médiateur en lui passant l'évenement
54 david 268
				observationMediateur.montrerContextMenu(e);
12 david 269
			}
270
 
271
			// gestion du double clic
272
			public void onRowDblClick(GridPanel grid, int rowIndex,
273
					EventObject e) {
274
				// on notifie le médiateur en lui passant le numéro de ligne
54 david 275
				observationMediateur.doubleClicListeObservation(rowIndex);
12 david 276
			}
41 jpm 277
 
12 david 278
		});
279
 
41 jpm 280
 
281
		/*this.getSelectionModel().addListener(new RowSelectionListenerAdapter() {
12 david 282
 
283
			// gestion de la sélection
284
 
285
			public void onSelectionChange(RowSelectionModel sm) {
286
 
287
				// si on a rien de sélectionné
288
				if (sm.getCount() <= 0) {
289
					// on notifie le médiateur (qui désactive notamment l'accès à certaines infos)
290
		//			getobservationMediateur().aucuneSelection();
291
				} else {
292
					// sinon on notifie le médiateur
293
			//		getobservationMediateur().selection();
294
					// et on lui demande de synchroniser la selection avec les autres vues
295
				//	getobservationMediateur().synchroniserSelection("liste");
296
				}
297
			}
41 jpm 298
		});*/
12 david 299
	}
300
 
301
	/**
302
	 * Méthode héritée de l'interface VueListable
303
	 * Sélectionne les observations  dans la liste suivant les identifiants donnés en paramètres
304
	 */
305
 
306
	public String[] getIdSelectionnees() {
307
 
308
		Record[] selection = this.getSelectionModel().getSelections();
309
		int taille = selection.length;
310
		String id_selection[] = new String[taille];
311
 
312
		for (int i = 0; i < selection.length; i++) {
313
 
314
			id_selection[i] = selection[i].getAsString("ordre_observation");
315
		}
316
 
317
		return id_selection;
318
	}
319
 
320
 
321
 
322
	/**
323
	 * Sélectionne des enregistrements donné
324
	 * @param sel un tableau d'enregistrement à selectionner
325
	 */
326
	public void selectionnerEnregistrements(Record[] sel) {
327
 
328
			getSelectionModel().clearSelections();
329
			getSelectionModel().selectRecords(sel);
330
 
331
	}
332
 
333
	/**
334
	 * Accesseur pour la toolbar de pagination
335
	 * @return la toolbar de pagination
336
	 */
337
 
59 david 338
	public BarrePaginationVue getToolBarVue()
12 david 339
	{
340
		return bt ;
341
	}
342
 
343
 
344
	/**
345
	 * Recherche l'élement actuellement affiché et affiche son message de chargement
346
	 */
347
	public void masquerChargement()
348
	{
349
			ExtElement masked = Ext.get(getId()) ;
350
 
52 david 351
 
12 david 352
			if (masked!=null) {
353
				masked.mask("Chargement") ;
354
			}
355
 
356
	}
357
 
358
	/**
359
	 * Recherche l'élement actuellement affiché et retire son message de chargement si l'était affiché
360
	 */
361
	public void demasquerChargement()
362
	{
363
			ExtElement masked = Ext.get(getId()) ;
364
 
52 david 365
 
12 david 366
			if (masked!=null) {
367
 
368
				if(masked.isMasked())
369
				{
370
					masked.unmask() ;
371
				}
372
			}
373
	}
374
 
375
 
54 david 376
 
46 david 377
	/**
378
	 * Méthode héritée de l'interface rafraichissable
379
	 * @param nouvelleDonnees les nouvelles données
380
	 * @param repandreRafraichissement le booleen de notification du rafraichissement
381
	 */
382
 
12 david 383
 
46 david 384
 
385
	public void rafraichir(Object nouvelleDonnees, boolean repandreRafraichissement) {
386
 
387
 
388
 
389
 
390
//		 si l'on a reçu une liste d'observation
391
		if(nouvelleDonnees instanceof ListeObservation)
392
		{
393
 
394
				ListeObservation data = (ListeObservation) nouvelleDonnees ;
54 david 395
				Object[][] observationData = new Object[data.size()][7];
46 david 396
				int i = 0 ;
397
 
398
				if(data.size() == 0)
399
				{
400
					pageEncours = 0 ;
401
				}
402
 
54 david 403
				// on la parse et on récupère les informations qui nous interessent
46 david 404
				for (Iterator it = data.keySet().iterator(); it.hasNext();)
405
				{
406
 
407
					Observation obs=(Observation) data.get(it.next());
408
 
409
					observationData[i][0]= obs.getTransmis();
410
					observationData[i][1]= obs.getNomSaisi();
411
					observationData[i][2]= obs.getNomRetenu();
412
					observationData[i][3]= obs.getLieudit();
413
					observationData[i][4]= obs.getDate();
414
					observationData[i][5]= obs.getNumeroOrdre();
54 david 415
					observationData[i][6]= obs.getNumeroNomenclaturalSaisi();
46 david 416
 
417
 
418
					i++ ;
419
				}
420
 
421
				// creation du store qui les contient
422
 
423
				FieldDef defEtatObservation = new StringFieldDef("etat_observation");
424
				FieldDef defNomSaisiObservation = new StringFieldDef("nomSaisi_observation");
425
				FieldDef defNomRetenuObservation = new StringFieldDef("nomRetenu_observation");
426
				FieldDef defLieuObservation = new StringFieldDef("lieu_observation");
427
				FieldDef defDateObservation = new StringFieldDef("date_observation");
428
				FieldDef defOrdreObservation = new StringFieldDef("ordre_observation");
429
 
54 david 430
				// Non affiches :
431
				FieldDef defNumeroNomenclaturalSaisiObservation = new StringFieldDef("numeroNomenclaturalSaisi_observation");
432
 
433
 
46 david 434
				// on associe le store
435
 
436
				FieldDef[] defTab = { defEtatObservation, defNomSaisiObservation, defNomRetenuObservation,
54 david 437
						defLieuObservation, defDateObservation, defOrdreObservation, defNumeroNomenclaturalSaisiObservation };
46 david 438
 
439
				RecordDef rd = new RecordDef(defTab);
440
 
441
				final MemoryProxy dataProxy = new MemoryProxy(observationData);
442
				final ArrayReader reader = new ArrayReader(rd);
443
 
444
				final Store observationStore = new Store(dataProxy, reader);
445
 
446
 
447
				st = observationStore ;
448
				st.load() ;
449
 
450
 
451
				// et on reconfigure et rafraichit la vue
452
				this.reconfigure(st, this.getColumnModel());
453
 
454
				demasquerChargement();
455
 
63 jpm 456
				observationMediateur.donneesRafraichies(nouvelleDonnees) ;
46 david 457
 
68 david 458
//TODO : a ce niveau ?
459
				if (repandreRafraichissement) {
460
					observationMediateur.obtenirListeEntiteGeographique();
461
				}
462
 
46 david 463
		}
464
 
465
 
466
		// Si on reçoit un tableau d'entiers
467
		// c'est un tableau d'un seul entier qui est le nombre d'observation correspondant aux critères
468
		if(nouvelleDonnees instanceof int[])
469
		{
470
			int[] pages = (int[])nouvelleDonnees ;
471
 
472
			// on calcule le nombre de pages nécessaires et on les met à jour dans le modèle
473
			pageMax  = calculerNbPages(pages[0]) ;
474
			nbElements = pages[0] ;
475
 
52 david 476
 
46 david 477
			// et on notifie de le mediateur du changement des valeurs
51 david 478
			changerPageMaxEtCourante(pageMax,pageEncours,taillePage,pages[0]) ;
46 david 479
 
54 david 480
			masquerChargement();
46 david 481
			observationMediateur.obtenirListeObservation();
482
		}
483
 
484
 
485
//		 si l'on a reçu une Observation, qui vient d'être cree on lance un raffraichissement
486
 
487
		if(nouvelleDonnees instanceof Observation) {
488
 
52 david 489
			// On affiche la dernière page
490
 
491
			pageEncours = pageMax ;
54 david 492
			masquerChargement();
493
 
46 david 494
			observationMediateur.obtenirNombreObservation();
495
 
496
		}
497
	}
51 david 498
 
499
 
500
	// GESTION DE LA PAGINATION
46 david 501
 
502
 
503
	/**
504
	 * Calcule le nombre de pages nécessaires pour afficher un nombre d'élements donnés en fonction de la taille de page
505
	 * en cours
506
	 * @param nbElements le nombre d'élements total
507
	 * @return le nombre de pages
508
	 */
509
	public int calculerNbPages(int nbElements)
510
	{
511
		// A cause de la betise de java pour les conversion implicite on fait quelques conversions manuellement
512
		// pour eviter qu'il arrondisse mal la division
513
		// nombre de pages = (nombre d'element / taille de la page) arrondie à l'entier superieur
514
 
515
		double nPage = (1.0*nbElements)/(1.0*taillePage) ;
516
		double nPageRound = Math.ceil(nPage) ;
517
		Double nPageInt = new Double(nPageRound) ;
518
 
519
		// on convertit en entier
520
		return nPageInt.intValue() ;
521
	}
522
 
523
 
524
	/**
525
	 * Recalcule la page en cours lors du changement du nombre d'élements
526
	 * @param nbElements le nombre d'élements total
527
	 * @return la nouvelle page encours
528
	 */
529
	public int calculerPageCourante(int nbElements)
530
	{
531
		// on calcule le nombre de page
532
		int nouvelNbPages = calculerNbPages(nbElements) ;
533
		// la nouvelle page en cours
534
		double nPageCourante = (1.0*pageEncours)/(1.0*pageMax) * (1.0*nouvelNbPages) ;
535
 
536
		// on arrondit au supérieur
537
		double nPageRound = Math.ceil(nPageCourante) ;
538
		Double nPageInt = new Double(nPageRound) ;
539
 
540
		// on convertit en entier
541
		return Math.abs(nPageInt.intValue()) ;
542
	}
543
 
544
 
545
	/**
546
	 * Appelle le modèle pour lui demander les données d'une page à afficher
547
	 * @param pageCourante le numéro de page à affciher
548
	 */
549
	public void changerNumeroPage(int pageCourante) {
550
 
551
 
552
 
553
		pageEncours = pageCourante ;
554
 
54 david 555
		masquerChargement();
556
 
46 david 557
		// On lance le chargerment des observations
558
		observationMediateur.obtenirNombreObservation();
559
 
560
		getToolBarVue().changerPageCourante(pageCourante);
561
 
562
	}
563
 
564
 
565
	/**
566
	 * Appelle le modèle pour qu'il change la taille de page utilisée
567
	 * @param nouvelleTaillePage la nouvelle taille de page
568
	 */
569
 
570
	public void changerTaillePage(int nouvelleTaillePage)
571
	{
572
 
573
		taillePage = nouvelleTaillePage ;
574
		pageEncours = calculerPageCourante(nbElements) ;
575
 
54 david 576
		masquerChargement();
577
 
61 jpm 578
		// 	On lance le chargement des observations
46 david 579
		observationMediateur.obtenirNombreObservation();
580
 
581
 
582
		// et on met à jour la taille de page dans les barres d'outils
583
		getToolBarVue().selectionnerTaillePage(nouvelleTaillePage);
584
 
585
 
586
	}
587
 
588
 
51 david 589
	/**
590
	 * Met à jour les barre d'outils avec des nouvelles valeurs
591
	 * @param pageMax le nombre de pages
592
	 * @param pageEncours la page en cours
593
	 * @param taillePage la taille de page
594
	 * @param nbElement le nombre d'élements par page
595
	 */
596
	public void changerPageMaxEtCourante(int pageMax, int pageEncours, int taillePage, int nbElement)
597
	{
598
 
599
		int[] pages = {pageMax,pageEncours, taillePage, nbElement} ;
600
		getToolBarVue().rafraichir(pages, false) ;
601
 
602
	}
46 david 603
 
61 jpm 604
	/**
605
	 * Renvoie la taille de page en cours d'utilisation
606
	 * @return la taille de page
607
	 */
46 david 608
	public int getTaillePage() {
609
 
610
		return taillePage;
611
	}
61 jpm 612
 
613
	/**
614
	 * Renvoie le numéro de la page encours (attention on commence à 0)
615
	 * @return le numéro de la page en cours
616
	 */
46 david 617
	public int getPageEncours() {
618
 
619
		return pageEncours;
620
	}
621
 
622
 
12 david 623
}