package com.smartgwt.sample.showcase.client.tiling; import com.smartgwt.client.data.DataSourceField; import com.smartgwt.client.data.XJSONDataSource; import com.smartgwt.client.data.fields.DataSourceImageField; import com.smartgwt.client.data.fields.DataSourceIntegerField; import com.smartgwt.client.data.fields.DataSourceLinkField; import com.smartgwt.client.types.FieldType; import com.smartgwt.client.widgets.Canvas; import com.smartgwt.client.widgets.form.SearchForm; import com.smartgwt.client.widgets.form.fields.ButtonItem; import com.smartgwt.client.widgets.form.fields.TextItem; import com.smartgwt.client.widgets.form.fields.events.ClickEvent; import com.smartgwt.client.widgets.form.fields.events.ClickHandler; import com.smartgwt.client.widgets.tile.TileGrid; import com.smartgwt.client.widgets.viewer.DetailViewerField; import com.smartgwt.sample.showcase.client.PanelFactory; import com.smartgwt.sample.showcase.client.ShowcasePanel; public class LoadOnDemandTilingSample extends ShowcasePanel { private static final String DESCRIPTION = "Tiled views can load data from services via DataSources, just like other " + "data-aware components. Enter a search term to search Yahoo Images and display available images as tiles."; public static class Factory implements PanelFactory { private String id; public Canvas create() { LoadOnDemandTilingSample panel = new LoadOnDemandTilingSample(); id = panel.getID(); return panel; } public String getID() { return id; } public String getDescription() { return DESCRIPTION; } } public Canvas getViewPanel() { Canvas canvas = new Canvas(); Canvas yahooAttribution = new Canvas(); yahooAttribution.setHeight(31); yahooAttribution.setContents("<a href='http://developer.yahoo.net/about'>" + "<img src='http://l.yimg.com/a/i/us/nt/bdg/websrv_88_1.gif' border='0'>" + "</a>"); canvas.addChild(yahooAttribution); XJSONDataSource yahooDS = new XJSONDataSource(); yahooDS.setDataURL("http://api.search.yahoo.com/ImageSearchService/V1/imageSearch?appid=YahooDemo&output=json"); yahooDS.setRecordXPath("/ResultSet/Result"); DataSourceImageField thumbnail = new DataSourceImageField("Thumbnail", "Thumbnail"); thumbnail.setWidth(150); thumbnail.setImageHeight("imageHeight"); thumbnail.setImageWidth("imageWidth"); thumbnail.setValueXPath("Thumbnail/Url"); DataSourceIntegerField imageWidth = new DataSourceIntegerField("imageWidth"); imageWidth.setValueXPath("Thumbnail/Width"); imageWidth.setAttribute("hidden", true); DataSourceIntegerField imageHeight = new DataSourceIntegerField("imageHeight"); imageHeight.setValueXPath("Thumbnail/Height"); imageHeight.setAttribute("hidden", true); DataSourceField title = new DataSourceField("Title", FieldType.TEXT); DataSourceField summary = new DataSourceField("Summary", FieldType.TEXT); DataSourceLinkField fullImage = new DataSourceLinkField("link", "Full Image"); fullImage.setValueXPath("Url"); fullImage.setAttribute("target", "_blank"); yahooDS.addField(thumbnail); yahooDS.addField(imageWidth); yahooDS.addField(imageHeight); yahooDS.addField(title); yahooDS.addField(summary); yahooDS.addField(fullImage); final TileGrid tileGrid = new TileGrid(); tileGrid.setTop(120); tileGrid.setWidth(500); tileGrid.setHeight(400); tileGrid.setTileWidth(150); tileGrid.setTileHeight(160); tileGrid.setCanReorderTiles(true); tileGrid.setShowAllRecords(true); tileGrid.setDataSource(yahooDS); DetailViewerField thumbnailField = new DetailViewerField("Thumbnail"); thumbnailField.setType("image"); DetailViewerField titleField = new DetailViewerField("Title"); tileGrid.setFields(thumbnailField, titleField); final SearchForm form = new SearchForm(); form.setTop(50); form.setNumCols(3); TextItem query = new TextItem(); query.setName("query"); query.setTitle("Query"); query.setDefaultValue("snowboarding"); ButtonItem button = new ButtonItem(); button.setTitle("Search"); button.setStartRow(false); button.addClickHandler(new ClickHandler() { public void onClick(ClickEvent event) { tileGrid.fetchData(form.getValuesAsCriteria()); } }); form.setItems(query, button); canvas.addChild(form); canvas.addChild(tileGrid); return canvas; } public String getIntro() { return DESCRIPTION; } }