Subversion Repositories eFlore/Applications.cel

Rev

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