/*
* Smart GWT (GWT for SmartClient)
* Copyright 2008 and beyond, Isomorphic Software, Inc.
*
* Smart GWT is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License version 3
* is published by the Free Software Foundation. Smart GWT is also
* available under typical commercial license terms - see
* http://smartclient.com/license
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*/
package com.smartgwt.sample.showcase.client.grid.appearance;
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.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 RollOverControlsSample extends ShowcasePanel {
private static final String DESCRIPTION = "RollOver the rows in the grid to row-level controls buttons appear embedded in the row. " +
"This example utilizes the rollOverCanvas subsystem to achieve this effect.";
public static class Factory implements PanelFactory {
private String id;
public Canvas create() {
RollOverControlsSample panel = new RollOverControlsSample();
id = panel.getID();
return panel;
}
public String getID() {
return id;
}
public String getDescription() {
return DESCRIPTION;
}
}
private HLayout rollOverCanvas;
private ListGridRecord rollOverRecord;
public Canvas getViewPanel() {
final ListGrid countryGrid = new ListGrid() {
@Override
protected Canvas getRollOverCanvas(Integer rowNum, Integer colNum) {
rollOverRecord = this.getRecord(rowNum);
if(rollOverCanvas == null) {
rollOverCanvas = new HLayout(3);
rollOverCanvas.setSnapTo("TR");
rollOverCanvas.setWidth(50);
rollOverCanvas.setHeight(22);
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 : " + rollOverRecord.getAttribute("countryName"));
}
});
ImgButton chartImg = new ImgButton();
chartImg.setShowDown(false);
chartImg.setShowRollOver(false);
chartImg.setLayoutAlign(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 : " + rollOverRecord.getAttribute("countryName"));
}
});
rollOverCanvas.addMember(editImg);
rollOverCanvas.addMember(chartImg);
}
return rollOverCanvas;
}
};
countryGrid.setShowRollOverCanvas(true);
countryGrid.setWidth(500);
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");
countryGrid.setFields(countryCodeField, nameField, capitalField, continentField);
countryGrid.setCanResizeFields(true);
countryGrid.setData(CountryData.getRecords());
return countryGrid;
}
public String getIntro() {
return DESCRIPTION;
}
}