Skip to content
New issue

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

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

Already on GitHub? # to your account

feature: add support for blocknote transactions #1147

Open
wants to merge 2 commits into
base: refactor/clean-blockcontainer
Choose a base branch
from

Conversation

YousefED
Copy link
Collaborator

This is a POC for blocknote-level transactions. It should make it possible to clean our existing commands (those in blockManipulation further down by migrating away from tiptap-style commands). It also unlocks the possibility for userland-transactions.

For example, the following bug is fixed:

  • select a number of paragraphs
  • change type to "heading"
  • "undo" will undo them one by one (after the fix, "undo" will reset all headings back to paragraphs in one step as expected)

closes https://github.com/TypeCellOS/BlockNote/issues?q=is%3Aissue+is%3Aopen+undo

TODO:

  • add tests
  • See if there are bugs with this approach. For example, what if you call other functions in a transact block that depend on editor.state? It's likely they should read the state from the activeTransaction instead (diagnose, create tests, and fix)
  • if there are other BlockNote APIs called in a loop (similar to blocktype select), migrate them to use transact

Copy link

vercel bot commented Oct 13, 2024

The latest updates on your projects. Learn more about Vercel for Git ↗︎

Name Status Preview Updated (UTC)
blocknote ✅ Ready (Inspect) Visit Preview Oct 13, 2024 7:14pm
blocknote-website ✅ Ready (Inspect) Visit Preview Oct 13, 2024 7:14pm

@YousefED YousefED changed the title add support for blocknote transactions fix: add support for blocknote transactions Oct 13, 2024
@YousefED YousefED changed the title fix: add support for blocknote transactions feature: add support for blocknote transactions Oct 13, 2024
Comment on lines +488 to +509
/**
* Dispatch a transaction, but only if not in a "blocknote transact".
*/
public dispatch(tr: Transaction) {
if (!this.activeTransaction) {
this._tiptapEditor.dispatch(tr);
}
}

/**
* Execute a function within a "blocknote transaction".
* All changes to the editor within the transaction will be grouped together, so that
* we can dispatch them as a single operation (thus creating only a single undo step)
*/
public transact(func: () => void) {
this.activeTransaction = this._tiptapEditor.state.tr;
try {
func();
this._tiptapEditor.dispatch(this.activeTransaction);
} finally {
this.activeTransaction = undefined;
}
Copy link
Contributor

Choose a reason for hiding this comment

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

Just for awareness, Tiptap already has a way to capture transactions without immediately dispatching them: https://github.com/ueberdosis/tiptap/blob/44cae5badc07e715bf6554e7042a9e4e926e57b7/packages/core/src/Editor.ts#L414-L429

# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants