Quick Start
For a swift start with BlockSuite, you can either kick off with ready-made examples for popular frameworks, or simply install the core packages to integrate it into your project.
Bootstrap Project
BlockSuite works with all common frameworks, you can start from these examples that basically builds a TodoMVC-like note app based on BlockSuite.
| Framework | Link | Maintaining |
| playground-apps | ✅ | |
| react-basic | ✅ | |
| vue-basic | ✅ | |
| angular-basic | ✅ | |
| preact-basic | ✅ | |
| svelte-basic | ✅ | |
| solid-basic | ✅ |
Init From Scratch
To use BlockSuite in your existing project, simply install these core packages:
pnpm install \
@blocksuite/presets@canary \
@blocksuite/blocks@canary \
@blocksuite/store@canaryKey takeaways in the snippet above:
- The
@blocksuite/presetspackage contains the prebuilt editors and opt-in additional UI components. - To work with the BlockSuite document model and first-party blocks, the
@blocksuite/storeand@blocksuite/blockspackages are required. - The BlockSuite
canaryversions are released daily based on the master branch, which is also used in production in AFFiNE.
Then you can use the prebuilt PageEditor out of the box, with an initialized doc instance attached as its document model:
The PageEditor here is a standard web component that can also be reused with <page-editor> HTML tag. Another EdgelessEditor also works similarly - simply attach the editor with a doc and you are all set.
For the doc.getBlockByFlavour and doc.updateBlock APIs used here, please see the introduction about block tree basics for further details.
As the next step, you can choose to:
- Explore how BlockSuite break down editors into different component types. Taking a look at the list of BlockSuite components may also be helpful.
- Try collaborative editing following the steps.
- Learn about basic concepts in BlockSuite framework that are used throughout the development of editors.
Note that BlockSuite is still under rapid development. For any questions or feedback, feel free to let us know!