Skip to content

BlockSuite Overview

BlockSuite is a toolkit for building collaborative editors and applications. It embraces the document-centric approach to facilitate the development of more flexible, diverse, and scalable editable interfaces.

We believe that for modern collaborative editing applications, the overall application data flow should be consistently modeled and reused on a larger scale, reducing the interoperability cost between editor and non-editor components. This is why BlockSuite completely separates the collaborative document model from the editor. This separation allows any UI component, whether part of an editor or not, to function effectively by simply attaching it to the same document, offering a more flexible editing experience.

showcase-doc-edgeless-editors

For an understanding of the design philosophy advocated by BlockSuite, welcome to read our Document-Centric, CRDT-Native post.

Based on this concept, BlockSuite starts with a foundational block-based document model and independently implements a series of collaborative editing infrastructures, including editors. This means that with BlockSuite, you can choose to:

  • Build new editors from the ground up based on the BlockSuite framework.
  • Or, reuse multiple first-party BlockSuite editors right out of the box:
    • DocEditor: Built entirely from scratch, DocEditor is a comprehensive block-based document editor, offering extensive customization and flexibility.
    • EdgelessEditor: Featuring canvas-based graphics rendering at its core with sophisticated rich-text features, EdgelessEditor offers unique functionalities and decent performance in whiteboard editing.

The BlockSuite project is structured around key packages that are categorized into two groups: a headless framework and prebuilt editing components.

Headless Framework
@blocksuite/storeData layer for modeling collaborative document states. It is natively built on the CRDT library Yjs, powering all BlockSuite documents with built-in real-time collaboration and time-travel capabilities.
@blocksuite/inlineMinimal rich text components for inline editing. BlockSuite allows spliting rich text content in different block nodes into different inline editors, making complex content conveniently composable. This significantly reduces the complexity required to implement traditional rich text editing features.
@blocksuite/block-stdFramework-agnostic library for modeling editable blocks. Its capabilities cover the structure of block fields, events, selection, clipboard support, etc.
@blocksuite/litIntermediate layer for adapting the block tree to the lit framework component tree UI. BlockSuite uses lit as the default framework because lit components are native web components, avoiding synchronization issues between the component tree and DOM tree during complex editing.
Prebuilt Components
@blocksuite/blocksDefault block implementations for composing preset editors, including widgets belonging to each block.
@blocksuite/presetsPlug-and-play editable components including editors (DocEditor / EdgelessEditor) and auxiliary UI components named fragments (CopilotPanel, DocTitle...).

This can be illustrated as the diagram below:

package-overview.png

In addition to extending custom blocks, here are what you can also conveniently achieve with BlockSuite:

  • Writing type-safe complex editing logic based on the command mechanism, similar to react hooks designed for document editing.
  • Persistence of documents and compatibility with various third-party formats (such as markdown and HTML) based on block snapshot and transformer.
  • Incremental updates, real-time collaboration, local-first state management, and even decentralized data synchronization based on the document streaming mechanism.
  • State scheduling across multiple documents and reusing one document in multiple editors.

To try out BlockSuite, refer to the Quick Start document and start with the preset editors in @blocksuite/presets.

🚧 BlockSuite is currently in its early stage, with some extension capabilities still under refinement. Hope you can stay tuned, try it out, or share your feedback!