| /* |
| * $Id$ |
| * $Revision$ |
| * $Date$ |
| * |
| * ==================================================================== |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| package wicket.extensions.markup.html.repeater.data.grid; |
| |
| import java.io.Serializable; |
| |
| import wicket.extensions.markup.html.repeater.refreshing.Item; |
| import wicket.model.IModel; |
| |
| /** |
| * Represents an object that is capable of populating an {@link Item} container |
| * representing a cell in a {@link DataGridView} with components. |
| * <p> |
| * Example |
| * <p> |
| * |
| * <pre> |
| * class NamePopulator implements ICellPopulator |
| * { |
| * void populateItem(final Item cellItem, final String componentId, final IModel rowModel) { |
| * User user=(User)rowModel.getObject(cellItem); |
| * String name=user.getFirstName()+" "+user.getLastName(); |
| * cellItem.add(new Label(componentId, name); |
| * }} |
| * </pre> |
| * |
| * In this example the IDataProvider assigned to the DataGridView retrieves User |
| * objects from the database. The cell populator adds a label to the cell that |
| * will display the full name of the user. |
| * |
| * @see DataGridView |
| * @see Item |
| * |
| * @author Igor Vaynberg (ivaynberg) |
| * |
| */ |
| public interface ICellPopulator extends Serializable |
| { |
| /** |
| * Method used to populate a cell in the {@link DataGridView} |
| * |
| * <b>Implementation MUST add a component to the cellItem using the |
| * component id provided by componentId argument, otherwise a |
| * WicketRuntimeException will be thrown</b> |
| * |
| * @param cellItem |
| * the item representing the current table cell being rendered |
| * @param componentId |
| * the id of the component used to render the cell (only one |
| * component should be added to the cell) |
| * @param rowModel |
| * the model of the row item being rendered. this model usually |
| * contains the model provided by the data provider. |
| * |
| * @see Item |
| */ |
| void populateItem(final Item cellItem, final String componentId, final IModel rowModel); |
| } |