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

org.fujion.highcharts.LegendOptions Maven / Gradle / Ivy

There is a newer version: 3.1.0
Show newest version
/*
 * #%L
 * fujion
 * %%
 * Copyright (C) 2020 Fujion Framework
 * %%
 * 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.
 *
 * #L%
 */
package org.fujion.highcharts;

import org.fujion.ancillary.JavaScript;
import org.fujion.ancillary.Options;
import org.fujion.annotation.Option;

/**
 * The legend is a box containing a symbol and name for each series item or point item in the chart.
 */
public class LegendOptions extends Options {
    
    /**
     * The horizontal alignment of the legend box within the chart area. Defaults to "center".
     */
    @Option
    public AlignHorizontal align;
    
    /**
     * The background color of the legend, filling the rounded corner border. Defaults to null.
     */
    @Option
    public String backgroundColor;
    
    /**
     * The color of the drawn border around the legend. Defaults to #999999.
     */
    @Option
    public String borderColor;
    
    /**
     * The border corner radius of the legend. Defaults to 0.
     */
    @Option
    public Integer borderRadius;
    
    /**
     * The width of the drawn border around the legend. Defaults to 0.
     */
    @Option
    public Integer borderWidth;
    
    /**
     * Enable or disable the legend. Defaults to true.
     */
    @Option
    public Boolean enabled;
    
    /**
     * When the legend is floating, the plot area ignores it and is allowed to be placed below it.
     * Defaults to false.
     */
    @Option
    public Boolean floating;
    
    /**
     * In a legend with horizontal layout, the itemDistance defines the pixel distance between each
     * item. Defaults to 20.
     */
    @Option
    public Integer itemDistance;
    
    /**
     * CSS styles for each legend item when the corresponding series or point is hidden.
     */
    @Option
    public final StyleOptions itemHiddenStyle = new StyleOptions();
    
    /**
     * CSS styles for each legend item in hover mode.
     */
    @Option
    public final StyleOptions itemHoverStyle = new StyleOptions();
    
    /**
     * The pixel bottom margin for each legend item. Defaults to 0.
     */
    @Option
    public Integer itemMarginBottom;
    
    /**
     * The pixel top margin for each legend item. Defaults to 0.
     */
    @Option
    public Integer itemMarginTop;
    
    /**
     * CSS styles for each legend item.
     */
    @Option
    public final StyleOptions itemStyle = new StyleOptions();
    
    /**
     * The width for each legend item. This is useful in a horizontal layout with many items when
     * you want the items to align vertically. . Defaults to null.
     */
    @Option
    public Integer itemWidth;
    
    /**
     * Enable/disable keyboard navigation for the legend. Requires the Accessibility module.
     * Defaults to true.
     */
    @Option("keyboardNavigation.enabled")
    public Boolean keyboardNavigation_enabled;

    /**
     * A format string for each legend label. Available variables relates to properties on the
     * series, or the point in case of pies. Defaults to {name}.
     */
    @Option
    public String labelFormat;
    
    /**
     * Callback function to format each of the series' labels. The this keyword refers to the series
     * object, or the point object in case of pie charts. By default the series or point name is
     * printed. Defaults to undefined.
     */
    @Option(convertTo = JavaScript.class)
    public String labelFormatter;
    
    /**
     * The layout of the legend items. Can be one of "horizontal" or "vertical". Defaults to
     * "horizontal".
     */
    @Option
    public Orientation layout;
    
    /**
     * If the plot area sized is calculated automatically and the legend is not floating, the legend
     * margin is the space between the legend and the axis labels or plot area. Defaults to 12.
     */
    @Option
    public Integer margin;
    
    /**
     * Maximum pixel height for the legend. When the maximum height is extended, navigation will
     * show. Defaults to undefined.
     */
    @Option
    public Integer maxHeight;
    
    /**
     * Options for the paging or navigation appearing when the legend has overflowed.
     */
    @Option
    public final LegendNavigationOptions navigation = new LegendNavigationOptions();
    
    /**
     * The inner padding of the legend box. Defaults to 8.
     */
    @Option
    public Integer padding;
    
    /**
     * Whether to reverse the order of the legend items compared to the order of the series or
     * points as defined in the configuration object. Defaults to false.
     */
    @Option
    public Boolean reversed;
    
    /**
     * Whether to show the symbol on the right side of the text rather than the left side. This is
     * common in Arabic and Hebraic. Defaults to false.
     */
    @Option
    public Boolean rtl;
    
    /**
     * Whether to apply a drop shadow to the legend. A backgroundColor also needs to be applied for
     * this to take effect. Defaults to no shadow.
     */
    @Option
    public ShadowOptions shadow;
    
    /**
     * When this is true, the legend symbol width will be the same as the symbol height, which in
     * turn defaults to the font size of the legend items. Defaults to true.
     */
    @Option
    public Boolean squareSymbol;

    /**
     * CSS styles for the legend area. The position is determined by properties like align,
     * verticalAlign, x and y, but the styles are still parsed for backwards compatibility. Defaults
     * to undefined.
     */
    @Option
    public final StyleOptions style = new StyleOptions();

    /**
     * The pixel height of the symbol for series types that use a rectangle in the legend. Defaults
     * to the font size of legend items. Defaults to undefined.
     */
    @Option
    public Integer symbolHeight;
    
    /**
     * The pixel padding between the legend item symbol and the legend item text. Defaults to 5.
     */
    @Option
    public Integer symbolPadding;
    
    /**
     * The border radius of the symbol for series types that use a rectangle in the legend. Defaults
     * to half the symbolHeight. Defaults to undefined.
     */
    @Option
    public Integer symbolRadius;

    /**
     * The pixel width of the legend item symbol. When the squareSymbol option is set, this defaults
     * to the symbolHeight, otherwise 16. Defaults to undefined.
     */
    @Option
    public Integer symbolWidth;
    
    /**
     * A title to be added on top of the legend.
     */
    @Option
    public final LegendTitleOptions title = new LegendTitleOptions();
    
    /**
     * Whether to use HTML to render the legend item texts. When using HTML, legend.navigation is
     * disabled.
     */
    @Option
    public Boolean useHTML;
    
    /**
     * The vertical alignment of the legend box. Can be one of "top", "middle" or "bottom". Vertical
     * position can be further determined by the y option. Defaults to "bottom".
     */
    @Option
    public AlignVertical verticalAlign;
    
    /**
     * The width of the legend box, not including style.padding. . Defaults to null.
     */
    @Option
    public Integer width;
    
    /**
     * The x offset of the legend relative to its horizontal alignment align within
     * chart.spacingLeft and chart.spacingRight. Negative x moves it to the left, positive x moves
     * it to the right. Defaults to 0.
     */
    @Option
    public Integer x;
    
    /**
     * The vertical offset of the legend relative to it's vertical alignment verticalAlign within
     * chart.spacingTop and chart.spacingBottom. Negative y moves it up, positive y moves it down.
     * Defaults to 0.
     */
    @Option
    public Integer y;
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy