package com.smartgwt.sample.showcase.client.tiling;
import com.smartgwt.client.data.DSCallback;
import com.smartgwt.client.data.DSRequest;
import com.smartgwt.client.data.DSResponse;
import com.smartgwt.client.data.Record;
import com.smartgwt.client.types.DragAppearance;
import com.smartgwt.client.types.SelectionStyle;
import com.smartgwt.client.widgets.Canvas;
import com.smartgwt.client.widgets.IButton;
import com.smartgwt.client.widgets.events.ClickEvent;
import com.smartgwt.client.widgets.events.ClickHandler;
import com.smartgwt.client.widgets.form.DynamicForm;
import com.smartgwt.client.widgets.form.fields.SelectItem;
import com.smartgwt.client.widgets.form.fields.TextItem;
import com.smartgwt.client.widgets.layout.HLayout;
import com.smartgwt.client.widgets.layout.VStack;
import com.smartgwt.client.widgets.tile.TileGrid;
import com.smartgwt.client.widgets.tile.events.RecordClickEvent;
import com.smartgwt.client.widgets.tile.events.RecordClickHandler;
import com.smartgwt.client.widgets.viewer.CellStyleHandler;
import com.smartgwt.client.widgets.viewer.DetailFormatter;
import com.smartgwt.client.widgets.viewer.DetailViewerField;
import com.smartgwt.sample.showcase.client.PanelFactory;
import com.smartgwt.sample.showcase.client.ShowcasePanel;
import com.smartgwt.sample.showcase.client.data.AnimalXmlDS;
public class TileEditingSample extends ShowcasePanel {
private static final String DESCRIPTION = "Tiled views can be connected to editors. The TiledView automatically reacts to changes to the underlying dataset. Change the life span of Gazelle to 2 to see it animate to the beginning of the list.";
public static class Factory implements PanelFactory {
private String id;
public Canvas create() {
TileEditingSample panel = new TileEditingSample();
id = panel.getID();
return panel;
}
public String getID() {
return id;
}
public String getDescription() {
return DESCRIPTION;
}
}
public Canvas getViewPanel() {
VStack vStack = new VStack(20);
vStack.setWidth100();
final TileGrid tileGrid = new TileGrid();
tileGrid.setTileWidth(150);
tileGrid.setTileHeight(205);
tileGrid.setHeight(400);
tileGrid.setSelectionType(SelectionStyle.SINGLE);
tileGrid.setCanReorderTiles(true);
tileGrid.setShowAllRecords(true);
tileGrid.setTileDragAppearance(DragAppearance.OUTLINE);
tileGrid.setDataSource(AnimalXmlDS.getInstance());
tileGrid.setAnimateTileChange(true);
DetailViewerField pictureField = new DetailViewerField("picture");
DetailViewerField commonNameField = new DetailViewerField("commonName");
commonNameField.setCellStyle("commonName");
DetailViewerField lifeSpanField = new DetailViewerField("lifeSpan");
lifeSpanField.setCellStyle("lifeSpan");
lifeSpanField.setDetailFormatter(new DetailFormatter() {
public String format(Object value, Record record, DetailViewerField field) {
return "Lifespan: " + value;
}
});
DetailViewerField statusField = new DetailViewerField("status");
statusField.setCellStyleHandler(new CellStyleHandler() {
public String execute(Object value, DetailViewerField field, Record record) {
if ("Endangered".equals(value)) {
return "endangered";
} else if ("Threatened".equals(value)) {
return "threatened";
} else if ("Not Endangered".equals(value)) {
return "notEndangered";
} else {
return null;
}
}
});
tileGrid.setFields(pictureField, commonNameField, lifeSpanField, statusField);
vStack.addMember(tileGrid);
final DynamicForm boundForm = new DynamicForm();
boundForm.setNumCols(6);
boundForm.setDataSource(AnimalXmlDS.getInstance());
boundForm.setAutoFocus(false);
TextItem commonNameItem = new TextItem("commonName");
TextItem lifeSpanItem = new TextItem("lifeSpan");
SelectItem statusItem = new SelectItem("status");
boundForm.setFields(commonNameItem, lifeSpanItem, statusItem);
vStack.addMember(boundForm);
tileGrid.addRecordClickHandler(new RecordClickHandler() {
public void onRecordClick(RecordClickEvent event) {
boundForm.editRecord(event.getRecord());
}
});
HLayout hLayout = new HLayout(10);
hLayout.setHeight(22);
IButton button = new IButton("Save");
button.setAutoFit(true);
button.addClickHandler(new ClickHandler() {
public void onClick(ClickEvent event) {
boundForm.saveData();
boundForm.clearValues();
}
});
hLayout.addMember(button);
vStack.addMember(hLayout);
tileGrid.fetchData(null, new DSCallback() {
public void execute(DSResponse response, Object rawData, DSRequest request) {
tileGrid.sortByProperty("lifeSpan", true);
}
});
return vStack;
}
public String getIntro() {
return DESCRIPTION;
}
}