Subversion Repositories eFlore/Applications.cel

Rev

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