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

com.vaadin.flow.component.tabs.Tab Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2000-2024 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.tabs;

import com.vaadin.flow.component.Component;
import com.vaadin.flow.component.HasAriaLabel;
import com.vaadin.flow.component.HasComponents;
import com.vaadin.flow.component.HasLabel;
import com.vaadin.flow.component.HasStyle;
import com.vaadin.flow.component.Tag;
import com.vaadin.flow.component.dependency.JsModule;
import com.vaadin.flow.component.dependency.NpmPackage;
import com.vaadin.flow.component.shared.HasThemeVariant;
import com.vaadin.flow.component.shared.HasTooltip;

/**
 * This component provides an accessible and customizable tab to be used inside
 * {@link Tabs} component.
 *
 * @author Vaadin Ltd.
 */
@Tag("vaadin-tab")
@NpmPackage(value = "@vaadin/polymer-legacy-adapter", version = "24.6.0")
@JsModule("@vaadin/polymer-legacy-adapter/style-modules.js")
@JsModule("@vaadin/tabs/src/vaadin-tab.js")
@NpmPackage(value = "@vaadin/tabs", version = "24.6.0")
public class Tab extends Component implements HasAriaLabel, HasComponents,
        HasLabel, HasStyle, HasThemeVariant, HasTooltip {

    private static final String FLEX_GROW_CSS_PROPERTY = "flexGrow";

    /**
     * Constructs a new object in its default state.
     */
    public Tab() {
    }

    /**
     * Constructs a new object with the given label.
     *
     * @param label
     *            the label to display
     */
    public Tab(String label) {
        setLabel(label);
    }

    /**
     * Constructs a new object with child components.
     *
     * @param components
     *            the child components
     */
    public Tab(Component... components) {
        add(components);
    }

    /**
     * Gets the label of this tab.
     *
     * @return the label
     */
    @Override
    public final String getLabel() {
        return getElement().getText();
    }

    /**
     * Sets the label of this tab.
     *
     * @param label
     *            the label to display
     */
    @Override
    public final void setLabel(String label) {
        getElement().setText(label);
    }

    /**
     * Sets the flex grow property of this tab. The flex grow property specifies
     * what amount of the available space inside the layout the component should
     * take up, proportionally to the other components.
     * 

* For example, if all components have a flex grow property value set to 1, * the remaining space in the layout will be distributed equally to all * components inside the layout. If you set a flex grow property of one * component to 2, that component will take twice the available space as the * other components, and so on. *

* Setting to flex grow property value 0 disables the expansion of the * component. Negative values are not allowed. * * @param flexGrow * the proportion of the available space the tab should take up */ public void setFlexGrow(double flexGrow) { if (flexGrow < 0) { throw new IllegalArgumentException( "Flex grow property cannot be negative"); } if (flexGrow == 0) { getElement().getStyle().remove(FLEX_GROW_CSS_PROPERTY); } else { getElement().getStyle().set(FLEX_GROW_CSS_PROPERTY, String.valueOf(flexGrow)); } } /** * Gets the flex grow property of this tab. * * @return the flex grow property, or 0 if none was set */ public double getFlexGrow() { String ratio = getElement().getStyle().get(FLEX_GROW_CSS_PROPERTY); if (ratio == null || ratio.isEmpty()) { return 0; } try { return Double.parseDouble(ratio); } catch (Exception e) { throw new IllegalStateException( "The flex grow property of the component is not parseable to double: " + ratio, e); } } /** * If true, the item is in selected state. * * @param selected * the boolean value to set */ public void setSelected(boolean selected) { getElement().setProperty("selected", selected); } /** * If true, the item is in selected state. *

* This property is not synchronized automatically from the client side, so * the returned value may not be the same as in client side. *

* If a {@link Tab} instance is used inside {@link Tabs} component then * selected state is updated based on currently selected tab. So the value * is the same as {@link Tabs#getSelectedTab()}. * * @see Tabs#getSelectedTab() * * @return the {@code selected} property from the webcomponent */ public boolean isSelected() { return getElement().getProperty("selected", false); } @Override public String toString() { return "Tab{" + getLabel() + "}"; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy