blob: f9497a3ac5d5e7036c8dc7373bf2d5dc8f384a99 [file] [log] [blame]
/*
* $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.pageable;
import java.util.Iterator;
/**
* Interface for item reuse strategies.
* <p>
* <u>Notice:</u> Child items will be rendered in the order they are provided
* by the returned iterator, so it is important that the strategy preserve the
* order of the
* </p>
*
* @author Igor Vaynberg (ivaynberg)
*
*/
public interface IItemReuseStrategy
{
/**
* Returns an iterator over items that will be added to the view. The
* iterator needs to return all the items because the old ones are removed
* prior to the new ones added.
*
* @param factory
* implementation of IItemFactory
* @param newModels
* iterator over models for items
* @param existingItems
* iterator over child items
* @return iterator over items that will be added after all the old items
* are moved.
*/
Iterator getItems(IItemFactory factory, Iterator newModels, Iterator existingItems);
}