@elastic/eui
Version:
Elastic UI Component Library
65 lines (63 loc) • 3.03 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.CanvasTextUtils = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the Elastic License
* 2.0 and the Server Side Public License, v 1; you may not use this file except
* in compliance with, at your election, the Elastic License 2.0 or the Server
* Side Public License, v 1.
*/
/**
* Creates a temporary Canvas element for manipulating text & determining text width.
*
* To accurately measure text, canvas rendering requires either a container to
* compute/derive font styles from, or a static font string (useful for usage
* outside the DOM). Particular care should be applied when fallback fonts are
* used, as more fallback fonts can lead to less precision.
*
* Please note that while canvas is more significantly more performant than DOM
* measurement, there are subpixel to single digit pixel differences between
* DOM and canvas measurement due to the different rendering engines used.
*/
var CanvasTextUtils = exports.CanvasTextUtils = /*#__PURE__*/function () {
function CanvasTextUtils(_ref) {
var _this = this;
var font = _ref.font,
container = _ref.container;
(0, _classCallCheck2.default)(this, CanvasTextUtils);
(0, _defineProperty2.default)(this, "context", void 0);
(0, _defineProperty2.default)(this, "currentText", '');
(0, _defineProperty2.default)(this, "computeFontFromElement", function (element) {
var computedStyles = window.getComputedStyle(element);
// TODO: font-stretch is not included even though it potentially should be
// @see https://developer.mozilla.org/en-US/docs/Web/CSS/font#constituent_properties
// It appears to be unsupported and/or breaks font computation in canvas
return ['font-style', 'font-variant', 'font-weight', 'font-size', 'font-family'].map(function (prop) {
return computedStyles.getPropertyValue(prop);
}).join(' ').trim();
});
(0, _defineProperty2.default)(this, "setTextToCheck", function (text) {
_this.currentText = text;
});
this.context = document.createElement('canvas').getContext('2d');
// Set the canvas font to ensure text width calculations are correct
if (font) {
this.context.font = font;
} else if (container) {
this.context.font = this.computeFontFromElement(container);
}
}
return (0, _createClass2.default)(CanvasTextUtils, [{
key: "textWidth",
get: function get() {
return this.context.measureText(this.currentText).width;
}
}]);
}();