Subversion Repositories eFlore/Applications.cel

Rev

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