UNPKG

@mui/x-charts

Version:

The community edition of the charts components (MUI X).

121 lines (116 loc) 3.78 kB
import _extends from "@babel/runtime/helpers/esm/extends"; import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray"; // DOM utils taken from // https://github.com/recharts/recharts/blob/master/src/util/DOMUtils.ts var isSsr = function isSsr() { return !(typeof window !== 'undefined' && window.document && window.setTimeout); }; var stringCache = { widthCache: {}, cacheCount: 0 }; var MAX_CACHE_NUM = 2000; var SPAN_STYLE = { position: 'absolute', top: '-20000px', left: 0, padding: 0, margin: 0, border: 'none', whiteSpace: 'pre' }; var STYLE_LIST = ['minWidth', 'maxWidth', 'width', 'minHeight', 'maxHeight', 'height', 'top', 'left', 'fontSize', 'padding', 'margin', 'paddingLeft', 'paddingRight', 'paddingTop', 'paddingBottom', 'marginLeft', 'marginRight', 'marginTop', 'marginBottom']; var MEASUREMENT_SPAN_ID = 'mui_measurement_span'; /** * * @param name CSS property name * @param value * @returns add 'px' for distance properties */ function autoCompleteStyle(name, value) { if (STYLE_LIST.indexOf(name) >= 0 && value === +value) { return "".concat(value, "px"); } return value; } /** * * @param text camelcase css property * @returns css property */ function camelToMiddleLine(text) { var strs = text.split(''); var formatStrs = strs.reduce(function (result, entry) { if (entry === entry.toUpperCase()) { return [].concat(_toConsumableArray(result), ['-', entry.toLowerCase()]); } return [].concat(_toConsumableArray(result), [entry]); }, []); return formatStrs.join(''); } /** * * @param style React style object * @returns CSS styling string */ export var getStyleString = function getStyleString(style) { return Object.keys(style).sort().reduce(function (result, s) { return "".concat(result).concat(camelToMiddleLine(s), ":").concat(autoCompleteStyle(s, style[s]), ";"); }, ''); }; /** * * @param text The string to estimate * @param style The style applied * @returns width and height of the text */ export var getStringSize = function getStringSize(text) { var style = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; if (text === undefined || text === null || isSsr()) { return { width: 0, height: 0 }; } var str = "".concat(text); var styleString = getStyleString(style); var cacheKey = "".concat(str, "-").concat(styleString); if (stringCache.widthCache[cacheKey]) { return stringCache.widthCache[cacheKey]; } try { var measurementSpan = document.getElementById(MEASUREMENT_SPAN_ID); if (measurementSpan === null) { measurementSpan = document.createElement('span'); measurementSpan.setAttribute('id', MEASUREMENT_SPAN_ID); measurementSpan.setAttribute('aria-hidden', 'true'); document.body.appendChild(measurementSpan); } // Need to use CSS Object Model (CSSOM) to be able to comply with Content Security Policy (CSP) // https://en.wikipedia.org/wiki/Content_Security_Policy var measurementSpanStyle = _extends({}, SPAN_STYLE, style); Object.keys(measurementSpanStyle).map(function (styleKey) { measurementSpan.style[camelToMiddleLine(styleKey)] = autoCompleteStyle(styleKey, measurementSpanStyle[styleKey]); return styleKey; }); measurementSpan.textContent = str; var rect = measurementSpan.getBoundingClientRect(); var result = { width: rect.width, height: rect.height }; stringCache.widthCache[cacheKey] = result; if (stringCache.cacheCount + 1 > MAX_CACHE_NUM) { stringCache.cacheCount = 0; stringCache.widthCache = {}; } else { stringCache.cacheCount += 1; } return result; } catch (e) { return { width: 0, height: 0 }; } };