package er.googlechart.components;
import com.webobjects.appserver.WOAssociation;
import com.webobjects.appserver.WOComponent;
import com.webobjects.appserver.WOContext;
import com.webobjects.appserver.WOElement;
import com.webobjects.appserver.WOResponse;
import com.webobjects.foundation.NSDictionary;
import er.extensions.foundation.ERXMutableURL;
/**
* A <a href="http://code.google.com/apis/chart/types.html#radar">radar chart</a>.
*
* @binding data the array, or array of arrays, of data
* @binding size "wxh" format chart size ("300x400")
* @binding width the width of the chart
* @binding height the height of the chart
* @binding colors an array of color values (for lines, bars, pie slices)
* @binding title the title of the chart
* @binding titleColor the color of the chart title
* @binding titleSize the size of the chart title
* @binding backgroundStyle "solid", "gradient", or "stripes"
* @binding background the solid color of the background
* @binding legend an array of legend values
* @binding labeledAxes an array of axes that have labels ("x,y,r") (see http://code.google.com/apis/chart/#multiple_axes_labels)
* @binding axisLabels an array of array of axis labels
* @binding custom custom query string parameters to append
* @binding id the id of the img tag
* @binding class the class of the img tag
* @binding alt the alt text of the img tag
* @binding encoding the explicit chart encoding to use ("simple", "extended", "text")
* @binding normalize if true, values will be normalized relative to the max value
* @binding maxValue if false, normalization is off or set to a number to override the max value
* @binding scaling if true, numbers will be scaled with an automatic min/max, or set to min/max string values (see http://code.google.com/apis/chart/#data_scaling)
* @binding fillArea the fill area (see http://code.google.com/apis/chart/#fill_area_marker)
* @binding lineStyles the line styles (see http://code.google.com/apis/chart/#line_styles)
* @binding rangeMarkers the string that specifies range markers (see http://code.google.com/apis/chart/#hor_line_marker)
* @binding shapeMarkers the string that specifies shape markers (see http://code.google.com/apis/chart/#shape_markers2)
* @binding gridLines the override for specifying all gridline values (see http://code.google.com/apis/chart/#grid)
* @binding gridXStep the number of steps on the x axis between grid lines
* @binding gridYStep the number of steps on the y axis between grid lines
* @binding gridLineSize the number of pixels in the line of the dash part of the grid line
* @binding gridBlankSize the numer of pixels in the spacing between dashes in the grid line
* @binding spline if true, a spline is used instead of line segments
*
* @author mschrag
*/
public class GCRadarChart extends GCAbstractChart {
protected WOAssociation _spline;
public GCRadarChart(String name, NSDictionary associations, WOElement element) {
super(name, associations, element);
_spline = (WOAssociation) associations.objectForKey("spline");
}
@Override
protected void addQueryParameters(ERXMutableURL chartUrl, WOResponse response, WOContext context) {
super.addQueryParameters(chartUrl, response, context);
WOComponent component = context.component();
if (_spline != null && _spline.booleanValueInComponent(component)) {
chartUrl.setQueryParameter("cht", "rs");
}
else {
chartUrl.setQueryParameter("cht", "r");
}
}
}