/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You 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 org.apache.wicket.markup.repeater.data; import org.apache.wicket.markup.html.navigation.paging.IPageable; import org.apache.wicket.markup.repeater.AbstractPageableView; /** * DataView is a basic implementation of {@link AbstractPageableView}. * * Data views aim to make it very simple to populate your repeating view from a database by * utilizing {@link IDataProvider} to act as an interface between the database and the dataview. * * * * <p> * Example: * * <pre> * <tbody> * <tr wicket:id="rows"> * <td><span wicket:id="id">Test ID</span></td> * ... * </pre> * * <p> * Though this example is about a HTML table, DataView is not at all limited to HTML tables. Any * kind of list can be rendered using DataView. * <p> * And the related Java code: * * <pre> * add(new DataView<UserDetails>("rows", dataProvider) * { * public void populateItem(final Item<UserDetails> item) * { * final UserDetails user = item.getModelObject(); * item.add(new Label("id", user.getId())); * } * }); * </pre> * * @see IDataProvider * @see IPageable * * @author Igor Vaynberg (ivaynberg) * * @param <T> * The Model type. */ public abstract class DataView<T> extends DataViewBase<T> { /** * */ private static final long serialVersionUID = 1L; /** * @param id * component id * @param dataProvider * data provider */ protected DataView(String id, IDataProvider<T> dataProvider) { super(id, dataProvider); } /** * @param id * component id * @param dataProvider * data provider * @param itemsPerPage * items per page */ protected DataView(String id, IDataProvider<T> dataProvider, long itemsPerPage) { super(id, dataProvider); setItemsPerPage(itemsPerPage); } /** * @return data provider */ public IDataProvider<T> getDataProvider() { return internalGetDataProvider(); } }