All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.vaadin.data.Collapsible Maven / Gradle / Ivy

There is a newer version: 8.7.2
Show newest version
/*
 * 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); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy