Skip to content

Commit

Permalink
chore: ensure markup attributes are passed to the children
Browse files Browse the repository at this point in the history
E.g. when a span is used inside a strong-tag:
<strong>Hi, <span>everybody</span></strong>
  • Loading branch information
Ewout Quax committed Jan 21, 2025
1 parent 5340dfc commit d31fe55
Showing 1 changed file with 19 additions and 19 deletions.
38 changes: 19 additions & 19 deletions src/components/richTextInput.js
Original file line number Diff line number Diff line change
Expand Up @@ -113,7 +113,7 @@
floatLabel,
} = options;
const isDev = env === 'dev';
const optionValue = useText(valueProp, { rawValue: true });
const optionValue = useText(valueProp);
const [currentValue, setCurrentValue] = useState(optionValue);
const [valueKey, setValueKey] = useState(0);
const labelText = useText(label);
Expand Down Expand Up @@ -303,7 +303,6 @@
UL: (el) => ({ type: 'bulleted-list', align: el.getAttribute('align') }),
};

// COMPAT: `B` is omitted here because Google Docs uses `<b>` in weird ways.
const TEXT_TAGS = {
CODE: () => ({ code: true }),
DEL: () => ({ strikethrough: true }),
Expand All @@ -319,9 +318,10 @@
typeof window !== 'undefined' &&
/Mac|iPod|iPhone|iPad/.test(window.navigator.platform);

const deserialize = (el) => {
const deserialize = (el, markAttributes = {}) => {
if (el.nodeType === 3) {
return el.textContent;
// Node is a TEXT;
return jsx('text', markAttributes, el.textContent);
}
if (el.nodeType !== 1) {
return null;
Expand All @@ -331,6 +331,7 @@
}

const { nodeName } = el;
let nodeAttributes = { ...markAttributes };
let parent = el;

if (
Expand All @@ -341,31 +342,30 @@
// eslint-disable-next-line prefer-destructuring
parent = el.childNodes[0];
}
let children = Array.from(parent.childNodes).map(deserialize).flat();

if (children.length === 0) {
children = [{ text: '' }];
}

if (ELEMENT_TAGS[nodeName]) {
const attrs = ELEMENT_TAGS[nodeName](el);
return jsx('element', attrs, children);
}

// define attributes for text markup
if (TEXT_TAGS[nodeName]) {
const attrs = TEXT_TAGS[nodeName](el);
return children.map((child) => jsx('text', attrs, child));
nodeAttributes = { ...nodeAttributes, ...TEXT_TAGS[nodeName](el) };
}

if (!Element.isElementList(children)) {
const attrs = ELEMENT_TAGS.P(el);
children = jsx('element', attrs, children);
const children = Array.from(parent.childNodes)
.map((node) => deserialize(node, nodeAttributes))
.flat();

if (children.length === 0) {
children.push(jsx('text', nodeAttributes, ''));
}

if (el.nodeName === 'BODY') {
return jsx('fragment', {}, children);
}

// define attributes for text nodes
if (ELEMENT_TAGS[nodeName]) {
const attrs = ELEMENT_TAGS[nodeName](el);
return jsx('element', attrs, children);
}

return children;
};

Expand Down

0 comments on commit d31fe55

Please sign in to comment.