Subversion Repositories eFlore/Applications.coel

Rev

Rev 843 | Rev 1066 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
61 jpm 1
package org.tela_botanica.client.composants;
2
 
66 jpm 3
import org.tela_botanica.client.ComposantId;
4
import org.tela_botanica.client.RegistreId;
907 jpm 5
import org.tela_botanica.client.configuration.Configuration;
498 jp_milcent 6
import org.tela_botanica.client.images.Images;
324 jp_milcent 7
import org.tela_botanica.client.modeles.Information;
66 jpm 8
import org.tela_botanica.client.modeles.Menu;
543 jp_milcent 9
import org.tela_botanica.client.util.Pattern;
311 jp_milcent 10
import org.tela_botanica.client.util.Print;
66 jpm 11
 
498 jp_milcent 12
import com.extjs.gxt.ui.client.event.Events;
66 jpm 13
import com.extjs.gxt.ui.client.Registry;
543 jp_milcent 14
import com.extjs.gxt.ui.client.Style.ButtonScale;
61 jpm 15
import com.extjs.gxt.ui.client.Style.LayoutRegion;
66 jpm 16
import com.extjs.gxt.ui.client.Style.Scroll;
498 jp_milcent 17
import com.extjs.gxt.ui.client.event.ButtonEvent;
66 jpm 18
import com.extjs.gxt.ui.client.event.Listener;
69 jpm 19
import com.extjs.gxt.ui.client.event.SelectionListener;
498 jp_milcent 20
import com.extjs.gxt.ui.client.event.TreePanelEvent;
66 jpm 21
import com.extjs.gxt.ui.client.store.Store;
22
import com.extjs.gxt.ui.client.store.TreeStore;
61 jpm 23
import com.extjs.gxt.ui.client.util.Margins;
24
import com.extjs.gxt.ui.client.widget.ContentPanel;
25
import com.extjs.gxt.ui.client.widget.Dialog;
66 jpm 26
import com.extjs.gxt.ui.client.widget.HtmlContainer;
324 jp_milcent 27
import com.extjs.gxt.ui.client.widget.Info;
343 jp_milcent 28
import com.extjs.gxt.ui.client.widget.LayoutContainer;
498 jp_milcent 29
import com.extjs.gxt.ui.client.widget.form.StoreFilterField;
61 jpm 30
import com.extjs.gxt.ui.client.widget.button.Button;
31
import com.extjs.gxt.ui.client.widget.layout.BorderLayout;
32
import com.extjs.gxt.ui.client.widget.layout.BorderLayoutData;
343 jp_milcent 33
import com.extjs.gxt.ui.client.widget.layout.FlowLayout;
34
import com.extjs.gxt.ui.client.widget.layout.FormLayout;
543 jp_milcent 35
import com.extjs.gxt.ui.client.widget.toolbar.ToolBar;
498 jp_milcent 36
import com.extjs.gxt.ui.client.widget.treepanel.TreePanel;
66 jpm 37
import com.google.gwt.core.client.GWT;
324 jp_milcent 38
import com.google.gwt.http.client.Request;
39
import com.google.gwt.http.client.RequestBuilder;
40
import com.google.gwt.http.client.RequestCallback;
41
import com.google.gwt.http.client.RequestException;
42
import com.google.gwt.http.client.Response;
43
import com.google.gwt.json.client.JSONArray;
44
import com.google.gwt.json.client.JSONObject;
45
import com.google.gwt.json.client.JSONParser;
46
import com.google.gwt.json.client.JSONValue;
66 jpm 47
import com.google.gwt.user.client.Event;
61 jpm 48
 
