From 9aed11800f7550613d6f467e2298657dee564281 Mon Sep 17 00:00:00 2001 From: Bernhard Owen Josephus Date: Sun, 18 Aug 2024 18:05:41 +0800 Subject: [PATCH] fix bold tag isn't rendered as markdown when it has a style --- __tests__/ExpensiMark-Markdown-test.js | 2 ++ lib/ExpensiMark.ts | 5 +++-- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/__tests__/ExpensiMark-Markdown-test.js b/__tests__/ExpensiMark-Markdown-test.js index 297c8971..1ebfd21a 100644 --- a/__tests__/ExpensiMark-Markdown-test.js +++ b/__tests__/ExpensiMark-Markdown-test.js @@ -7,10 +7,12 @@ test('Test bold HTML replacement', () => { const boldTestStartString = 'This is a sentence, and it has some punctuation, words, and spaces. ' + 'test * testing* test*test*test. * testing * *testing * ' + 'This is a sentence, and it has some punctuation, words, and spaces. ' + + 'This is a bold sentence with style ' + 'test * testing* test*test*test. * testing * *testing *'; const boldTestReplacedString = 'This is a *sentence,* and it has some *punctuation, words, and spaces*. ' + '*test* * testing* test*test*test. * testing * *testing * ' + 'This is a *sentence,* and it has some *punctuation, words, and spaces*. ' + + 'This is a *bold sentence with style* ' + '*test* * testing* test*test*test. * testing * *testing *'; expect(parser.htmlToMarkdown(boldTestStartString)).toBe(boldTestReplacedString); diff --git a/lib/ExpensiMark.ts b/lib/ExpensiMark.ts index 8b97487c..422564f1 100644 --- a/lib/ExpensiMark.ts +++ b/lib/ExpensiMark.ts @@ -576,13 +576,14 @@ export default class ExpensiMark { }; // Determine if the outer tag is bold - const styleAttributeMatch = match.match(/style="(.*?)"/); + const fontWeightRegex = /style="([^"]*?\bfont-weight:\s*(\d+|bold|normal)[^"]*?)"/ + const styleAttributeMatch = match.match(fontWeightRegex); const isFontWeightBold = isBoldFromStyle(styleAttributeMatch ? styleAttributeMatch[1] : null); const isBold = styleAttributeMatch ? isFontWeightBold : tagName === 'b' || tagName === 'strong'; // Process nested spans with potential bold style const processedInnerContent = innerContent.replace(/])*>([\s\S]*?)<\/span>/gi, (nestedMatch, nestedContent) => { - const nestedStyleMatch = nestedMatch.match(/style="(.*?)"/); + const nestedStyleMatch = nestedMatch.match(fontWeightRegex); const isNestedBold = isBoldFromStyle(nestedStyleMatch ? nestedStyleMatch[1] : null); return updateSpacesAndWrapWithAsterisksIfBold(nestedContent, isNestedBold); });