Subversion Repositories eFlore/Applications.cel

Rev

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