mirror of
https://github.com/penpot/penpot.git
synced 2025-01-08 07:50:43 -05:00
🐛 Fix text editor issues
This commit is contained in:
parent
59e5656bd7
commit
59ca09c24e
3 changed files with 34 additions and 6 deletions
|
@ -223,7 +223,9 @@ export class TextEditor extends EventTarget {
|
||||||
* @param {FocusEvent} e
|
* @param {FocusEvent} e
|
||||||
*/
|
*/
|
||||||
#onFocus = (e) => {
|
#onFocus = (e) => {
|
||||||
this.#selectionController.restoreSelection();
|
if (!this.#selectionController.restoreSelection()) {
|
||||||
|
this.selectAll();
|
||||||
|
}
|
||||||
if (this.#selectionImposterElement) {
|
if (this.#selectionImposterElement) {
|
||||||
this.#selectionImposterElement.replaceChildren();
|
this.#selectionImposterElement.replaceChildren();
|
||||||
}
|
}
|
||||||
|
|
|
@ -49,9 +49,10 @@ export function mapContentFragmentFromDocument(document, root, styleDefaults) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
currentParagraph.appendChild(
|
const inline = createInline(new Text(currentNode.nodeValue), currentStyle);
|
||||||
createInline(new Text(currentNode.nodeValue), currentStyle)
|
const fontSize = inline.style.getPropertyValue("font-size");
|
||||||
);
|
if (!fontSize) console.warn("font-size", fontSize);
|
||||||
|
currentParagraph.appendChild(inline);
|
||||||
|
|
||||||
currentNode = nodeIterator.nextNode();
|
currentNode = nodeIterator.nextNode();
|
||||||
}
|
}
|
||||||
|
|
|
@ -173,13 +173,31 @@ export function setStyle(element, styleName, styleValue, styleUnit) {
|
||||||
return element;
|
return element;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the value of the font size
|
||||||
|
*
|
||||||
|
* @param {number} styleValueAsNumber
|
||||||
|
* @param {string} styleValue
|
||||||
|
* @returns {string}
|
||||||
|
*/
|
||||||
|
function getStyleFontSize(styleValueAsNumber, styleValue) {
|
||||||
|
if (styleValue.endsWith("pt")) {
|
||||||
|
return (styleValueAsNumber * 1.3333).toFixed();
|
||||||
|
} else if (styleValue.endsWith("em")) {
|
||||||
|
return (styleValueAsNumber * baseSize).toFixed();
|
||||||
|
} else if (styleValue.endsWith("%")) {
|
||||||
|
return ((styleValueAsNumber / 100) * baseSize).toFixed();
|
||||||
|
}
|
||||||
|
return styleValueAsNumber.toFixed();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the value of a style from a declaration.
|
* Returns the value of a style from a declaration.
|
||||||
*
|
*
|
||||||
* @param {CSSStyleDeclaration} style
|
* @param {CSSStyleDeclaration} style
|
||||||
* @param {string} styleName
|
* @param {string} styleName
|
||||||
* @param {string|undefined} [styleUnit]
|
* @param {string|undefined} [styleUnit]
|
||||||
* @returns {*}
|
* @returns {string}
|
||||||
*/
|
*/
|
||||||
export function getStyleFromDeclaration(style, styleName, styleUnit) {
|
export function getStyleFromDeclaration(style, styleName, styleUnit) {
|
||||||
if (styleName.startsWith("--")) {
|
if (styleName.startsWith("--")) {
|
||||||
|
@ -189,8 +207,15 @@ export function getStyleFromDeclaration(style, styleName, styleUnit) {
|
||||||
if (styleValue.endsWith(styleUnit)) {
|
if (styleValue.endsWith(styleUnit)) {
|
||||||
return styleValue.slice(0, -styleUnit.length);
|
return styleValue.slice(0, -styleUnit.length);
|
||||||
}
|
}
|
||||||
|
const styleValueAsNumber = parseFloat(styleValue);
|
||||||
|
if (styleName === "font-size") {
|
||||||
|
return getStyleFontSize(styleValueAsNumber, styleValue);
|
||||||
|
}
|
||||||
|
if (Number.isNaN(styleValueAsNumber)) {
|
||||||
return styleValue;
|
return styleValue;
|
||||||
}
|
}
|
||||||
|
return styleValueAsNumber.toFixed();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the value of a style.
|
* Returns the value of a style.
|
||||||
|
|
Loading…
Reference in a new issue