@visx/vendor
Version:
vendored packages for visx
90 lines (89 loc) • 3.08 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.copy = copy;
exports.default = sequential;
exports.sequentialLog = sequentialLog;
exports.sequentialPow = sequentialPow;
exports.sequentialSqrt = sequentialSqrt;
exports.sequentialSymlog = sequentialSymlog;
var _index = require("../../../vendor-cjs/d3-interpolate/src/index.js");
var _continuous = require("./continuous.js");
var _init = require("./init.js");
var _linear = require("./linear.js");
var _log = require("./log.js");
var _symlog = require("./symlog.js");
var _pow = require("./pow.js");
function transformer() {
var x0 = 0,
x1 = 1,
t0,
t1,
k10,
transform,
interpolator = _continuous.identity,
clamp = false,
unknown;
function scale(x) {
return x == null || isNaN(x = +x) ? unknown : interpolator(k10 === 0 ? 0.5 : (x = (transform(x) - t0) * k10, clamp ? Math.max(0, Math.min(1, x)) : x));
}
scale.domain = function (_) {
return arguments.length ? ([x0, x1] = _, t0 = transform(x0 = +x0), t1 = transform(x1 = +x1), k10 = t0 === t1 ? 0 : 1 / (t1 - t0), scale) : [x0, x1];
};
scale.clamp = function (_) {
return arguments.length ? (clamp = !!_, scale) : clamp;
};
scale.interpolator = function (_) {
return arguments.length ? (interpolator = _, scale) : interpolator;
};
function range(interpolate) {
return function (_) {
var r0, r1;
return arguments.length ? ([r0, r1] = _, interpolator = interpolate(r0, r1), scale) : [interpolator(0), interpolator(1)];
};
}
scale.range = range(_index.interpolate);
scale.rangeRound = range(_index.interpolateRound);
scale.unknown = function (_) {
return arguments.length ? (unknown = _, scale) : unknown;
};
return function (t) {
transform = t, t0 = t(x0), t1 = t(x1), k10 = t0 === t1 ? 0 : 1 / (t1 - t0);
return scale;
};
}
function copy(source, target) {
return target.domain(source.domain()).interpolator(source.interpolator()).clamp(source.clamp()).unknown(source.unknown());
}
function sequential() {
var scale = (0, _linear.linearish)(transformer()(_continuous.identity));
scale.copy = function () {
return copy(scale, sequential());
};
return _init.initInterpolator.apply(scale, arguments);
}
function sequentialLog() {
var scale = (0, _log.loggish)(transformer()).domain([1, 10]);
scale.copy = function () {
return copy(scale, sequentialLog()).base(scale.base());
};
return _init.initInterpolator.apply(scale, arguments);
}
function sequentialSymlog() {
var scale = (0, _symlog.symlogish)(transformer());
scale.copy = function () {
return copy(scale, sequentialSymlog()).constant(scale.constant());
};
return _init.initInterpolator.apply(scale, arguments);
}
function sequentialPow() {
var scale = (0, _pow.powish)(transformer());
scale.copy = function () {
return copy(scale, sequentialPow()).exponent(scale.exponent());
};
return _init.initInterpolator.apply(scale, arguments);
}
function sequentialSqrt() {
return sequentialPow.apply(null, arguments).exponent(0.5);
}
;