Browse Source

Fix for issue http://github.com/c3js/c3/issues/1691

If an object has key that contains . or [], it is now correctly found
instead of searching for an inner object or array that does not exist.
Example:
var data = [{"key.withdot":"1"}]; // did not work before, works now
var data2 = [{"key":{"innerkey":"1"}}]; // still works

Updated test with new bugfix.
pull/1694/head
Jakob Kneissl 9 years ago
parent
commit
e34fb48021
  1. 8
      c3.js
  2. 12
      c3.min.js
  3. 30
      spec/data-spec.js
  4. 8
      src/data.convert.js

8
c3.js

@ -2100,9 +2100,17 @@
return data; return data;
}; };
c3_chart_internal_fn.findValueInJson = function (object, path) { c3_chart_internal_fn.findValueInJson = function (object, path) {
if (path in object) {
// if object has a key that contains . or [], return the key's value
// instead of searching for an inner object
return object[path];
}
path = path.replace(/\[(\w+)\]/g, '.$1'); // convert indexes to properties (replace [] with .) path = path.replace(/\[(\w+)\]/g, '.$1'); // convert indexes to properties (replace [] with .)
path = path.replace(/^\./, ''); // strip a leading dot path = path.replace(/^\./, ''); // strip a leading dot
var pathArray = path.split('.'); var pathArray = path.split('.');
// search for any inner objects or arrays denoted by the path
for (var i = 0; i < pathArray.length; ++i) { for (var i = 0; i < pathArray.length; ++i) {
var k = pathArray[i]; var k = pathArray[i];
if (k in object) { if (k in object) {

12
c3.min.js vendored

File diff suppressed because one or more lines are too long

30
spec/data-spec.js

@ -85,13 +85,15 @@ describe('c3 chart data', function () {
"112": ["600"], "112": ["600"],
"223": [{"224": "100"}], "223": [{"224": "100"}],
"334": [[],[{"335": "300"}]], "334": [[],[{"335": "300"}]],
"556": {"557" : {"558" : ["1000"]}} "556": {"557" : {"558" : ["1000"]}},
"778.889" : "700"
}, { }, {
"date": "2014-06-04", "date": "2014-06-04",
"443": "1000", "443": "1000",
"112": ["700"], "112": ["700"],
"223": [{"224": "200"}], "223": [{"224": "200"}],
"556": {"557" : {"558" : ["2000"]}} "556": {"557" : {"558" : ["2000"]}},
"778.889" : "300"
}, { }, {
"date": "2014-06-05", "date": "2014-06-05",
"995": {"996": "1000"}, "995": {"996": "1000"},
@ -99,11 +101,12 @@ describe('c3 chart data', function () {
"223": [{"224": "300"}], "223": [{"224": "300"}],
"443": "5000", "443": "5000",
"334": [[],[{"335": "500"}]], "334": [[],[{"335": "500"}]],
"556": {"557" : {"558" : ["3000"]}} "556": {"557" : {"558" : ["3000"]}},
"778.889" : "800"
}], }],
keys: { keys: {
x: 'date', x: 'date',
value: [ "443","995.996","112[0]","223[0].224","334[1][0].335","556.557.558[0]"] value: [ "443","995.996","112[0]","223[0].224","334[1][0].335","556.557.558[0]","778.889"]
} }
}, },
axis: { axis: {
@ -118,12 +121,13 @@ describe('c3 chart data', function () {
it('should draw nested JSON correctly', function () { it('should draw nested JSON correctly', function () {
var expectedCx = [98, 294, 490], var expectedCx = [98, 294, 490],
expectedCy = { expectedCy = {
443: [181, 326, 36], "443": [181, 326, 36],
995: [362, 398, 326], "995": [362, 398, 326],
112: [354, 347, 340], "112": [354, 347, 340],
223: [391, 383, 376], "223": [391, 383, 376],
334: [376, 398, 362], "334": [376, 398, 362],
556: [326, 253, 181] "556": [326, 253, 181],
"778.889": [347, 376, 340]
}; };
d3.selectAll('.c3-circles-443 .c3-circle').each(function (d, i) { d3.selectAll('.c3-circles-443 .c3-circle').each(function (d, i) {
@ -161,6 +165,12 @@ describe('c3 chart data', function () {
expect(+circle.attr('cx')).toBeCloseTo(expectedCx[i], 0); expect(+circle.attr('cx')).toBeCloseTo(expectedCx[i], 0);
expect(+circle.attr('cy')).toBeCloseTo(expectedCy[556][i], 0); expect(+circle.attr('cy')).toBeCloseTo(expectedCy[556][i], 0);
}); });
d3.selectAll('.c3-circles-778-889 .c3-circle').each(function (d, i) {
var circle = d3.select(this);
expect(+circle.attr('cx')).toBeCloseTo(expectedCx[i], 0);
expect(+circle.attr('cy')).toBeCloseTo(expectedCy["778.889"][i], 0);
});
}); });
}); });

8
src/data.convert.js

@ -72,9 +72,17 @@ c3_chart_internal_fn.convertJsonToData = function (json, keys) {
return data; return data;
}; };
c3_chart_internal_fn.findValueInJson = function (object, path) { c3_chart_internal_fn.findValueInJson = function (object, path) {
if (path in object) {
// if object has a key that contains . or [], return the key's value
// instead of searching for an inner object
return object[path];
}
path = path.replace(/\[(\w+)\]/g, '.$1'); // convert indexes to properties (replace [] with .) path = path.replace(/\[(\w+)\]/g, '.$1'); // convert indexes to properties (replace [] with .)
path = path.replace(/^\./, ''); // strip a leading dot path = path.replace(/^\./, ''); // strip a leading dot
var pathArray = path.split('.'); var pathArray = path.split('.');
// search for any inner objects or arrays denoted by the path
for (var i = 0; i < pathArray.length; ++i) { for (var i = 0; i < pathArray.length; ++i) {
var k = pathArray[i]; var k = pathArray[i];
if (k in object) { if (k in object) {

Loading…
Cancel
Save