-
Notifications
You must be signed in to change notification settings - Fork 6
Chart
object
The chart object represents a chart with conventional x- and y-axes that is rendered with SVG. Customizable configuration options determine the appearance and behavior of the chart, and these options can be manipulated indirectly through a set of controls. The chart has several lifecycle methods used to instantiate the object, render necessary elements, and adjust the rendered elements as needed. The chart can therefore be updated dynamically by changing some config options (or operating directly on the chart object's properties) or by feeding it new data and then calling its draw method to trigger an animated re-render.
string
CSS selector identifying the DOM element housing the rendered chart
object
a reference to the config object that specifies chart settings
controls
a controls object associated with this chart
array
raw (unfiltered, untransformed) dataset stored by the chart; this dataset is provided directly as an argument to chart.init
array
a list of objects describing the state of any data filters currently associated with the chart; this property is manipulated by controls with type='subsetter'
array
a list of objects describing each set of marks rendered by the chart; essentially a copy of the marks property of the configuration object, but with the mark-specfic transformed data attached
d3.selection
a d3 selection of a <div>
appended within the DOM element specified by chart.div
number
a unique identifier for this chart instance; assigned automatically
array
domain for the x-axis; computed automatically based on the provided dataset, config.x, and config.marks.
array
domain for the y-axis; computed automatically based on the provided dataset, config.y, and config.marks.
a method for attaching a callback function to be called at a given point in the chart's lifecycle; the this
context of the callback is automatically assigned to the current chart object, so that its properties can be accessed like so:
myChart.on('draw', function(){
this.svg.selectAll('.bar');
\\maniuplate bars
});
Param | Type | Description |
---|---|---|
event | string |
point in the chart lifecycle at which to fire the associated callback; can be "init" , "layout" , "preprocess" , "datatransform" , "draw" , "resize" or "destroy"
|
callback | function |
function to run at the specified point in the chart lifecycle |
checks raw dataset against the configuration object for the chart and throws errors if the configuration references values that are not present; called once upon initialization of chart
kicks off the lifecycle of the chart
Param | Type | Description |
---|---|---|
[data] | array |
raw data to be used in the initial rendering of the chart |
fills in default values for config object
sets up the SVG that serves as the chart "canvas" and its static child elements; happens once immediately after chart.init
sets up the color scale for the chart, which is an ordinal d3.scale with a domain based on unique values determined by config.color_by and a range determined by config.colors
draws legend for the chart
Param | Type | Default | Description |
---|---|---|---|
[scale] | d3.scale |
scale returned by chart.setColorScale | color scale to use in the legend |
[label] | string |
label for the legend |
parses config object, triggers data transformation and chart rendering methods; if raw_data
is provided, it will be used when rendering the chart instead of the chart's current raw data
Param | Type | Default | Description |
---|---|---|---|
[raw_data] | array |
chart.raw_data | raw data to be consumed by later chart functions |
transforms raw data into an appropriately nested format for each mark
Param | Type | Description |
---|---|---|
raw | array |
raw dataset to be transformed |
mark | mark |
object describing the set of marks |
pools data for each set of marks and determines comprehensive domains for x- and y-axes
Param | Type | Description |
---|---|---|
raw | array |
raw dataset to be transformed and then consolidated |
sets up x-scale and x-axis functions
Param | Type | Default | Description |
---|---|---|---|
max_range | number |
maximum SVG x-coordinate that can be used; typically set to the width of the chart's plotting area | |
[domain] | array |
chart.x_dom | Domain passed to the scale function |
[type] | string |
config.x.type | Type of scale to define |
sets up y-scale and y-axis functions
Param | Type | Default | Description |
---|---|---|---|
max_range | number |
maximum SVG x-coordinate that can be used; typically set to the height of the chart's plotting area | |
[domain] | array |
chart.y_dom | domain passed to the scale function |
[type] | string |
config.y.type | type of scale to define |
draws bars (<rect>
elements) as defined by marks with type: "bar"
Param | Type | Description |
---|---|---|
marks | array |
the members of chart.marks with type: "bar"
|
draws lines (<path>
elements) as defined by marks with type: "line"
Param | Type | Description |
---|---|---|
marks | array |
the members of chart.marks with type: "line"
|
draws points (<circle>
elements) as defined by marks with type: "circle"
Param | Type | Description |
---|---|---|
marks | array |
the members of chart.marks with type: "circle"
|
arranges all chart components; determines final chart dimensions and triggers rendering of axes and marks
triages rendering functions for the chart's currently-defined marks
draws gridlines at x and or y tick mark locations, as defined by the gridlines
property in the configuration object
determines margins for the chart automatically based on axis ticks, labels, etc.
determines text size for the chart automatically based on certain breakpoints
Param | Type | Description |
---|---|---|
width | number |
width of the chart container |
Removes all components of the chart from the DOM and deletes event listeners and, optionally, controls. Triggers the destroy
callback method.
Param | Type | Default | Description |
---|---|---|---|
destroyControls | boolean |
true | specifies whether to remove any controls bound to the chart |