Subversion Repositories eFlore/Applications.cel

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
2 aperonnet 1
package org.tela_botanica.client.vues;
2
 
56 david 3
 
4
import org.tela_botanica.client.interfaces.ListePaginable;
2 aperonnet 5
import org.tela_botanica.client.interfaces.Rafraichissable;
6
 
7
import com.gwtext.client.core.EventCallback;
8
import com.gwtext.client.core.EventObject;
9
import com.gwtext.client.core.Template;
10
import com.gwtext.client.data.Record;
11
import com.gwtext.client.data.SimpleStore;
12
import com.gwtext.client.data.Store;
13
import com.gwtext.client.widgets.Button;
14
import com.gwtext.client.widgets.Toolbar;
15
import com.gwtext.client.widgets.ToolbarButton;
16
import com.gwtext.client.widgets.ToolbarTextItem;
17
import com.gwtext.client.widgets.event.ButtonListenerAdapter;
18
import com.gwtext.client.widgets.form.ComboBox;
19
import com.gwtext.client.widgets.form.Field;
20
import com.gwtext.client.widgets.form.TextField;
21
import com.gwtext.client.widgets.form.event.ComboBoxListenerAdapter;
22
import com.gwtext.client.widgets.form.event.TextFieldListenerAdapter;
23
 
24
/**
5 aperonnet 25
 * Barre de pagination asynchrone avec filtrage des touches et accès directs et
26
 * séquentiels à une page
27
 *
2 aperonnet 28
 * @author aurelien
5 aperonnet 29
 *
2 aperonnet 30
 */
59 david 31
public class BarrePaginationVue extends Toolbar implements Rafraichissable {
5 aperonnet 32
 
2 aperonnet 33
	/**
34
	 * Instance du médiateur à qui on notifie les évnènements
35
	 */
56 david 36
	private ListePaginable listePaginable = null;
5 aperonnet 37
 
2 aperonnet 38
	/**
39
	 * Bouton précédent
40
	 */
5 aperonnet 41
	private ToolbarButton prevPage = new ToolbarButton();
2 aperonnet 42
	/**
43
	 * Bouton suivant
44
	 */
5 aperonnet 45
	private ToolbarButton suivPage = new ToolbarButton();
2 aperonnet 46
	/**
5 aperonnet 47
	 * Numéro de la page courante (attention, commence à zéro pour des raisons
48
	 * pratiques)
2 aperonnet 49
	 */
5 aperonnet 50
	private int pageCourante = 0;
2 aperonnet 51
	/**
52
	 * Nombre de page total
53
	 */
5 aperonnet 54
	private int pageTotale = 1;
2 aperonnet 55
	/**
56
	 * Nombre d'élements total
57
	 */
5 aperonnet 58
	private int nbElement = 0;
2 aperonnet 59
	/**
60
	 * Nombre d'élément par page
61
	 */
5 aperonnet 62
	private int taillePage = 0;
2 aperonnet 63
	/**
64
	 * Texte statique de la toolbar 1
65
	 */
5 aperonnet 66
	private ToolbarTextItem page = new ToolbarTextItem("Page ");
2 aperonnet 67
	/**
68
	 * Affichage de la page courante
69
	 */
5 aperonnet 70
	private TextField champPage = new TextField("" + (pageCourante + 1));
2 aperonnet 71
	/**
72
	 * Affichage de "sur pageTotale "
73
	 */
5 aperonnet 74
	private ToolbarTextItem surTotalPage = new ToolbarTextItem(" sur "
75
			+ pageTotale);
2 aperonnet 76
	/**
77
	 * Texte statique de la toolbar 2
78
	 */
5 aperonnet 79
	private ToolbarTextItem afficherNbElem = new ToolbarTextItem("Afficher ");
2 aperonnet 80
	/**
5 aperonnet 81
	 * Combobox permettant de selectionner le nombre d'élements à afficher par
82
	 * page et donc de changer la variable taillePage
2 aperonnet 83
	 */
5 aperonnet 84
	private ComboBox selecteurTaillePage = new ComboBox();
59 david 85
 
60 jpm 86
	/**
87
	 * Les différents intervalles de page possibles (intialisé par défaut)
88
	 */
89
	String[] pages = { "200","100","50", "20", "10" };
59 david 90
 
60 jpm 91
	Store storeIntervalle = null ;
92
 
93
 
59 david 94
 
2 aperonnet 95
	/**
59 david 96
	 * Label indiquant le type d'element affiché
97
	 *
98
	 */
99
 
100
	private String labelElement="Elements";
101
 
102
	/**
103
	 * taille de la page par defaut
104
	 *
105
	 */
106
 
107
	private int taillePageDefaut = 50;
108
 
109
 
110
	/**
2 aperonnet 111
	 * Texte statique de la toolbar 3
112
	 */
5 aperonnet 113
	private ToolbarTextItem nbElemParPage = new ToolbarTextItem(
59 david 114
			labelElement + " par page ");
2 aperonnet 115
	/**
116
	 * Affiche l'intervalle des éléments contenus dans la page
117
	 */
59 david 118
	private ToolbarTextItem intervalleElements = new ToolbarTextItem(labelElement + " "
5 aperonnet 119
			+ pageCourante * taillePage + " sur " + nbElement);
2 aperonnet 120
 
59 david 121
 
2 aperonnet 122
	/**
56 david 123
	 * retourne la liste associé à la barre
2 aperonnet 124
	 */
56 david 125
 
126
	public ListePaginable getlistePaginable() {
127
		return listePaginable;
2 aperonnet 128
	}
5 aperonnet 129
 
130
	/***************************************************************************
2 aperonnet 131
	 * constructeur sans argument (privé car ne doit pas être utilisé)
132
	 */
133
	@SuppressWarnings("unused")
59 david 134
	private BarrePaginationVue() {
5 aperonnet 135
		super();
2 aperonnet 136
	}
5 aperonnet 137
 
2 aperonnet 138
	/**
139
	 * constructeur avec paramètres
5 aperonnet 140
	 *
141
	 * @param im
142
	 *            le médiateur à associer à la barre
2 aperonnet 143
	 */
59 david 144
	public BarrePaginationVue(ListePaginable lst) {
5 aperonnet 145
		super();
146
 
56 david 147
		listePaginable = lst;
5 aperonnet 148
 
128 aurelien 149
		// on remplit l'espace pour que l'intervalle d'élement se place à droite
150
		// de la barre
151
		addItem(intervalleElements);
152
		addSpacer();
153
		// on remplit l'espace pour que l'intervalle d'élement se place à droite
154
		// de la barre
155
		addFill();
156
 
5 aperonnet 157
		// on dispose un peu de texte et quelques espaces pour séparer les
158
		// éléments
159
		addButton(prevPage);
160
		addSpacer();
161
		addItem(page);
162
		addField(champPage);
163
		addItem(surTotalPage);
164
		addSpacer();
165
		addButton(suivPage);
166
 
167
		champPage.setWidth(30);
168
 
169
		addSpacer();
170
		addItem(afficherNbElem);
171
 
172
		prevPage.setIcon("page_prev.png");
173
		suivPage.setIcon("page_suiv.png");
174
 
60 jpm 175
		setIntervallesPages(pages) ;
5 aperonnet 176
 
177
		// le template definit ce que l'on affiche pour chaque element du store
178
		// dans la combobox
179
		final Template tp = new Template("<div class=\"x-combo-list-item\">"
180
				+ "{nb_page}" + "<div class=\"x-clear\"></div></div>");
2 aperonnet 181
		tp.compile();
5 aperonnet 182
 
183
		selecteurTaillePage.setTpl(tp);
60 jpm 184
		selecteurTaillePage.setStore(storeIntervalle);
5 aperonnet 185
		selecteurTaillePage.setEditable(false);
186
		addField(selecteurTaillePage);
59 david 187
		selecteurTaillePage.setValue(""+taillePageDefaut);
5 aperonnet 188
		selecteurTaillePage.setWidth(50);
189
		addItem(nbElemParPage);
59 david 190
 
5 aperonnet 191
 
2 aperonnet 192
		// on ajoute les différents listeners
5 aperonnet 193
		ajouterListeners();
2 aperonnet 194
	}
5 aperonnet 195
 
59 david 196
 
2 aperonnet 197
	/**
59 david 198
	 *  Texte nommant les elements pagines (Images, Observation, truc, machin etc...).
199
	 * 	@param label
200
	 */
201
 
202
	public void setLabelElement(String label) {
203
		this.labelElement = label;
204
		nbElemParPage.setText(labelElement + " par page ");
205
		intervalleElements.setText(labelElement + " " + pageCourante * taillePage + " sur " + nbElement);
206
	}
207
 
208
	public void setTaillePageParDefaut(int taille) {
209
		this.taillePageDefaut = taille;
210
		selecteurTaillePage.setValue(""+taillePageDefaut);
211
	}
212
 
60 jpm 213
	public void setIntervallesPages(String[] intervalle)
214
	{
215
		String[][] intervallesPages = new String[intervalle.length][1] ;
216
 
217
		for(int i = 0 ; i < intervalle.length ; i++)
218
		{
219
			intervallesPages[i][0] = intervalle[i] ;
220
		}
221
 
222
		storeIntervalle = new SimpleStore(new String[] { "nb_page" },
223
				intervallesPages );
224
		storeIntervalle.load();
225
		selecteurTaillePage.setStore(storeIntervalle);
226
	}
59 david 227
 
60 jpm 228
 
59 david 229
	/**
5 aperonnet 230
	 * ajoute les différents listeners nécessaires au bon fonctionnement des
231
	 * éléments de la barre de pagination
2 aperonnet 232
	 */
5 aperonnet 233
	private void ajouterListeners() {
59 david 234
 
235
 
236
 
5 aperonnet 237
		// boutons suivants et précédents
2 aperonnet 238
		prevPage.addListener(new ButtonListenerAdapter() {
239
 
240
			public void onClick(Button button, EventObject e) {
5 aperonnet 241
 
2 aperonnet 242
				// si la page courante n'est pas la première
5 aperonnet 243
				if (pageCourante > 0) {
2 aperonnet 244
					// on décrémente la page courante de 1
5 aperonnet 245
					pageCourante--;
2 aperonnet 246
					// on rafraichit l'affichage
5 aperonnet 247
					rafraichirNumeroPage();
2 aperonnet 248
					// et on notifie le médiateur de l'évenement
56 david 249
					listePaginable.changerNumeroPage(pageCourante);
5 aperonnet 250
 
2 aperonnet 251
				}
252
			}
5 aperonnet 253
		});
254
 
2 aperonnet 255
		suivPage.addListener(new ButtonListenerAdapter() {
5 aperonnet 256
 
2 aperonnet 257
			public void onClick(Button button, EventObject e) {
5 aperonnet 258
 
2 aperonnet 259
				// si la page courante n'est pas la dernière
5 aperonnet 260
				if (pageCourante < pageTotale - 1) {
2 aperonnet 261
					// on incrémente la page courante de 1
5 aperonnet 262
					pageCourante++;
2 aperonnet 263
					// on rafraichit l'affichage
5 aperonnet 264
					rafraichirNumeroPage();
2 aperonnet 265
					// et on notifie le médiateur de l'évenement
56 david 266
					listePaginable.changerNumeroPage(pageCourante);
5 aperonnet 267
 
268
				}
2 aperonnet 269
			}
5 aperonnet 270
		});
271
 
2 aperonnet 272
		champPage.addListener(new TextFieldListenerAdapter() {
273
 
274
			public void onSpecialKey(Field field, EventObject e) {
5 aperonnet 275
 
2 aperonnet 276
				// on teste si la touche entrée a été pressée
5 aperonnet 277
				if (e.getKey() == EventObject.ENTER) {
278
					int nouvellePage = pageCourante;
2 aperonnet 279
					// on teste avec parseInt si la valeur entrée est un entier
5 aperonnet 280
					try {
281
						nouvellePage = Integer
282
								.parseInt(champPage.getRawValue());
283
					}
284
					// si ce n'est pas le cas alors on remet le numéro de page
285
					// correct
286
					catch (NumberFormatException nfe) {
287
						rafraichirNumeroPage();
288
						champPage.focus(true);
289
						return;
290
					}
2 aperonnet 291
 
5 aperonnet 292
					// si la conversion reussit on verifie s'il est nécessaire
293
					// de changer de page
294
					// et si la nouvelle est comprise dans l'intervalle des
295
					// pages existantes (0..pageTotale)
296
					if (nouvellePage != pageCourante + 1 && nouvellePage > 0
297
							&& nouvellePage <= pageTotale) {
298
						// le cas échéant, on charge la nouvelle page et on
299
						// notifie le médiateur
300
						changerPageCourante(nouvellePage - 1);
56 david 301
						listePaginable.changerNumeroPage(pageCourante);
5 aperonnet 302
 
303
					} else {
304
						// sinon on reaffiche l'ancien numero de page sans rien
305
						// changer
306
						rafraichirNumeroPage();
307
						champPage.focus(true);
2 aperonnet 308
					}
309
				}
310
			}
5 aperonnet 311
 
2 aperonnet 312
			public void onFocus(Field field) {
5 aperonnet 313
 
314
				champPage.focus(true);
2 aperonnet 315
			}
5 aperonnet 316
 
2 aperonnet 317
		});
5 aperonnet 318
 
319
		// pour éviter de se compliquer la vie, on filtre tous les charactères
320
		// non numériques
2 aperonnet 321
		champPage.addKeyPressListener(new EventCallback() {
322
 
323
			public void execute(EventObject e) {
5 aperonnet 324
 
2 aperonnet 325
				// si c'est un numerique
5 aperonnet 326
				if (Character.isDigit((char) e.getCharCode())) {
2 aperonnet 327
					// on laisse passer
5 aperonnet 328
					return;
2 aperonnet 329
				}
5 aperonnet 330
 
2 aperonnet 331
				// si c'est la touche entrée ou backspace (valider ou effacer)
5 aperonnet 332
				if (e.getKey() == EventObject.ENTER
333
						|| e.getKey() == EventObject.BACKSPACE) {
2 aperonnet 334
					// on laisse passer
5 aperonnet 335
					return;
336
				} else {
337
					// sinon on remet le numero de page correct et on annule
338
					// l'évenement
339
					rafraichirNumeroPage();
340
					e.stopEvent();
2 aperonnet 341
				}
342
			}
5 aperonnet 343
 
344
		});
345
 
346
		// listener pour la selection dans la combobox
2 aperonnet 347
		selecteurTaillePage.addListener(new ComboBoxListenerAdapter() {
5 aperonnet 348
 
2 aperonnet 349
			public void onSelect(ComboBox comboBox, Record record, int index) {
5 aperonnet 350
 
351
				String nouvelleTaillePageString = comboBox.getStore()
352
						.getRecordAt(index).getAsString("nb_page");
353
				int nouvelleTaillePage = Integer
354
						.parseInt(nouvelleTaillePageString);
355
 
2 aperonnet 356
				// si la taille de page est différente de l'ancienne
5 aperonnet 357
				if (nouvelleTaillePage != taillePage) {
2 aperonnet 358
					// on la change
5 aperonnet 359
					changerTaillePage(nouvelleTaillePage);
2 aperonnet 360
				}
361
				// et on met la valeur à jour dans la combobox
5 aperonnet 362
				comboBox.setValue(nouvelleTaillePageString);
2 aperonnet 363
			}
5 aperonnet 364
 
365
		});
2 aperonnet 366
	}
5 aperonnet 367
 
2 aperonnet 368
	/**
5 aperonnet 369
	 * Met à jour les affichage sur les numéros de pages et d'intervalle
370
	 * d'éléments à partir des variables de classes
2 aperonnet 371
	 */
5 aperonnet 372
	public void rafraichirNumeroPage() {
373
		surTotalPage.setText(" sur " + pageTotale);
374
 
375
		if (nbElement == 0) {
376
			champPage.setValue("" + (0));
377
			// on met simplement à jour l'intervalle qui contient toujours le
378
			// même nombre d'éléments
59 david 379
			intervalleElements.setText(labelElement + " 0 - 0 sur 0");
5 aperonnet 380
		} else {
381
			champPage.setValue("" + (pageCourante + 1));
382
 
383
			// si la page n'est pas la dernière
384
			if (pageCourante + 1 != pageTotale) {
385
				// sauf pour la dernière page qui contient souvent moins
386
				// d'élements que le nombre d'élements par page
59 david 387
				intervalleElements.setText(labelElement + " " + pageCourante
5 aperonnet 388
						* taillePage + " - " + (pageCourante + 1) * taillePage
389
						+ " sur " + nbElement);
390
			} else {
391
				// on met simplement à jour l'intervalle qui contient toujours
392
				// le même nombre d'éléments
59 david 393
				intervalleElements.setText(labelElement + " " + pageCourante
5 aperonnet 394
						* taillePage + " - " + nbElement + " sur " + nbElement);
395
			}
2 aperonnet 396
		}
397
	}
5 aperonnet 398
 
2 aperonnet 399
	/**
5 aperonnet 400
	 * Met à jour la page en cours
401
	 *
402
	 * @param nouvellePageCourante
403
	 *            la nouvelle page en cours
2 aperonnet 404
	 */
5 aperonnet 405
	public void changerPageCourante(int nouvellePageCourante) {
406
		pageCourante = nouvellePageCourante;
2 aperonnet 407
	}
5 aperonnet 408
 
2 aperonnet 409
	/**
410
	 * Methode héritée de l'interface rafraichissable
411
	 */
412
	public void rafraichir(Object nouvelleDonnees,
413
			boolean repandreRaffraichissement) {
5 aperonnet 414
 
2 aperonnet 415
		// si on reçoit un tableau de int
5 aperonnet 416
		if (nouvelleDonnees instanceof int[]) {
417
			int[] page = (int[]) nouvelleDonnees;
418
			// le premier élement est le nombre de pages totales
419
			pageTotale = page[0];
2 aperonnet 420
			// le second la page en cours
5 aperonnet 421
			pageCourante = page[1];
2 aperonnet 422
			// le troisième la taille de la page
5 aperonnet 423
			taillePage = page[2];
2 aperonnet 424
			// et le dernier le nombre total d'éléments
5 aperonnet 425
			nbElement = page[3];
426
 
427
			// si la page courante dépasse la page totale (cas normalement
428
			// improbable car géré en amont)
429
			// on met le numéro de page à la page courante -1 (car la page
430
			// courante est comptée à partir
2 aperonnet 431
			// de zéro)
5 aperonnet 432
			if (pageCourante >= pageTotale && pageCourante != 0) {
433
				pageCourante = pageTotale - 1;
2 aperonnet 434
				// le cas échéant on en notifie le médiateur
56 david 435
				listePaginable.changerNumeroPage(pageCourante);
2 aperonnet 436
			}
437
		}
5 aperonnet 438
 
439
		// enfin on rafraichit les informations affichées à partir des nouvelles
440
		// variables de classes mises à jour
441
		rafraichirNumeroPage();
2 aperonnet 442
	}
5 aperonnet 443
 
2 aperonnet 444
	/**
445
	 * Renvoie les différents intervalles de pages possibles
5 aperonnet 446
	 *
60 jpm 447
	 * @return un tableau de string qui contient les différentes
5 aperonnet 448
	 *         taille de pages
2 aperonnet 449
	 */
60 jpm 450
	public String[] getNbPages() {
5 aperonnet 451
 
452
		return pages;
2 aperonnet 453
	}
454
 
455
	/**
5 aperonnet 456
	 * Envoie au médiateur une demande pour modifier la taille de la page (qui
457
	 * va à son tour faire les modifications nécessaires)
458
	 *
459
	 * @param nouvelleTaillePage
460
	 *            la nouvelle taille de page (élement appartenant au tableau
461
	 *            renvoyé par getNbPages())
2 aperonnet 462
	 */
463
	public void changerTaillePage(int nouvelleTaillePage) {
5 aperonnet 464
 
56 david 465
		listePaginable.changerTaillePage(nouvelleTaillePage);
5 aperonnet 466
 
2 aperonnet 467
	}
5 aperonnet 468
 
2 aperonnet 469
	/**
5 aperonnet 470
	 * Selectionne la valeur correspond à celle passée en paramètre dans la
471
	 * combobox (si elle existe)
472
	 *
473
	 * @param nouvelleTaillePage
474
	 *            la nouvelle taille de page
2 aperonnet 475
	 */
476
	public void selectionnerTaillePage(int nouvelleTaillePage) {
5 aperonnet 477
 
478
		selecteurTaillePage.setValue("" + nouvelleTaillePage);
2 aperonnet 479
	}
5 aperonnet 480
 
2 aperonnet 481
}