Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix inline code formatting for text enclosed in backticks #4468

Merged
merged 4 commits into from
Nov 25, 2024

Conversation

marwan37
Copy link
Contributor

@marwan37 marwan37 commented Sep 21, 2023

Please describe your changes

In the current implementation of the @tiptap/extension-code, the regex pattern does not correctly format text enclosed in backticks when they are immediately preceded or followed by any character other than whitespace.

How did you accomplish your changes

Updated the inputRegex and pasteRegex patterns to the following:

export const inputRegex = /(?<!`)`([^`]+)`(?!`)/;
export const pasteRegex = /(?<!`)`([^`]+)`(?!`)/g;

The regex uses negative lookbehind and lookahead assertions to ensure that only single backticks are considered for formatting to avoid conflicts with potential code block syntax or other uses of multiple backticks.

How have you tested your changes

Tested in various scenarios to ensure that it correctly formats text as inline code blocks, and that it doesn't conflict with other extensions.

TipTap-LocalTest

How can we verify your changes

  1. Clone the repository and switch to the branch containing these changes.
  2. Start the app via npm run start and navigate to any playground
  3. Type text enclosed in backticks, with various surrounding characters.
  4. You should observe the text within the backticks being correctly formatted as inline code.
  5. Additionally, test with multiple backticks to ensure they don't interfere with the formatting.

Remarks

This change enhances the flexibility of the inline code formatting.

Checklist

  • The changes are not breaking the editor
  • Added tests where possible
  • Followed the guidelines
  • Fixed linting issues

Related issues

#4467
Issue #338 in BlockNote - Original issue where the bug was identified and discussed.

@netlify
Copy link

netlify bot commented Sep 21, 2023

Deploy Preview for tiptap-embed ready!

Name Link
🔨 Latest commit 66c8f9b
🔍 Latest deploy log https://app.netlify.com/sites/tiptap-embed/deploys/6744965c2dd9260008f84a7f
😎 Deploy Preview https://deploy-preview-4468--tiptap-embed.netlify.app
📱 Preview on mobile
Toggle QR Code...

QR Code

Use your smartphone camera to open QR code link.

To edit notification comments on pull requests, go to your Netlify site configuration.

@nperez0111 nperez0111 force-pushed the develop branch 2 times, most recently from bcaef5c to 7e7ae19 Compare June 12, 2024 04:33
@bdbch bdbch deleted the branch ueberdosis:develop June 26, 2024 21:57
@bdbch bdbch closed this Jun 26, 2024
@bdbch bdbch reopened this Jun 27, 2024
Copy link

changeset-bot bot commented Nov 25, 2024

🦋 Changeset detected

Latest commit: 66c8f9b

The changes in this PR will be included in the next version bump.

This PR includes changesets to release 54 packages
Name Type
@tiptap/extension-code Patch
@tiptap/core Patch
@tiptap/extension-blockquote Patch
@tiptap/extension-bold Patch
@tiptap/extension-bubble-menu Patch
@tiptap/extension-bullet-list Patch
@tiptap/extension-character-count Patch
@tiptap/extension-code-block-lowlight Patch
@tiptap/extension-code-block Patch
@tiptap/extension-collaboration-cursor Patch
@tiptap/extension-collaboration Patch
@tiptap/extension-color Patch
@tiptap/extension-document Patch
@tiptap/extension-dropcursor Patch
@tiptap/extension-floating-menu Patch
@tiptap/extension-focus Patch
@tiptap/extension-font-family Patch
@tiptap/extension-gapcursor Patch
@tiptap/extension-hard-break Patch
@tiptap/extension-heading Patch
@tiptap/extension-highlight Patch
@tiptap/extension-history Patch
@tiptap/extension-horizontal-rule Patch
@tiptap/extension-image Patch
@tiptap/extension-italic Patch
@tiptap/extension-link Patch
@tiptap/extension-list-item Patch
@tiptap/extension-list-keymap Patch
@tiptap/extension-mention Patch
@tiptap/extension-ordered-list Patch
@tiptap/extension-paragraph Patch
@tiptap/extension-placeholder Patch
@tiptap/extension-strike Patch
@tiptap/extension-subscript Patch
@tiptap/extension-superscript Patch
@tiptap/extension-table-cell Patch
@tiptap/extension-table-header Patch
@tiptap/extension-table-row Patch
@tiptap/extension-table Patch
@tiptap/extension-task-item Patch
@tiptap/extension-task-list Patch
@tiptap/extension-text-align Patch
@tiptap/extension-text-style Patch
@tiptap/extension-text Patch
@tiptap/extension-typography Patch
@tiptap/extension-underline Patch
@tiptap/extension-youtube Patch
@tiptap/html Patch
@tiptap/pm Patch
@tiptap/react Patch
@tiptap/starter-kit Patch
@tiptap/suggestion Patch
@tiptap/vue-2 Patch
@tiptap/vue-3 Patch

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

Copy link
Contributor

@nperez0111 nperez0111 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for your contribution @marwan37, sorry for the long wait!

@nperez0111 nperez0111 merged commit f79c05e into ueberdosis:develop Nov 25, 2024
4 checks passed
@nperez0111 nperez0111 mentioned this pull request Nov 26, 2024
5 tasks
@rfgamaral
Copy link
Contributor

This change introduced the following issue:

firefox_gjEVM9odIA

I spent some time trying to tweak the RegExp to keep this fix and avoid the bug that introduced, but I have a feeling that tweaking the RegExp will not be enough, I think the markInputRule and markPasteRule functions play a part in this.

@marwan37 Think you can have a look since you were the original author of this change?

(cc @nperez0111 for awareness; not sure if a fix for this is that straightforward, but if it's not, maybe a revert could be in order?)

@nperez0111
Copy link
Contributor

@rfgamaral what version are you using, because we've changed the regex since this was closed to remove the backtracking in: #5916

@rfgamaral
Copy link
Contributor

rfgamaral commented Jan 7, 2025

@rfgamaral what version are you using, because we've changed the regex since this was closed to remove the backtracking in: #5916

I tried with both the version that introduced this PR, and the latest, the issue exists on both.

That PR changed the implementation of the regex to not include lookbehind assertions (unsupported by Safari below 16.4), but it kept the RegExp change that introduces the new behaviour described in this PR (which also introduces the bug I just described). You can replicate the bug I described in the default text editor example (which I'm assuming is always using the latest production version).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
No open projects
Archived in project
Development

Successfully merging this pull request may close these issues.

4 participants