49
public class AideFenetre extends Dialog {
50
 
311 jp_milcent 51
	private static final String SERVICE_NOM = "CoelAide";
543 jp_milcent 52
	private static final String PAGE_SOMMAIRE_CODE = "AideCOELSommaire";
53
	private static final String PAGE_A_OUVRIR_CODE = "AideCOELPresentationGenerale";
311 jp_milcent 54
	private static Menu pagePrincipale = null;
498 jp_milcent 55
	private static Menu menuAOuvrirParDefaut = null;
56
	private TreePanel<Menu> arbre = null;
69 jpm 57
	private TreeStore<Menu> magazin = null;
58
	private StoreFilterField<Menu> filtre = null;
324 jp_milcent 59
	private Menu sommaire = null;
343 jp_milcent 60
	private ContentPanel sommairePanneau = null;
66 jpm 61
	private ContentPanel contenuPanneau = null;
324 jp_milcent 62
	private HtmlContainer conteneurDuHtml;
343 jp_milcent 63
	private LayoutContainer entetePanneau;
543 jp_milcent 64
	private ToolBar sommaireBarreOutils;
324 jp_milcent 65
 
61 jpm 66
	public AideFenetre() {
67
		setBodyBorder(false);
69 jpm 68
		setButtons(Dialog.OK);
516 jp_milcent 69
		setIcon(Images.ICONES.appPanneauListe());
61 jpm 70
		setHeading("COEL - Aide");
324 jp_milcent 71
		setWidth(675);
72
		setHeight(400);
61 jpm 73
		setHideOnButtonClick(true);
324 jp_milcent 74
		setLayout(new BorderLayout());
61 jpm 75
 
543 jp_milcent 76
		creerPanneauEntete();
77
		creerPanneauSommaire();
78
		getSommaireArbreModele();
79
		creerPanneauContenu();
80
	}
81
 
82
	private void creerPanneauEntete() {
343 jp_milcent 83
		entetePanneau = new LayoutContainer();
84
		entetePanneau.setLayout(new FlowLayout());
85
		BorderLayoutData enteteDisposition = new BorderLayoutData(LayoutRegion.NORTH, 30);
86
		add(entetePanneau, enteteDisposition);
543 jp_milcent 87
	}
88
 
89
	private void creerPanneauSommaire() {
343 jp_milcent 90
		inititialiserSommaireArbreFiltre();
543 jp_milcent 91
		creerSommaire();
343 jp_milcent 92
 
93
		sommairePanneau = new ContentPanel();
324 jp_milcent 94
		sommairePanneau.setScrollMode(Scroll.AUTO);
543 jp_milcent 95
		sommairePanneau.setHeight("100%");
96
		sommairePanneau.setHeaderVisible(false);
97
 
98
		creerBarreOutilSommaire();
99
 
358 jp_milcent 100
		BorderLayoutData sommaireDisposition = new BorderLayoutData(LayoutRegion.WEST, 230, 175, 350);
66 jpm 101
		sommaireDisposition.setMargins(new Margins(0, 5, 0, 0));
102
		sommaireDisposition.setSplit(true);
103
		sommaireDisposition.setFloatable(true);
543 jp_milcent 104
		add(sommairePanneau, sommaireDisposition);
105
	}
106
 
107
	private void creerBarreOutilSommaire() {
108
		sommaireBarreOutils = new ToolBar();
109
		// FIXME : on peut utiliser l'alignement à droite car cela pose un problème de rendu dans le Hosted Mode
110
		//sommaireBarreOutils.setAlignment(HorizontalAlignment.RIGHT);
111
		creerBoutonPlierDeplier();
112
		sommairePanneau.setTopComponent(sommaireBarreOutils);
113
	}
114
 
115
	private void creerBoutonPlierDeplier() {
116
		Button plierDeplierToutBtn = new Button();
117
		plierDeplierToutBtn.addSelectionListener(new SelectionListener<ButtonEvent>() {
498 jp_milcent 118
			public void componentSelected(ButtonEvent be) {
119
				Button boutonPlierDeplierTout = (Button) be.getSource();
120
				if (boutonPlierDeplierTout.getIcon().equals(Images.ICONES.deplierTout())) {
543 jp_milcent 121
					boutonPlierDeplierTout.setIcon(Images.ICONES.replierTout());
343 jp_milcent 122
					arbre.expandAll();
498 jp_milcent 123
				} else if (boutonPlierDeplierTout.getIcon().equals(Images.ICONES.replierTout())) {
543 jp_milcent 124
					boutonPlierDeplierTout.setIcon(Images.ICONES.deplierTout());
343 jp_milcent 125
					arbre.collapseAll();
126
				}
543 jp_milcent 127
				boutonPlierDeplierTout.repaint();
343 jp_milcent 128
			}
129
		});
498 jp_milcent 130
		plierDeplierToutBtn.setIcon(Images.ICONES.deplierTout());
543 jp_milcent 131
		plierDeplierToutBtn.setScale(ButtonScale.SMALL);
343 jp_milcent 132
		plierDeplierToutBtn.setToolTip("Étendre le sommaire");
543 jp_milcent 133
		sommaireBarreOutils.add(plierDeplierToutBtn);
134
	}
135
 
136
	private void creerPanneauContenu() {
137
		contenuPanneau = new ContentPanel();
138
		contenuPanneau.setScrollMode(Scroll.AUTO);
343 jp_milcent 139
 
543 jp_milcent 140
		creerBarreOutilContenu();
61 jpm 141
 
543 jp_milcent 142
		BorderLayoutData contenuDisposition = new BorderLayoutData(LayoutRegion.CENTER);
143
		add(contenuPanneau, contenuDisposition);
144
	}
145
 
146
	private void creerBarreOutilContenu() {
498 jp_milcent 147
		Button imprimerBtn = new Button(null, new SelectionListener<ButtonEvent>() {
148
			public void componentSelected(ButtonEvent be) {
324 jp_milcent 149
				Print.it(conteneurDuHtml.el().getInnerHtml());
311 jp_milcent 150
			}
69 jpm 151
		});
516 jp_milcent 152
		imprimerBtn.setIcon(Images.ICONES.imprimer());
69 jpm 153
		contenuPanneau.getHeader().insertTool(imprimerBtn, 0);
61 jpm 154
	}
543 jp_milcent 155
 
498 jp_milcent 156
	private void etendreArbre(Menu menuAOuvrir) {
543 jp_milcent 157
		if (menuAOuvrir != null) {
158
			arbre.setExpanded(menuAOuvrir, true);
159
			arbre.getSelectionModel().select(menuAOuvrir, false);
160
		}
311 jp_milcent 161
	}
162
 
498 jp_milcent 163
	private void etendreArbre(String menuCode) {
164
		Menu menuAOuvrir = magazin.findModel("code", menuCode);
543 jp_milcent 165
		etendreArbre(menuAOuvrir);
311 jp_milcent 166
	}
167
 
498 jp_milcent 168
	private void creerSommaire() {
516 jp_milcent 169
		magazin = new TreeStore<Menu>();
66 jpm 170
 
171
		filtre.bind(magazin);
343 jp_milcent 172
 
516 jp_milcent 173
		arbre = new TreePanel<Menu>(magazin);
543 jp_milcent 174
		arbre.setAutoLoad(true);
175
		arbre.setHeight("100%");
176
		arbre.setDisplayProperty("nom");
516 jp_milcent 177
		arbre.getStyle().setLeafIcon(Images.ICONES.aide());
498 jp_milcent 178
		arbre.addListener(Events.OnClick, new Listener<TreePanelEvent<Menu>>(){
179
			public void handleEvent(TreePanelEvent<Menu> tpe) {
543 jp_milcent 180
				Menu menuSelectionne = arbre.getSelectionModel().getSelectedItem();
181
				if (menuSelectionne.get("code") != null) {
182
					selectionSommaire((String) menuSelectionne.get("code"));
66 jpm 183
				}
184
			}
325 jp_milcent 185
		});
66 jpm 186
	}
187
 
498 jp_milcent 188
	private void definirMenuAOuvrirParDefaut() {
189
		menuAOuvrirParDefaut = magazin.findModel("code", PAGE_A_OUVRIR_CODE);
311 jp_milcent 190
	}
191
 
66 jpm 192
	private void selectionSommaire(String page) {
193
		String serviceUrl = ((Configuration) Registry.get(RegistreId.CONFIG)).getServiceBaseUrl();
311 jp_milcent 194
		String aidePageUrl = serviceUrl+SERVICE_NOM+"/"+page;
66 jpm 195
		chargerPageAide(aidePageUrl);
196
	}
197
 
198
	private void chargerPageAide(String url) {
324 jp_milcent 199
		conteneurDuHtml = new HtmlContainer() {
66 jpm 200
			public void onBrowserEvent(Event e) {
201
				// Nous vérifions que l'évenement est un clic et qu'il a lieu sur un lien
543 jp_milcent 202
				if (e.getTypeInt() == Event.ONCLICK && e.getEventTarget().toString().startsWith("http://")) {
66 jpm 203
					e.preventDefault();
498 jp_milcent 204
					String urlPageAideCible = e.getEventTarget().toString();
311 jp_milcent 205
					chargerPageAide(urlPageAideCible);
206
					String codePageAideCible = urlPageAideCible.substring(urlPageAideCible.lastIndexOf("/")+1);
207
					etendreArbre(codePageAideCible);
208
				} else {
543 jp_milcent 209
					GWT.log("Event target:"+e.getEventTarget().toString()+" - type :"+e.getTypeInt()+"="+Event.ONCLICK, null);
66 jpm 210
				}
211
			}
212
		};
311 jp_milcent 213
 
214
		conteneurDuHtml.setId(ComposantId.PANNEAU_AIDE);
215
		conteneurDuHtml.setWidth(400);
216
		conteneurDuHtml.sinkEvents(Event.ONCLICK);
217
		conteneurDuHtml.setUrl(url);
218
		conteneurDuHtml.recalculate();
219
 
66 jpm 220
		contenuPanneau.removeAll();
311 jp_milcent 221
		contenuPanneau.add(conteneurDuHtml);
66 jpm 222
		contenuPanneau.layout();
223
	}
224
 
225
	private void inititialiserSommaireArbreFiltre() {
69 jpm 226
		filtre = new StoreFilterField<Menu>() {
66 jpm 227
			@Override
69 jpm 228
			protected boolean doSelect(Store<Menu> magazin, Menu parent, Menu enregistrement, String propriete, String filtre) {
311 jp_milcent 229
				Boolean retour = false;
69 jpm 230
				// Seul les feuilles sont traitées par le filtre
311 jp_milcent 231
				String nomMenu = enregistrement.getNom();
232
				String nomMenuMinuscule = nomMenu.toLowerCase();
233
				String nomFiltreMinuscule = filtre.toLowerCase();
543 jp_milcent 234
				String nomFiltreMinusculeProtege = Pattern.quote(nomFiltreMinuscule);
235
				if (nomMenuMinuscule.matches(".*"+nomFiltreMinusculeProtege+".*")) {
311 jp_milcent 236
					retour = true;
69 jpm 237
				}
343 jp_milcent 238
				return retour;
66 jpm 239
			}
240
		};
343 jp_milcent 241
		filtre.setFieldLabel("Chercher");
242
		filtre.setLabelStyle("font-weight:normal;");
243
		filtre.setToolTip("Filtrer le sommaire");
244
		filtre.setWidth(200);
245
 
246
		FormLayout fl = new FormLayout();
247
		fl.setLabelWidth(55);
248
 
249
		ContentPanel fp = new ContentPanel();
250
		fp.setHeaderVisible(false);
251
		fp.setLayout(fl);
252
		fp.add(filtre);
253
		entetePanneau.add(fp);
66 jpm 254
	}
255
 
324 jp_milcent 256
	public void getSommaireArbreModele() {
257
		String serviceUrl = ((Configuration) Registry.get(RegistreId.CONFIG)).getServiceBaseUrl();
258
		String sommairePageUrl = serviceUrl+SERVICE_NOM+"/"+PAGE_SOMMAIRE_CODE+"/sommaire";
259
		RequestBuilder rb = new RequestBuilder(RequestBuilder.GET, sommairePageUrl);
260
		try {
261
			rb.sendRequest(null, new RequestCallback() {
66 jpm 262
 
324 jp_milcent 263
				public void onError(Request request, Throwable exception) {
264
					// Gestion des exceptions déclenchées par l'exécution de la requête
265
					GWT.log("Erreur à l'exécution du service "+SERVICE_NOM+" (selection)", exception);
266
					Info.display("Erreur de Requête", "Une erreur s'est produite lors de l'exécution de la requête.");
267
				}
268
 
269
				public void onErrorHTTP(Request request, Response reponse) {
270
					// Gestion des erreurs HTTP renvoyé par Apache ou JRest
271
					Information info = new Information("erreur_jrest", JSONParser.parse(reponse.getText()).isArray());
272
					GWT.log("Erreur JREST - Code "+reponse.getStatusCode()+"\n"+info.getMessages().toString(), null);
273
					Info.display("Erreur JREST - Code "+reponse.getStatusCode(), info.toString());
274
				}
275
 
276
				public void onResponseReceived(Request request, Response response) {
277
					// Si le code de réponse HTTP ne vaut pas 200 OK, on lance le mécanise d'erreur HTTP
278
					if (response.getStatusCode() != 200) {
279
						onErrorHTTP(request, response);
280
					} else {
281
						if (response.getText().length() != 0 && response.getText() != null) {
282
							final JSONValue responseValue = JSONParser.parse(response.getText());
283
							JSONArray jsonArray = responseValue.isArray();
284
 
285
							if (jsonArray != null) {
286
								sommaire = new Menu("Sommaire");
287
								ajouterMenuRecursivement(sommaire, jsonArray);
66 jpm 288
 
516 jp_milcent 289
								magazin.removeAll();
324 jp_milcent 290
								magazin.add(sommaire, true);
291
 
498 jp_milcent 292
								definirMenuAOuvrirParDefaut();
325 jp_milcent 293
 
324 jp_milcent 294
								sommairePanneau.add(arbre);
498 jp_milcent 295
								sommairePanneau.layout();
343 jp_milcent 296
 
324 jp_milcent 297
								// Chargement de la page racine
298
								selectionSommaire(pagePrincipale.getCode());
498 jp_milcent 299
								etendreArbre(menuAOuvrirParDefaut);
324 jp_milcent 300
							} else {
301
								GWT.log("\n\tLa réponse n'est pas un objet ou un talbeau JSON et vaut : "+responseValue.toString(), null);
302
							}
303
						}
304
					}
305
				}
306
			});
307
		} catch (RequestException e) {
308
			e.printStackTrace();
66 jpm 309
		}
324 jp_milcent 310
	}
311
 
312
	private void ajouterMenuRecursivement(Menu brancheSommaire, JSONArray tableau) {
313
		final int tailleMax = tableau.size();
69 jpm 314
 
324 jp_milcent 315
		for (int i = 0; i < tailleMax; i++) {
316
			JSONObject pageCourante = tableau.get(i).isObject() ;
317
			if (pageCourante != null) {
318
				Menu menuCourrant = new Menu();
319
 
320
				if (pageCourante.get("code") != null) {
543 jp_milcent 321
					String codeCourant = pageCourante.get("code").isString().stringValue();
322
					menuCourrant.setCode(codeCourant);
324 jp_milcent 323
				}
324
				if (pageCourante.get("txt") != null) {
325
					menuCourrant.setNom(pageCourante.get("txt").isString().stringValue());
326
				}
327
 
328
				if (menuCourrant.getNom() == null && menuCourrant.getCode() == null) {
329
					menuCourrant = (Menu) brancheSommaire.getChild((brancheSommaire.getChildCount() - 1));
330
				} else {
331
					if (brancheSommaire != null) {
332
						brancheSommaire.add(menuCourrant);
333
						if (pagePrincipale == null) {
334
							pagePrincipale = menuCourrant;
335
						}
336
					}
337
				}
338
				if (pageCourante.get("liste") != null) {
339
					ajouterMenuRecursivement(menuCourrant, pageCourante.get("liste").isArray());
340
				}
341
			}
342
		}
66 jpm 343
	}
61 jpm 344
}