devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
59 lines (52 loc) • 1.81 kB
JavaScript
/**
* DevExtreme (esm/viz/tree_map/colorizing.gradient.js)
* Version: 24.2.6
* Build date: Mon Mar 17 2025
*
* Copyright (c) 2012 - 2025 Developer Express Inc. ALL RIGHTS RESERVED
* Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/
*/
import {
addColorizer,
createColorCodeGetter as _createColorCodeGetter
} from "./colorizing";
const _min = Math.min;
const _max = Math.max;
function createSimpleColorizer(getColor, range) {
return function(node) {
return getColor(node, range)
}
}
function getRangeData(range) {
return [Number(range[0]) || 0, range[1] - range[0] || 1]
}
function calculateRange(nodes, getValue) {
let i;
const ii = nodes.length;
const codes = [];
let code;
for (i = 0; i < ii; ++i) {
code = getValue(nodes[i]);
if (isFinite(code)) {
codes.push(code)
}
}
return getRangeData([_min.apply(null, codes), _max.apply(null, codes)])
}
function createGuessingColorizer(getColor, getValue) {
const ranges = {};
return function(node) {
const parent = node.parent;
return getColor(node, ranges[parent._id] || (ranges[parent._id] = calculateRange(parent.nodes, getValue)))
}
}
function gradientColorizer(options, themeManager) {
const palette = themeManager.createGradientPalette(options.palette);
const getValue = _createColorCodeGetter(options);
return "range" in options ? createSimpleColorizer(getColor, getRangeData(options.range || [])) : createGuessingColorizer(getColor, getValue);
function getColor(node, arg) {
return palette.getColor((getValue(node) - arg[0]) / arg[1])
}
}
addColorizer("gradient", gradientColorizer);
export default gradientColorizer;