/* * Copyright (C) 2013 David Sowerby * * 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 uk.q3c.krail.core.view.component; import com.vaadin.ui.Component; import com.vaadin.ui.Tree; import uk.q3c.krail.core.navigate.sitemap.comparator.DefaultUserSitemapSorters.SortType; import uk.q3c.krail.core.navigate.sitemap.comparator.UserSitemapSorters; import uk.q3c.krail.core.option.Option; public interface UserNavigationTree extends Component, UserSitemapSorters { /** * Returns the Vaadin {@link Tree} * * @return */ Tree getTree(); void clear(); int getOptionMaxDepth(); /** * Set the maximum level or depth of the tree you want to be visible. A value of <=0 is ignored. This value is * stored in {@link Option}, and the tree is rebuilt. * * @param level */ void setOptionMaxDepth(int maxDepth); /** * Populate the tree with the entries from the UserSitemap */ void build(); /** * Set the maximum level or depth of the tree you want to be visible. A value of <=0 is ignored. This value is * stored in {@link Option}. If {@code rebuild} is true, the tree is rebuilt. * * @param level */ void setOptionMaxDepth(int maxDepth, boolean rebuild); /** * Sets the sort type but only rebuilds the tree if {@code rebuild} is true. Useful to call with * {@code rebuild=false} if you want to make several changes to the tree before rebuilding, otherwise just use * {@link UserSitemapSorters#setOptionKeySortType(SortType)} * * @param sortType * @param rebuild */ void setOptionSortType(SortType sortType, boolean rebuild); /** * Sets the sort direction but only rebuilds the tree if {@code rebuild} is true. Useful to call with * {@code rebuild=false} if you want to make several changes to the tree before rebuilding, otherwise just use * {@link UserSitemapSorters#setOptionSortAscending(boolean)} * * @param sortType * @param rebuild */ void setOptionSortAscending(boolean ascending, boolean rebuild); }