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

com.vaadin.flow.component.menubar.MenuBar Maven / Gradle / Ivy

There is a newer version: 24.6.2
Show newest version
/*
 * Copyright 2000-2019 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.flow.component.menubar;

import java.util.List;
import java.util.stream.Collectors;
import java.util.stream.Stream;

import com.vaadin.flow.component.ClickEvent;
import com.vaadin.flow.component.Component;
import com.vaadin.flow.component.ComponentEventListener;
import com.vaadin.flow.component.HasSize;
import com.vaadin.flow.component.HasStyle;
import com.vaadin.flow.component.HasTheme;
import com.vaadin.flow.component.Tag;
import com.vaadin.flow.component.UI;
import com.vaadin.flow.component.contextmenu.HasMenuItems;
import com.vaadin.flow.component.contextmenu.MenuItem;
import com.vaadin.flow.component.contextmenu.MenuItemsArrayGenerator;
import com.vaadin.flow.component.contextmenu.MenuManager;
import com.vaadin.flow.component.contextmenu.SubMenu;
import com.vaadin.flow.component.dependency.HtmlImport;
import com.vaadin.flow.component.dependency.JavaScript;
import com.vaadin.flow.component.dependency.JsModule;
import com.vaadin.flow.component.dependency.NpmPackage;
import com.vaadin.flow.function.SerializableConsumer;

/**
 * Server-side component for the vaadin-menu-bar element.
 *
 * @author Vaadin Ltd
 */
@Tag("vaadin-menu-bar")
@JavaScript("frontend://menubarConnector.js")
@JsModule("./menubarConnector.js")
@HtmlImport("frontend://bower_components/vaadin-menu-bar/src/vaadin-menu-bar.html")
@JsModule("@vaadin/vaadin-menu-bar/src/vaadin-menu-bar.js")
@NpmPackage(value = "@vaadin/vaadin-menu-bar", version = "1.1.0")
public class MenuBar extends Component
        implements HasMenuItems, HasSize, HasStyle, HasTheme {

    private MenuManager menuManager;
    private MenuItemsArrayGenerator menuItemsArrayGenerator;

    private boolean updateScheduled = false;

    /**
     * Creates an empty menu bar component.
     * 

* Use {@link #addItem(String)} to add content to the menu bar. */ public MenuBar() { menuItemsArrayGenerator = new MenuItemsArrayGenerator<>(this); menuManager = new MenuManager<>(this, this::resetContent, (menu, contentReset) -> new MenuBarRootItem(this, contentReset), MenuItem.class, null); addAttachListener(event -> { initConnector(); resetContent(); }); } /** * Creates a new {@link MenuItem} component with the provided text content * and adds it to the root level of this menu bar. *

* The added {@link MenuItem} component is placed inside a button in the * menu bar. If this button overflows the menu bar horizontally, the * {@link MenuItem} is moved out of the button, into a context menu openable * via an overflow button at the end of the button row. *

* To add content to the sub menu opened by clicking the root level item, * use {@link MenuItem#getSubMenu()}. * * @param text * the text content for the new item * @return the added {@link MenuItem} component */ public MenuItem addItem(String text) { return menuManager.addItem(text); } /** * Creates a new {@link MenuItem} component and adds it to the root level of * this menu bar. The provided component is added into the created * {@link MenuItem}. *

* The added {@link MenuItem} component is placed inside a button in the * menu bar. If this button overflows the menu bar horizontally, the * {@link MenuItem} is moved out of the button, into a context menu openable * via an overflow button at the end of the button row. *

* To add content to the sub menu opened by clicking the root level item, * use {@link MenuItem#getSubMenu()}. * * @param component * the component to add inside new item * @return the added {@link MenuItem} component */ public MenuItem addItem(Component component) { return menuManager.addItem(component); } /** * Creates a new {@link MenuItem} component with the provided text content * and click listener and adds it to the root level of this menu bar. *

* The added {@link MenuItem} component is placed inside a button in the * menu bar. If this button overflows the menu bar horizontally, the * {@link MenuItem} is moved out of the button, into a context menu openable * via an overflow button at the end of the button row. *

* To add content to the sub menu opened by clicking the root level item, * use {@link MenuItem#getSubMenu()}. * * @param text * the text content for the new item * @param clickListener * the handler for clicking the new item, can be {@code null} to * not add listener * @return the added {@link MenuItem} component */ @Override public MenuItem addItem(String text, ComponentEventListener> clickListener) { return menuManager.addItem(text, clickListener); } /** * Creates a new {@link MenuItem} component with the provided click listener * and adds it to the root level of this menu bar. The provided component is * added into the created {@link MenuItem}. *

* The added {@link MenuItem} component is placed inside a button in the * menu bar. If this button overflows the menu bar horizontally, the * {@link MenuItem} is moved out of the button, into a context menu openable * via an overflow button at the end of the button row. *

* To add content to the sub menu opened by clicking the root level item, * use {@link MenuItem#getSubMenu()}. * * @param component * the component to add inside the added menu item * @param clickListener * the handler for clicking the new item, can be {@code null} to * not add listener * @return the added {@link MenuItem} component */ @Override public MenuItem addItem(Component component, ComponentEventListener> clickListener) { return menuManager.addItem(component, clickListener); } /** * Gets the {@link MenuItem} components added to the root level of the menu * bar. *

* To manage the contents inside the sub menus, use the * {@link MenuItem#getSubMenu()}. * * @return the root level {@link MenuItem} components added to this menu bar */ public List getItems() { return menuManager.getItems(); } /** * Removes the given item components from this menu bar. * * @param items * the item components to remove, not {@code null} * @throws IllegalArgumentException * if any of the item components to remove is not a child of * this menu bar * */ public void remove(MenuItem... items) { menuManager.remove(items); } /** * Removes all item components from this menu bar. */ public void removeAll() { menuManager.removeAll(); } /** * Gets the child components of this menu bar. *

* The returned components are the same as the ones returned by * {@link #getItems()}. * * @return the child components of this menu bar */ @Override public Stream getChildren() { return menuManager.getChildren(); } /** * Sets the event which opens the sub menus of the root level buttons. * * @param openOnHover * {@code true} to make the sub menus open on hover (mouseover), * {@code false} to make them openable by clicking */ public void setOpenOnHover(boolean openOnHover) { getElement().setProperty("openOnHover", openOnHover); } /** * Gets whether the sub menus open by clicking or hovering on the root level * buttons. * * @return {@code true} if the sub menus open by hovering on the root level * buttons, {@code false} if they open by clicking */ public boolean isOpenOnHover() { return getElement().getProperty("openOnHover", false); } /** * Adds theme variants to the component. * * @param variants * theme variants to add */ public void addThemeVariants(MenuBarVariant... variants) { getThemeNames() .addAll(Stream.of(variants).map(MenuBarVariant::getVariantName) .collect(Collectors.toList())); } /** * Removes theme variants from the component. * * @param variants * theme variants to remove */ public void removeThemeVariants(MenuBarVariant... variants) { getThemeNames().removeAll( Stream.of(variants).map(MenuBarVariant::getVariantName) .collect(Collectors.toList())); } void resetContent() { menuItemsArrayGenerator.generate(); updateButtons(); } void updateButtons() { if (updateScheduled) { return; } runBeforeClientResponse(ui -> { getElement().executeJs("this.$connector.updateButtons()"); updateScheduled = false; }); updateScheduled = true; } private void initConnector() { getElement().executeJs( "window.Vaadin.Flow.menubarConnector.initLazy(this)"); } private void runBeforeClientResponse(SerializableConsumer command) { getElement().getNode().runWhenAttached(ui -> ui .beforeClientResponse(this, context -> command.accept(ui))); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy