package com.smartgwt.sample.showcase.client.grid.datatypes;
import com.google.gwt.i18n.client.NumberFormat;
import com.smartgwt.client.types.Alignment;
import com.smartgwt.client.types.ListGridEditEvent;
import com.smartgwt.client.types.ListGridFieldType;
import com.smartgwt.client.widgets.Canvas;
import com.smartgwt.client.widgets.grid.*;
import com.smartgwt.client.widgets.grid.events.EditorExitEvent;
import com.smartgwt.client.widgets.grid.events.EditorExitHandler;
import com.smartgwt.sample.showcase.client.PanelFactory;
import com.smartgwt.sample.showcase.client.ShowcasePanel;
import com.smartgwt.sample.showcase.client.data.CountryData;
import com.smartgwt.sample.showcase.client.data.CountryRecord;
public class GridDataTypesCalculatedSample extends ShowcasePanel {
private static final String DESCRIPTION = "Click on column headers to sort, or data values to" +
" edit. \"GDP (per capita)\" is calculated from the" +
" \"GDP\" and \"Population\" fields.";
public static class Factory implements PanelFactory {
private String id;
public Canvas create() {
GridDataTypesCalculatedSample panel = new GridDataTypesCalculatedSample();
id = panel.getID();
return panel;
}
public String getID() {
return id;
}
public String getDescription() {
return DESCRIPTION;
}
}
public Canvas getViewPanel() {
Canvas canvas = new Canvas();
final ListGrid countryGrid = new ListGrid();
countryGrid.setWidth(500);
countryGrid.setHeight(224);
countryGrid.setShowAllRecords(true);
countryGrid.setCanEdit(true);
countryGrid.setEditEvent(ListGridEditEvent.CLICK);
countryGrid.setModalEditing(true);
ListGridField countryCodeField = new ListGridField("countryCode", "Flag", 50);
countryCodeField.setAlign(Alignment.CENTER);
countryCodeField.setType(ListGridFieldType.IMAGE);
countryCodeField.setImageURLPrefix("flags/16/");
countryCodeField.setImageURLSuffix(".png");
countryCodeField.setCanEdit(false);
ListGridField nameField = new ListGridField("countryName", "Country");
final ListGridField populationField = new ListGridField("population", "Population");
populationField.setType(ListGridFieldType.INTEGER);
populationField.setCellFormatter(new CellFormatter() {
public String format(Object value, ListGridRecord record, int rowNum, int colNum) {
if (value == null) {
return null;
} else {
NumberFormat nf = NumberFormat.getFormat("0,000");
try {
return nf.format(((Number) value).longValue());
} catch (Exception e) {
return value.toString();
}
}
}
});
final ListGridField gdpField = new ListGridField("gdp", "GDP ($B)");
gdpField.setType(ListGridFieldType.FLOAT);
gdpField.setCellFormatter(new CellFormatter() {
public String format(Object value, ListGridRecord record, int rowNum, int colNum) {
if (value == null) {
return null;
} else {
NumberFormat nf = NumberFormat.getFormat("#,##0.00");
try {
return nf.format(((Number) value).floatValue());
} catch (Exception e) {
return value.toString();
}
}
}
});
final ListGridField gdpPerCapitaField = new ListGridField("gdpPerCapita", "GDP (per capita)");
gdpPerCapitaField.setCanEdit(false);
gdpPerCapitaField.setAlign(Alignment.RIGHT);
gdpPerCapitaField.setType(ListGridFieldType.FLOAT);
gdpPerCapitaField.setCellFormatter(new CellFormatter() {
public String format(Object value, ListGridRecord record, int rowNum, int colNum) {
CountryRecord countryRecord = (CountryRecord) record;
long gdpPerCapita = Math.round((countryRecord.getGdp() * 1000000000) / countryRecord.getPopulation());
NumberFormat nf = NumberFormat.getFormat("0,000");
return "$" + nf.format(gdpPerCapita);
}
});
gdpPerCapitaField.setSortNormalizer(new SortNormalizer() {
public Object normalize(ListGridRecord record, String fieldName) {
CountryRecord countryRecord = (CountryRecord) record;
return countryRecord.getGdp() / countryRecord.getPopulation();
}
});
countryGrid.addEditorExitHandler(new EditorExitHandler() {
public void onEditorExit(EditorExitEvent event) {
String fieldName = countryGrid.getFieldName(event.getColNum());
if("gdp".equals(fieldName) || "population".equals(fieldName)) {
int gdpFieldNum = countryGrid.getFieldNum("gdp_percap");
countryGrid.refreshCell(event.getRowNum(), gdpFieldNum, false, true);
}
}
});
countryGrid.setFields(countryCodeField, nameField, populationField, gdpField, gdpPerCapitaField);
countryGrid.setData(CountryData.getRecords());
canvas.addChild(countryGrid);
return canvas;
}
public String getIntro() {
return DESCRIPTION;
}
}