Box size known. Text string length unknown. Fit text to box without ruining its aspect ratio.
I've developed @Roberto answer, but instead of transforming (scaling) the textNode, we simply:
font-size
of 1em
to begin withgetBBox
font-size
to that scale(You can also use 1px
etc.)
Here's the React HOC that does this:
import React from 'react';
import TextBox from './TextBox';
const AutoFitTextBox = TextBoxComponent =>
class extends React.Component {
constructor(props) {
super(props);
this.svgTextNode = React.createRef();
this.state = { scale: 1 };
}
componentDidMount() {
const { width, height } = this.props;
const textBBox = this.getTextBBox();
const widthScale = width / textBBox.width;
const heightScale = height / textBBox.height;
const scale = Math.min(widthScale, heightScale);
this.setState({ scale });
}
getTextBBox() {
const svgTextNode = this.svgTextNode.current;
return svgTextNode.getBBox();
}
render() {
const { scale } = this.state;
return (
);
}
};
export default AutoFitTextBox(TextBox);