com.jwebmp.plugins.jqplot.options.JQPlotLegendOptions Maven / Gradle / Ivy
Show all versions of jwebmp-jqplot Show documentation
/*
* Copyright (C) 2017 GedMarc
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
package com.jwebmp.plugins.jqplot.options;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonRawValue;
import com.jwebmp.core.generics.CompassPoints;
import com.jwebmp.core.htmlbuilder.css.colours.ColourHex;
import com.jwebmp.core.htmlbuilder.css.fonts.FontFamilies;
import com.jwebmp.core.htmlbuilder.javascript.JavaScriptPart;
import com.jwebmp.plugins.jqplot.JQPlotGraph;
import com.jwebmp.plugins.jqplot.options.legends.JQPlotLegendRendererEnhancedOptions;
import com.jwebmp.plugins.jqplot.parts.interfaces.JQPlotLegendRenderer;
import javax.validation.constraints.NotNull;
import java.util.ArrayList;
import java.util.List;
/**
* The Legend options
*
*
* @param
*
* @author GedMarc
* @version 1.0
* @since 07 Aug 2015
*/
public class JQPlotLegendOptions>
extends JavaScriptPart
{
/**
* The legend renderer string
*/
@JsonRawValue
private String renderer;
/**
* The legend renderer options
*/
private O rendererOptions;
/**
* Whether to display the legend on the graph.
*/
private Boolean show;
/**
* Placement of the legend. compass direction, nw, n, ne, e, se, s, sw, w.
*/
private CompassPoints location;
/**
* pixel offset of the legend box from the x (or x2) axis.
*/
private Integer xoffset;
/**
* pixel offset of the legend box from the y (or y2) axis.
*/
private Integer yoffset;
/**
* Array of labels to use.
*/
private List labels;
/**
* true to show the label text on the legend.
*/
private Boolean showLabels;
/**
* true to show the color swatches on the legend.
*/
private Boolean showSwatch;
/**
* “insideGrid” places legend inside the grid area of the plot.
*/
private String placement;
/**
* CSS spec for the border around the legend box.
*/
private String border;
/**
* CSS spec for the background of the legend box.
*/
private String background;
/**
* CSS color spec for the legend text.
*/
private String textColor;
/**
* CSS font-family spec for the legend text.
*/
private FontFamilies fontFamily;
/**
* CSS font-size spec for the legend text.
*/
private Integer fontSize;
/**
* CSS padding-top spec for the rows in the legend.
*/
private Integer rowSpacing;
/**
* Whether to draw the legend before the series or not.
*/
private Boolean predraw;
/**
* CSS margin for the legend DOM element.
*/
private Integer marginTop;
/**
* CSS margin for the legend DOM element.
*/
private Integer marginRight;
/**
* CSS margin for the legend DOM element.
*/
private Integer marginBottom;
/**
* CSS margin for the legend DOM element.
*/
private Integer marginLeft;
@JsonIgnore
private JQPlotGraph linkedGraph;
/**
* Sets the linked graph for this options
*
* @param linkedGraph
*/
public JQPlotLegendOptions(JQPlotGraph linkedGraph)
{
this.linkedGraph = linkedGraph;
}
/**
* Whether to display the legend on the graph.
*/
public Boolean getShow()
{
return show;
}
/**
* Whether to display the legend on the graph.
*
*
* @param show
*/
@SuppressWarnings("unchecked")
@NotNull
public J setShow(Boolean show)
{
this.show = show;
return (J) this;
}
/**
* Placement of the legend. compass direction, nw, n, ne, e, se, s, sw, w.
*
*
* @return
*/
public CompassPoints getLocation()
{
return location;
}
/**
* Placement of the legend. compass direction, nw, n, ne, e, se, s, sw, w.
*
*
* @param location
*/
@SuppressWarnings("unchecked")
@NotNull
public J setLocation(CompassPoints location)
{
this.location = location;
return (J) this;
}
/**
* pixel offset of the legend box from the x (or x2) axis.
*
*/
public Integer getXoffset()
{
return xoffset;
}
/**
* pixel offset of the legend box from the x (or x2) axis.
*
*/
@SuppressWarnings("unchecked")
@NotNull
public J setXoffset(Integer xoffset)
{
this.xoffset = xoffset;
return (J) this;
}
/**
* pixel offset of the legend box from the x (or x2) axis.
*
*/
public Integer getYoffset()
{
return yoffset;
}
/**
* pixel offset of the legend box from the x (or x2) axis.
*
*/
@SuppressWarnings("unchecked")
@NotNull
public J setYoffset(Integer yoffset)
{
this.yoffset = yoffset;
return (J) this;
}
/**
* Custom list of labels
*
*
* @return
*/
public List getLabels()
{
if (labels == null)
{
labels = new ArrayList<>();
}
return labels;
}
/**
* Sets a custom display list for labels
*
*
* @param labels
*/
@SuppressWarnings("unchecked")
@NotNull
public J setLabels(List labels)
{
this.labels = labels;
return (J) this;
}
/**
* Sets to show the labels or not
*
*
* @return
*/
public Boolean getShowLabels()
{
return showLabels;
}
/**
* Sets to show the labels
*
*
* @param showLabels
*/
@SuppressWarnings("unchecked")
@NotNull
public J setShowLabels(Boolean showLabels)
{
this.showLabels = showLabels;
return (J) this;
}
/**
* Whether to show the swatch or not
*
*
* @return
*/
public Boolean getShowSwatch()
{
return showSwatch;
}
/**
* Whether to show the swatch or not
*
*
* @param showSwatch
*/
public J setShowSwatch(Boolean showSwatch)
{
this.showSwatch = showSwatch;
return (J) this;
}
/**
* ”insideGrid” places legend inside the grid area of the plot “outsideGrid” places the legend outside the grid but inside the plot container, shrinking the grid to accomodate
* the legend “inside”
* synonym for “insideGrid”,
*
* “outside” places the legend ouside the grid area, but does not shrink the grid which can cause the legend to overflow the plot container.
*
*
* @return
*/
public String getPlacement()
{
return placement;
}
/**
* ”insideGrid” places legend inside the grid area of the plot
* “outsideGrid” places the legend outside the grid but inside the plot container, shrinking the grid to accomodate the legend
* “inside” synonym for “insideGrid”,
*
* “outside” places the legend ouside the grid area, but does not shrink the grid which can cause the legend to overflow the plot container.
*
*
* @param placement
*/
@SuppressWarnings("unchecked")
@NotNull
public J setPlacement(String placement)
{
this.placement = placement;
return (J) this;
}
/**
* CSS Border Configuration line
*
*
* @return
*/
public String getBorder()
{
return border;
}
/**
* Sets the css border configuration
*
*
* @param border
*/
@SuppressWarnings("unchecked")
@NotNull
public J setBorder(String border)
{
this.border = border;
return (J) this;
}
/**
* Sets the CSS Background
*
*
* @return
*/
public String getBackground()
{
return background;
}
/**
* Sets the CSS Background
*
*
* @param background
*/
@SuppressWarnings("unchecked")
@NotNull
public J setBackground(String background)
{
this.background = background;
return (J) this;
}
/**
* Gets the text colour
*
*
* @return
*/
public String getTextColor()
{
return textColor;
}
/**
* Sets the text colour
*
*
* @param textColor
*/
@SuppressWarnings("unchecked")
@NotNull
public J setTextColor(ColourHex textColor)
{
this.textColor = textColor.getValue();
return (J) this;
}
/**
* Gets the font family used
*
*
* @return
*/
public FontFamilies getFontFamily()
{
return fontFamily;
}
/**
* Sets the font family used
*
*
* @param fontFamily
*/
@SuppressWarnings("unchecked")
@NotNull
public J setFontFamily(FontFamilies fontFamily)
{
this.fontFamily = fontFamily;
return (J) this;
}
/**
* Gets the font size
*
*
* @return
*/
public Integer getFontSize()
{
return fontSize;
}
/**
* Sets the font size
*
*
* @param fontSize
*/
@SuppressWarnings("unchecked")
@NotNull
public J setFontSize(Integer fontSize)
{
this.fontSize = fontSize;
return (J) this;
}
/**
* Gets the row spacing
*
*
* @return
*/
public Integer getRowSpacing()
{
return rowSpacing;
}
/**
* Sets the row spacing
*
*
* @param rowSpacing
*/
@SuppressWarnings("unchecked")
@NotNull
public J setRowSpacing(Integer rowSpacing)
{
this.rowSpacing = rowSpacing;
return (J) this;
}
/**
* Whether to draw the legend before the series or not.
*
*
* @return
*/
public Boolean getPredraw()
{
return predraw;
}
/**
* Whether to draw the legend before the series or not.
*
*
* @param predraw
*/
@SuppressWarnings("unchecked")
@NotNull
public J setPredraw(Boolean predraw)
{
this.predraw = predraw;
return (J) this;
}
/**
* Sets the margin top
*
*
* @return
*/
public Integer getMarginTop()
{
return marginTop;
}
/**
* Sets the margin top
*
*
* @param marginTop
*/
@SuppressWarnings("unchecked")
@NotNull
public J setMarginTop(Integer marginTop)
{
this.marginTop = marginTop;
return (J) this;
}
/**
* Sets the margin right
*
*
* @return
*/
public Integer getMarginRight()
{
return marginRight;
}
/**
* Sets the margin right
*
*
* @param marginRight
*/
@SuppressWarnings("unchecked")
@NotNull
public J setMarginRight(Integer marginRight)
{
this.marginRight = marginRight;
return (J) this;
}
/**
* Gets the margin bottom
*
*
* @return
*/
public Integer getMarginBottom()
{
return marginBottom;
}
/**
* Sets the margin bottom
*
*
* @param marginBottom
*/
@SuppressWarnings("unchecked")
@NotNull
public J setMarginBottom(Integer marginBottom)
{
this.marginBottom = marginBottom;
return (J) this;
}
/**
* Sets the margin left
*
*
* @return
*/
public Integer getMarginLeft()
{
return marginLeft;
}
/**
* Sets the margin left
*
*
* @param marginLeft
*/
@SuppressWarnings("unchecked")
@NotNull
public J setMarginLeft(Integer marginLeft)
{
this.marginLeft = marginLeft;
return (J) this;
}
/**
* Legend Renderer Options
*
* Defaults to JQPlotLegendRendererEnhancedOptions
*
* @return
*/
public O getRendererOptions()
{
if (rendererOptions == null)
{
setRendererOptions((O) new JQPlotLegendRendererEnhancedOptions(getLinkedGraph()));
}
return rendererOptions;
}
/**
* Gets the linked graph for this legends box
*
* @return
*/
public JQPlotGraph getLinkedGraph()
{
return linkedGraph;
}
/**
* Sets the linked graph for this box
*
* @param linkedGraph
*/
@SuppressWarnings("unchecked")
@NotNull
public J setLinkedGraph(JQPlotGraph linkedGraph)
{
this.linkedGraph = linkedGraph;
return (J) this;
}
/**
* Sets legend renderer options
*
* @param rendererOptions
*/
@SuppressWarnings("unchecked")
@NotNull
public J setRendererOptions(O rendererOptions)
{
renderer = rendererOptions.getRenderer();
this.rendererOptions = rendererOptions;
return (J) this;
}
/**
* Returns the renderer string for the options
*
* @return
*/
public String getRenderer()
{
return renderer;
}
}