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

com.jwebmp.plugins.c3.options.data.C3DataOptions Maven / Gradle / Ivy

/*
 * 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.c3.options.data;

import com.fasterxml.jackson.annotation.JsonIgnore;
import com.jwebmp.core.htmlbuilder.css.colours.ColourHex;
import com.jwebmp.core.htmlbuilder.javascript.JavaScriptPart;
import com.jwebmp.core.htmlbuilder.javascript.JavascriptFunction;
import com.jwebmp.plugins.c3.options.C3DataSelectionOptions;
import com.jwebmp.plugins.c3.options.C3RegionOptions;
import com.jwebmp.plugins.c3.series.C3DataColumnHeader;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * Represents a C3 Graphing Data Structure
 *
 * @author GedMarc
 * @since 09 Mar 2016
 */
public class C3DataOptions
		extends JavaScriptPart
{


	private String url;
	private JavaScriptPart json;
	private C3RowData rows;
	private C3ColumnData columns;
	private String mimeType;
	private List keys;
	private C3DataColumnHeader x;
	private Map xs;
	private String xFormat;
	private String xLocaltime;
	private String xSort;
	private Map names;
	private Map classes;
	private List> groups;
	private Map axes;
	private C3GraphTypeOptions type;
	private Map types;
	private Boolean labels;
	private C3DataOrderOptions order;
	private Map regions;
	private JavascriptFunction color;
	private Map colors;
	private List hide;
	private C3DataEmptyOptions empty;
	private C3DataSelectionOptions selection;

	@JsonIgnore
	private List columnHeaders;
	@JsonIgnore
	private boolean renderByRow;
	@JsonIgnore
	private boolean renderByColumn;

	/**
	 * Constructs a new Data Options Object
	 */
	public C3DataOptions()
	{
		//No options are required
	}

	/**
	 * Constructs a new instance of data options with the column headers set
	 *
	 * @param columnHeaders
	 */
	public C3DataOptions(List columnHeaders)
	{
		this.columnHeaders = columnHeaders;
	}

	/**
	 * Returns the current column headers array
	 *
	 * @return
	 */
	public List getColumnHeaders()
	{
		if (columnHeaders == null)
		{
			columnHeaders = new ArrayList<>();
		}
		return columnHeaders;
	}

	/**
	 * Sets the column headers array
	 *
	 * @param columnHeaders
	 */
	public void setColumnHeaders(List columnHeaders)
	{
		this.columnHeaders = columnHeaders;
	}

	/**
	 * Returns if the data should be delivered by row
	 *
	 * @return
	 */
	public boolean isRenderByRow()
	{
		return renderByRow;
	}

	/**
	 * Sets if the data should be delivered by row
	 *
	 * @param renderByRow
	 */
	public void setRenderByRow(boolean renderByRow)
	{
		this.renderByRow = renderByRow;
	}

	/**
	 * Gets if the data should be delivered by column
	 *
	 * @return
	 */
	public boolean isRenderByColumn()
	{
		return renderByColumn;
	}

	/**
	 * Sets if the data should be rendered by column
	 *
	 * @param renderByColumn
	 */
	public void setRenderByColumn(boolean renderByColumn)
	{
		this.renderByColumn = renderByColumn;
	}

	/**
	 * *************************************************************************************************
	 * args
	 ***************************************************************************************************
	 */
	/**
	 * Load a CSV or JSON file from a URL. Note that this will not work if loading via the "file://" protocol as most browsers with block XMLHTTPRequests.
	 *
	 * @return
	 */
	public String getUrl()
	{
		return url;
	}

	/**
	 * Load a CSV or JSON file from a URL. Note that this will not work if loading via the "file://" protocol as most browsers with block XMLHTTPRequests.
	 *
	 * @param url
	 */
	public void setUrl(String url)
	{
		this.url = url;
	}

	/**
	 * Parse a JSON object for data. See also data.keys.
	 */
	public JavaScriptPart getJson()
	{
		return json;
	}

	/**
	 * Parse a JSON object for data. See also data.keys.
	 *
	 * @param json
	 */
	public void setJson(JavaScriptPart json)
	{
		this.json = json;
	}

	/**
	 * Load data from a multidimensional array, with the first element containing the data names, the following containing related data in that order.
	 *
	 * @return
	 */
	public C3RowData getRows()
	{
		if (rows == null)
		{
			rows = new C3RowData();
		}
		return rows;
	}

	/**
	 * Load data from a multidimensional array, with the first element containing the data names, the following containing related data in that order.
	 *
	 * @param rows
	 */
	public void setRows(C3RowData rows)
	{
		this.rows = rows;
	}

	/**
	 * Load data from a multidimensional array, with each element containing an array consisting of a datum name and associated data values.
	 *
	 * @return
	 */
	public C3ColumnData getColumns()
	{
		if (columns == null)
		{
			columns = new C3ColumnData(new C3DataColumnHeader("Header"));
		}
		return columns;
	}

	/**
	 * Load data from a multidimensional array, with each element containing an array consisting of a datum name and associated data values.
	 *
	 * @param columns
	 */
	public void setColumns(C3ColumnData columns)
	{
		this.columns = columns;
	}

	/**
	 * Used if loading JSON via data.url:
	 *
	 * @return
	 */
	public String getMimeType()
	{
		return mimeType;
	}

	/**
	 * Used if loading JSON via data.url:
	 *
	 * @param mimeType
	 */
	public void setMimeType(String mimeType)
	{
		this.mimeType = mimeType;
	}

	/**
	 * Choose which JSON object keys correspond to desired data.
	 *
	 * @return
	 */
	public List getKeys()
	{
		if (keys == null)
		{
			keys = new ArrayList<>();
		}
		return keys;
	}

	/**
	 * Choose which JSON object keys correspond to aggregate data.
	 *
	 * @param keys
	 */
	public void setKeys(List keys)
	{
		this.keys = keys;
	}

	/**
	 * Specify the key of x values in the data.
	 * 

* We can show the data with non-index x values by this option. This option is required when the type of x axis is timeseries. If this option is set on category axis, the * values of the data on the * key will be used for category names * * @return */ public C3DataColumnHeader getX() { return x; } /** * Specify the key of x values in the data. *

* We can show the data with non-index x values by this option. This option is required when the type of x axis is timeseries. If this option is set on category axis, the * values of the data on the * key will be used for category names * * @param x */ public void setX(C3DataColumnHeader x) { this.x = x; } /** * Specify the keys of the x values for each data. *

* This option can be used if we want to show the data that has different x values. * * @return */ public Map getXs() { if (xs == null) { xs = new HashMap<>(); } return xs; } /** * Specify the keys of the x values for each data. *

* This option can be used if we want to show the data that has different x values. * * @param xs */ public void setXs(Map xs) { this.xs = xs; } /** * Set a format to parse string specifed as x. * * @return */ public String getxFormat() { return xFormat; } /** * Set a format to parse string specifed as x. * * @param xFormat */ public void setxFormat(String xFormat) { this.xFormat = xFormat; } /** * not yet * * @return */ public String getxLocaltime() { return xLocaltime; } /** * not yet * * @param xLocaltime */ public void setxLocaltime(String xLocaltime) { this.xLocaltime = xLocaltime; } /** * not yet * * @return */ public String getxSort() { return xSort; } /** * not yet * * @param xSort */ public void setxSort(String xSort) { this.xSort = xSort; } /** * Set custom data name. * * @return */ public Map getNames() { if (names == null) { names = new HashMap<>(); } return names; } /** * Set custom data name. * * @param names */ public void setNames(Map names) { this.names = names; } /** * Set custom data class. *

* If this option is specified, the element g for the data has an additional class that has the prefix c3-target- (e.g. c3-target-additional-data1-class). * * @return */ public Map getClasses() { if (classes == null) { classes = new HashMap<>(); } return classes; } /** * Set custom data class. *

* If this option is specified, the element g for the data has an additional class that has the prefix c3-target- (e.g. c3-target-additional-data1-class). * * @param classes */ public void setClasses(Map classes) { this.classes = classes; } /** * Sets the columns that are grouped together for the stacked effect * * @return */ public List> getGroups() { if (groups == null) { groups = new ArrayList<>(); } return groups; } /** * Sets the columns that are grouped together for the stacked effect * * @param groups */ public void setGroups(List> groups) { this.groups = groups; } /** * Set y axis the data related to. y and y2 can be used. * * @return */ public Map getAxes() { if (axes == null) { axes = new HashMap<>(); } return axes; } /** * Set y axis the data related to. y and y2 can be used. * * @param axes */ public void setAxes(Map axes) { this.axes = axes; } /** * Set chart type at once. *

* If this option is specified, the type will be applied to every data. This setting can be overwritten by data.types. * * @return */ public C3GraphTypeOptions getType() { return type; } /** * Set chart type at once. *

* If this option is specified, the type will be applied to every data. This setting can be overwritten by data.types. * * @param type */ public void setType(C3GraphTypeOptions type) { this.type = type; } /** * Set chart type for each data. *

* This setting overwrites data.type setting. * * @return */ public Map getTypes() { if (types == null) { types = new HashMap<>(); } return types; } /** * Set chart type for each data. *

* This setting overwrites data.type setting. * * @param types */ public void setTypes(Map types) { this.types = types; } /** * Show labels on each data points. * * @return */ public Boolean getLabels() { return labels; } /** * Show labels on each data points. * * @param labels */ public void setLabels(Boolean labels) { this.labels = labels; } /** * Define the order of the data. *

* This option changes the order of stacking the data and pieces of pie/donut. If null specified, it will be the order the data loaded. If function specified, it will be used * to sort the data and * it will recieve the data as argument. * * @return */ public C3DataOrderOptions getOrder() { return order; } /** * Define the order of the data. *

* This option changes the order of stacking the data and pieces of pie/donut. If null specified, it will be the order the data loaded. If function specified, it will be used * to sort the data and * it will recieve the data as argument. * * @param order */ public void setOrder(C3DataOrderOptions order) { this.order = order; } /** * Define regions for each data. *

* The values must be an array for each data and it should include an object that has start, end, style. * If start is not set, the start will be the first data point. If end is not set, the end * will be the last data point. *

* Currently this option supports only line chart and dashed style. If this option specified, the line will be dashed only in the regions. * * @return */ public Map getRegions() { return regions; } /** * Define regions for each data. *

* The values must be an array for each data and it should include an object that has start, end, style. * If start is not set, the start will be the first data point. If end is not set, the end * will be the last data point. *

* Currently this option supports only line chart and dashed style. If this option specified, the line will be dashed only in the regions. * * @param regions */ public void setRegions(Map regions) { this.regions = regions; } /** * Set color converter function. *

* This option should a function and the specified function receives color (e.g. '#ff0000') and d that has data parameters like id, value, index, etc. And it must return a * string that represents * color (e.g. '#00ff00'). * * @return */ public JavascriptFunction getColor() { return color; } /** * Set color converter function. *

* This option should a function and the specified function receives color (e.g. '#ff0000') and d that has data parameters like id, value, index, etc. And it must return a * string that represents * color (e.g. '#00ff00'). * * @param color */ public void setColor(JavascriptFunction color) { this.color = color; } /** * Set color for each data. * * @return */ public Map getColors() { if (colors == null) { colors = new HashMap<>(); } return colors; } /** * Set color for each data. * * @param colors */ public void setColors(Map colors) { this.colors = colors; } /** * Hide each data when the chart appears. * * @return */ public List getHide() { if (hide == null) { hide = new ArrayList<>(); } return hide; } /** * Hide each data when the chart appears. * * @param hide */ public void setHide(List hide) { this.hide = hide; } /** * @return */ public C3DataEmptyOptions getEmpty() { return empty; } public void setEmpty(C3DataEmptyOptions empty) { this.empty = empty; } public C3DataSelectionOptions getSelection() { return selection; } public void setSelection(C3DataSelectionOptions selection) { this.selection = selection; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy