-
-
Notifications
You must be signed in to change notification settings - Fork 1.9k
/
Copy pathcalc.js
97 lines (82 loc) · 2.84 KB
/
calc.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
/**
* Copyright 2012-2017, Plotly, Inc.
* All rights reserved.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
'use strict';
var isNumeric = require('fast-isnumeric');
var Axes = require('../../plots/cartesian/axes');
var hasColorscale = require('../../components/colorscale/has_colorscale');
var colorscaleCalc = require('../../components/colorscale/calc');
var arraysToCalcdata = require('./arrays_to_calcdata');
var calcSelection = require('../scatter/calc_selection');
module.exports = function calc(gd, trace) {
// depending on bar direction, set position and size axes
// and data ranges
// note: this logic for choosing orientation is
// duplicated in graph_obj->setstyles
var xa = Axes.getFromId(gd, trace.xaxis || 'x'),
ya = Axes.getFromId(gd, trace.yaxis || 'y'),
orientation = trace.orientation || ((trace.x && !trace.y) ? 'h' : 'v'),
sa, pos, size, i, scalendar;
if(orientation === 'h') {
sa = xa;
size = xa.makeCalcdata(trace, 'x');
pos = ya.makeCalcdata(trace, 'y');
// not sure if it really makes sense to have dates for bar size data...
// ideally if we want to make gantt charts or something we'd treat
// the actual size (trace.x or y) as time delta but base as absolute
// time. But included here for completeness.
scalendar = trace.xcalendar;
}
else {
sa = ya;
size = ya.makeCalcdata(trace, 'y');
pos = xa.makeCalcdata(trace, 'x');
scalendar = trace.ycalendar;
}
// create the "calculated data" to plot
var serieslen = Math.min(pos.length, size.length),
cd = new Array(serieslen);
// set position and size
for(i = 0; i < serieslen; i++) {
cd[i] = { p: pos[i], s: size[i] };
}
// set base
var base = trace.base,
b;
if(Array.isArray(base)) {
for(i = 0; i < Math.min(base.length, cd.length); i++) {
b = sa.d2c(base[i], 0, scalendar);
if(isNumeric(b)) {
cd[i].b = +b;
cd[i].hasB = 1;
}
else cd[i].b = 0;
}
for(; i < cd.length; i++) {
cd[i].b = 0;
}
}
else {
b = sa.d2c(base, 0, scalendar);
var hasBase = isNumeric(b);
b = hasBase ? b : 0;
for(i = 0; i < cd.length; i++) {
cd[i].b = b;
if(hasBase) cd[i].hasB = 1;
}
}
// auto-z and autocolorscale if applicable
if(hasColorscale(trace, 'marker')) {
colorscaleCalc(trace, trace.marker.color, 'marker', 'c');
}
if(hasColorscale(trace, 'marker.line')) {
colorscaleCalc(trace, trace.marker.line.color, 'marker.line', 'c');
}
arraysToCalcdata(cd, trace);
calcSelection(cd, trace);
return cd;
};