package com.smartgwt.sample.showcase.client.grid;
import com.smartgwt.client.types.Alignment;
import com.smartgwt.client.types.ListGridFieldType;
import com.smartgwt.client.util.SC;
import com.smartgwt.client.widgets.Canvas;
import com.smartgwt.client.widgets.IButton;
import com.smartgwt.client.widgets.ImgButton;
import com.smartgwt.client.widgets.events.ClickEvent;
import com.smartgwt.client.widgets.events.ClickHandler;
import com.smartgwt.client.widgets.grid.ListGrid;
import com.smartgwt.client.widgets.grid.ListGridField;
import com.smartgwt.client.widgets.grid.ListGridRecord;
import com.smartgwt.client.widgets.layout.HLayout;
import com.smartgwt.sample.showcase.client.PanelFactory;
import com.smartgwt.sample.showcase.client.ShowcasePanel;
import com.smartgwt.sample.showcase.client.data.CountryData;
public class GridCellWidgetsSample extends ShowcasePanel {
private static final String DESCRIPTION = "<p>This example illustrates embedding arbitrary widgets in ListGrid cells. Notice how reordering the column with widgets " +
"works as any other column. Smart GWT uses widget pooling to maximize efficiency however for better performance consider using one or more fields of type ListGridFieldType.ICON</p>.";
public static class Factory implements PanelFactory {
private String id;
public Canvas create() {
GridCellWidgetsSample panel = new GridCellWidgetsSample();
id = panel.getID();
return panel;
}
public String getID() {
return id;
}
public String getDescription() {
return DESCRIPTION;
}
}
public Canvas getViewPanel() {
final ListGrid countryGrid = new ListGrid() {
@Override
protected Canvas createRecordComponent(final ListGridRecord record, Integer colNum) {
String fieldName = this.getFieldName(colNum);
if (fieldName.equals("iconField")) {
HLayout recordCanvas = new HLayout(3);
recordCanvas.setHeight(22);
recordCanvas.setAlign(Alignment.CENTER);
ImgButton editImg = new ImgButton();
editImg.setShowDown(false);
editImg.setShowRollOver(false);
editImg.setLayoutAlign(Alignment.CENTER);
editImg.setSrc("silk/comment_edit.png");
editImg.setPrompt("Edit Comments");
editImg.setHeight(16);
editImg.setWidth(16);
editImg.addClickHandler(new ClickHandler() {
public void onClick(ClickEvent event) {
SC.say("Edit Comment Icon Clicked for country : " + record.getAttribute("countryName"));
}
});
ImgButton chartImg = new ImgButton();
chartImg.setShowDown(false);
chartImg.setShowRollOver(false);
chartImg.setAlign(Alignment.CENTER);
chartImg.setSrc("silk/chart_bar.png");
chartImg.setPrompt("View Chart");
chartImg.setHeight(16);
chartImg.setWidth(16);
chartImg.addClickHandler(new ClickHandler() {
public void onClick(ClickEvent event) {
SC.say("Chart Icon Clicked for country : " + record.getAttribute("countryName"));
}
});
recordCanvas.addMember(editImg);
recordCanvas.addMember(chartImg);
return recordCanvas;
} else if (fieldName.equals("buttonField")) {
IButton button = new IButton();
button.setHeight(18);
button.setWidth(65);
button.setIcon("flags/16/" + record.getAttribute("countryCode") + ".png");
button.setTitle("Info");
button.addClickHandler(new ClickHandler() {
public void onClick(ClickEvent event) {
SC.say(record.getAttribute("countryName") + " info button clicked.");
}
});
return button;
} else {
return null;
}
}
};
countryGrid.setShowRecordComponents(true);
countryGrid.setShowRecordComponentsByCell(true);
countryGrid.setCanRemoveRecords(true);
countryGrid.setWidth(550);
countryGrid.setHeight(224);
countryGrid.setShowAllRecords(true);
ListGridField countryCodeField = new ListGridField("countryCode", "Flag", 40);
countryCodeField.setAlign(Alignment.CENTER);
countryCodeField.setType(ListGridFieldType.IMAGE);
countryCodeField.setImageURLPrefix("flags/16/");
countryCodeField.setImageURLSuffix(".png");
ListGridField nameField = new ListGridField("countryName", "Country");
ListGridField capitalField = new ListGridField("capital", "Capital");
ListGridField continentField = new ListGridField("continent", "Continent");
ListGridField buttonField = new ListGridField("buttonField", "Info");
buttonField.setAlign(Alignment.CENTER);
ListGridField iconField = new ListGridField("iconField", "Comments/Stats");
iconField.setWidth(100);
countryGrid.setFields(countryCodeField, nameField, capitalField, continentField, buttonField, iconField);
countryGrid.setCanResizeFields(true);
countryGrid.setData(CountryData.getRecords());
return countryGrid;
}
public String getIntro() {
return DESCRIPTION;
}
}