Browse Source

Fix load/unload transition

pull/110/head
Masayuki Tanaka 11 years ago
parent
commit
cb5c017062
  1. 94
      c3.js
  2. 4
      c3.min.js

94
c3.js

@ -1896,6 +1896,15 @@
return Math.pow(x(data.x) - pos[0], 2) + Math.pow(y(data.value) - pos[1], 2); return Math.pow(x(data.x) - pos[0], 2) + Math.pow(y(data.value) - pos[1], 2);
} }
function endall(transition, callback) {
var n = 0;
transition
.each(function () { ++n; })
.each("end", function () {
if (!--n) { callback.apply(this, arguments); }
});
}
//-- Selection --// //-- Selection --//
function selectPoint(target, d, i) { function selectPoint(target, d, i) {
@ -3386,21 +3395,53 @@
// Redraw with new targets // Redraw with new targets
redraw({withUpdateOrgXDomain: true, withUpdateXDomain: true, withLegend: true}); redraw({withUpdateOrgXDomain: true, withUpdateXDomain: true, withLegend: true});
done(); if (typeof done === 'function') { done(); }
}
function loadFromArgs(args) {
// load data
if ('data' in args) {
load(convertDataToTargets(args.data), args.done);
}
else if ('url' in args) {
d3.csv(args.url, function (error, data) {
load(convertDataToTargets(data), args.done);
});
}
else if ('rows' in args) {
load(convertDataToTargets(convertRowsToData(args.rows)), args.done);
}
else if ('columns' in args) {
load(convertDataToTargets(convertColumnsToData(args.columns)), args.done);
}
else {
throw Error('url or rows or columns is required.');
}
} }
function unload(targetIds) { function unload(targetIds, done) {
if (typeof done !== 'function') {
done = function () {};
}
if (!targetIds || targetIds.length === 0) {
done();
return;
}
svg.selectAll(targetIds.map(function (id) { return selectorTarget(id); }))
.transition()
.style('opacity', 0)
.remove()
.call(endall, done);
targetIds.forEach(function (id) { targetIds.forEach(function (id) {
c3.data.targets = c3.data.targets.filter(function (t) { // Reset fadein for future load
return t.id !== id; withoutFadeIn[id] = false;
}); // Remove target's elements
svg.selectAll(selectorTarget(id))
.transition()
.style('opacity', 0)
.remove();
if (__legend_show) { if (__legend_show) {
legend.selectAll('.' + CLASS.legendItem + getTargetSelectorSuffix(id)).remove(); legend.selectAll('.' + CLASS.legendItem + getTargetSelectorSuffix(id)).remove();
} }
// Remove target
c3.data.targets = c3.data.targets.filter(function (t) {
return t.id !== id;
});
}); });
} }
@ -3662,10 +3703,6 @@
}; };
c3.load = function (args) { c3.load = function (args) {
// check args
if (typeof args.done !== 'function') {
args.done = function () {};
}
// update xs if exists // update xs if exists
if (args.xs) { if (args.xs) {
addXs(args.xs); addXs(args.xs);
@ -3680,33 +3717,20 @@
load(getCaches(args.cacheIds), args.done); load(getCaches(args.cacheIds), args.done);
return; return;
} }
// load data // unload if needed
if ('data' in args) { if ('unload' in args) {
load(convertDataToTargets(args.data), args.done); // TODO: do not unload if target will load (included in url/rows/columns)
} unload(args.unload ? typeof args.unload === 'string' ? [args.unload] : args.unload : [], function () {
else if ('url' in args) { loadFromArgs(args);
d3.csv(args.url, function (error, data) {
load(convertDataToTargets(data), args.done);
}); });
} } else {
else if ('rows' in args) { loadFromArgs(args);
load(convertDataToTargets(convertRowsToData(args.rows)), args.done);
}
else if ('columns' in args) {
load(convertDataToTargets(convertColumnsToData(args.columns)), args.done);
}
else {
throw Error('url or rows or columns is required.');
} }
}; };
c3.unload = function (targetIds) { c3.unload = function (targetIds) {
// remove elements for targetId unload(targetIds ? typeof targetIds === 'string' ? [targetIds] : targetIds : getTargetIds());
unload(typeof targetIds === 'string' ? [targetIds] : targetIds); redraw({withUpdateOrgXDomain: true, withUpdateXDomain: true, withLegend: true});
// try redraw if targets exist
if (c3.data.targets.length > 0) {
redraw({withUpdateOrgXDomain: true, withUpdateXDomain: true, withLegend: true});
}
}; };
c3.selected = function (targetId) { c3.selected = function (targetId) {

4
c3.min.js vendored

File diff suppressed because one or more lines are too long
Loading…
Cancel
Save