com.vaadin.data.Collapsible Maven / Gradle / Ivy
/*
* Copyright 2000-2014 Vaadin Ltd.
*
* 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 com.vaadin.data;
import com.vaadin.data.Container.Hierarchical;
import com.vaadin.data.Container.Ordered;
/**
* Container needed by large lazy loading hierarchies displayed e.g. in
* TreeTable.
*
* Container of this type gets notified when a subtree is opened/closed in a
* component displaying its content. This allows container to lazy load subtrees
* and release memory when a sub-tree is no longer displayed.
*
* Methods from {@link Container.Ordered} (and from {@linkContainer.Indexed} if
* implemented) are expected to work as in "preorder" of the currently visible
* hierarchy. This means for example that the return value of size method
* changes when subtree is collapsed/expanded. In other words items in collapsed
* sub trees should be "ignored" by container when the container is accessed
* with methods introduced in {@link Container.Ordered} or
* {@linkContainer.Indexed}. From the accessors point of view, items in
* collapsed subtrees don't exist.
*
*
*/
public interface Collapsible extends Hierarchical, Ordered {
/**
*
* Collapsing the {@link Item} indicated by itemId hides all
* children, and their respective children, from the {@link Container}.
*
*
*
* If called on a leaf {@link Item}, this method does nothing.
*
*
* @param itemId
* the identifier of the collapsed {@link Item}
* @param collapsed
* true if you want to collapse the children below
* this {@link Item}. false if you want to
* uncollapse the children.
*/
public void setCollapsed(Object itemId, boolean collapsed);
/**
*
* Checks whether the {@link Item}, identified by itemId is
* collapsed or not.
*
*
*
* If an {@link Item} is "collapsed" its children are not included in
* methods used to list Items in this container.
*
*
* @param itemId
* The {@link Item}'s identifier that is to be checked.
* @return true iff the {@link Item} identified by
* itemId is currently collapsed, otherwise
* false.
*/
public boolean isCollapsed(Object itemId);
}