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

[Feature] contenteditable="false" Inline Elements #472

Open
MrAlexand0r opened this issue Nov 25, 2024 · 2 comments
Open

[Feature] contenteditable="false" Inline Elements #472

MrAlexand0r opened this issue Nov 25, 2024 · 2 comments

Comments

@MrAlexand0r
Copy link

MrAlexand0r commented Nov 25, 2024

Hello!

I'm implementing placeholders in my application, but encountered minor issues using Squire:

  1. Backspace doesn't delete Inline Elements as it would with Block Types.
  2. The cursor sometimes gets placed inside the readonly element, causing unusual behavior.
firefox_DyL6rOmqVu.mp4

As seen in this video, when adding a character, in this example a whitespace , it's correctly added outside the contenteditable=false span. However, upon deleting it again, the cursor jumps inside the readonly span, causing unwanted behvaiour, like when pressing Enter, the element gets split up into two separate elements.

Regarding 1: There's existing logic for similar behavior with block elements, but not for inline elements.

if (!(previous as HTMLElement).isContentEditable) {
detachUneditableNode(previous, root);
return;
}

I'm still looking for a solution to the second issue. Could you perhaps point me in the right direction?

If you're open to adding this feature to the editor, I can create a CodeSandbox and potentially even a Pull Request.

MrAlexand0r pushed a commit to MrAlexand0r/solv-Squire that referenced this issue Nov 29, 2024
MrAlexand0r pushed a commit to MrAlexand0r/solv-Squire that referenced this issue Nov 29, 2024
…n AFTER contenteditable=false element instead of inside
MrAlexand0r pushed a commit to MrAlexand0r/solv-Squire that referenced this issue Nov 29, 2024
…hey shouldn't, fixed compilation error caused by missing nullcheck
@neilj
Copy link
Member

neilj commented Dec 12, 2024

I don't have any immediate ideas, as this is not something we've needed to handle. I'd consider a PR if it didn't require extensive changes.

@MrAlexand0r
Copy link
Author

I already created a pull request that fixes the most glaring issues with non editable inline elements.
Can you take a look? :)

#473

MrAlexand0r pushed a commit to MrAlexand0r/solv-Squire that referenced this issue Jan 9, 2025
…possible due to startContainer.isContentEditable being undefined on text nodes
MrAlexand0r pushed a commit to MrAlexand0r/solv-Squire that referenced this issue Jan 10, 2025
…t by iterating parent nodes instead of only checking the startContainer (which does not work)
MrAlexand0r pushed a commit to MrAlexand0r/solv-Squire that referenced this issue Jan 20, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants