Plate
Hiring
Plate consulting:
Looking to hire:
DM
@zbeyens to get added to the list if your offer includes Plate contribution.
Introduction
Slate is a low-level editor
framework that helps you deal with difficult parts when building an
editor, such as events handlers, elements, formatting, commands,
rendering, serializing, normalizing, etc.
While you are trying to build your own editors, it still needs a lot of
skills to make something similar to
Quill or
build your editor right away with minimal slate knowledge.
@udecode/plate is built on top of slate to handle plugins and state
management for an optimal development experience. This repository comes
with a lot of plugins as elements, marks, serializers, normalizers,
queries, transforms, components and so on.
- 🏎 Simple Start
You only need one component to get started: <Plate>
- 🐻 State Management
to support multiple editor states.
- 💅 Design System
The API is design system friendly. We provide a default design system
for quick start but you can plug-in your own one using a single
- 🔌 40+ Packages
We enforce separation of concerns by packaging each feature for build
optimization and versioning.
- 🛠 Extensible
All plugins accept extensible options and if you need to fork a
plugin, all its functions are exported.
- 📦 Tree-shaking / ES modules
- ✅ TypeScript types
- ✅ Unit tested with slate@0.63.0 and slate-react@0.65.2
Documentation
To find out more see the following Plate documentation sections:
The documentation is far from being complete and will be constantly
evolving (as will the packages).
Contributing and project organization
Ideas and discussions
place for bringing opinions and contributions. Letting us know if we're
going in the right or wrong direction is great feedback and will be much
appreciated!
Development
Plate is a modular, multi-package, monorepo project. It consists of a
core package that creates the plugin system, based on which the plugin
packages are implemented.
your code to the project.
Packages
Core libraries
| Name | Version | Description |
|:-------------------------------------------|:------------------------------------------------------------------------------------------------------------------------------------------------------------------------|:------------------------------------------|
| [`@udecode/plate-common`](packages/common) | [
data:image/s3,"s3://crabby-images/c87f8/c87f89b6d0851f41240fe9742639b5b25229813a" alt="@udecode/plate-common npm package badge"
](https://www.npmjs.com/package/@udecode/plate-common) | Common queries, transforms and utilities. || [`@udecode/plate-core`](packages/core) | [
data:image/s3,"s3://crabby-images/c1ad5/c1ad5f2ffb387cbe346060d1f75ee580039e2b22" alt="@udecode/plate-core npm package badge"
](https://www.npmjs.com/package/@udecode/plate-core) | Core plate architecture. |
Element Plugins
| Name | Version | Description |
|:------------------------------------------------------------------|:------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|:----------------------------------------------------------|
| [`@udecode/plate-basic-elements`](packages/nodes/basic-elements) | [
data:image/s3,"s3://crabby-images/660a0/660a06e0caa7f7ebcb24dd2fe3a4e63d1aaa5698" alt="@udecode/plate-basic-elements npm package badge"
](https://www.npmjs.com/package/@udecode/plate-basic-elements) | Basic elements plugins. || [`@udecode/plate-alignment`](packages/nodes/alignment) | [
data:image/s3,"s3://crabby-images/969e6/969e676bad6458798c5bed11c8f27beb47ead1df" alt="@udecode/plate-alignment npm package badge"
](https://www.npmjs.com/package/@udecode/plate-alignment) | Text alignment plugin. || [`@udecode/plate-ui-alignment`](packages/ui/nodes/alignment) | [
data:image/s3,"s3://crabby-images/64d35/64d35d4ca756902a476e15d376bddd91ec18806b" alt="@udecode/plate-ui-alignment npm package badge"
](https://www.npmjs.com/package/@udecode/plate-ui-alignment) | Text alignment UI. || [`@udecode/plate-block-quote`](packages/nodes/block-quote/) | [
data:image/s3,"s3://crabby-images/46a83/46a83db77702c13b35b3c5986556c5bfc43937d2" alt="@udecode/plate-block-quote npm package badge"
](https://www.npmjs.com/package/@udecode/plate-block-quote) | Block quote plugin. || [`@udecode/plate-ui-block-quote`](packages/ui/nodes/block-quote/) | [
data:image/s3,"s3://crabby-images/623a4/623a45474bf4acdea8b9e715d72109219a0b5b77" alt="@udecode/plate-ui-block-quote npm package badge"
](https://www.npmjs.com/package/@udecode/plate-ui-block-quote) | Block quote UI. || [`@udecode/plate-code-block`](packages/nodes/code-block) | [
data:image/s3,"s3://crabby-images/afde0/afde00f06bda9764b89511b72901835595be7faa" alt="@udecode/plate-code-block npm package badge"
](https://www.npmjs.com/package/@udecode/plate-code-block) | Code block plugin. || [`@udecode/plate-ui-code-block`](packages/ui/nodes/code-block) | [
data:image/s3,"s3://crabby-images/d4a97/d4a97b88c7b352a568d85f31a230427bb1e5c465" alt="@udecode/plate-ui-code-block npm package badge"
](https://www.npmjs.com/package/@udecode/plate-ui-code-block) | Code block UI. || [`@udecode/plate-excalidraw`](packages/ui/nodes/excalidraw/) | [
data:image/s3,"s3://crabby-images/34db2/34db241b311f78e00fc97bf9ccded5a5a44a3634" alt="@udecode/plate-excalidraw npm package badge"
](https://www.npmjs.com/package/@udecode/plate-excalidraw) | Excalidraw plugin. || [`@udecode/plate-heading`](packages/nodes/heading/) | [
data:image/s3,"s3://crabby-images/06b2f/06b2f76203c25835d286e7569b81eda63b3c9f14" alt="@udecode/plate-heading npm package badge"
](https://www.npmjs.com/package/@udecode/plate-heading) | Headings (1-6) plugin. || [`@udecode/plate-link`](packages/nodes/link/) | [
data:image/s3,"s3://crabby-images/3ed27/3ed27787b86d3c9c831587562b6c96d1f3e3bd54" alt="@udecode/plate-link npm package badge"
](https://www.npmjs.com/package/@udecode/plate-link) | Link plugin. || [`@udecode/plate-ui-link`](packages/ui/nodes/link/) | [
data:image/s3,"s3://crabby-images/9508d/9508dd259f1d373cdbf5b58b8f2f68357a06e2c8" alt="@udecode/plate-ui-link npm package badge"
](https://www.npmjs.com/package/@udecode/plate-ui-link) | Link UI. || [`@udecode/plate-list`](packages/nodes/list) | [
data:image/s3,"s3://crabby-images/cc1f0/cc1f0736e5f12fc39a5cbc3cf11abf2028e87004" alt="@udecode/plate-list npm package badge"
](https://www.npmjs.com/package/@udecode/plate-list) | Bulleted, numbered and to-do list plugins. || [`@udecode/plate-ui-list`](packages/ui/nodes/list) | [
data:image/s3,"s3://crabby-images/1921d/1921d2cddfb2106420bc46fbef6c46e274ecaa31" alt="@udecode/plate-ui-list npm package badge"
](https://www.npmjs.com/package/@udecode/plate-ui-list) | List UI. || [`@udecode/plate-media`](packages/nodes/media) | [
data:image/s3,"s3://crabby-images/d198b/d198b879cc8295b7ef19e44ffc289715fac02df4" alt="@udecode/plate-media npm package badge"
](https://www.npmjs.com/package/@udecode/plate-media) | Media embed plugin. || [`@udecode/plate-ui-media`](packages/ui/nodes/media) | [
data:image/s3,"s3://crabby-images/17916/17916335d66e1393ed9793167bd581c0473e0bd6" alt="@udecode/plate-ui-media npm package badge"
](https://www.npmjs.com/package/@udecode/plate-ui-media) | Media embed UI. || [`@udecode/plate-mention`](packages/nodes/mention/) | [
data:image/s3,"s3://crabby-images/25303/253035452c6d613f244236026a0bbafc2e07bd53" alt="@udecode/plate-mention npm package badge"
](https://www.npmjs.com/package/@udecode/plate-mention) | Mention plugin (autocomplete `@mentions`, `#tags`, etc.). || [`@udecode/plate-ui-mention`](packages/ui/nodes/mention/) | [
data:image/s3,"s3://crabby-images/151dc/151dcc042de4a51e2ad87ea4dc06aac0e28de533" alt="@udecode/plate-ui-mention npm package badge"
](https://www.npmjs.com/package/@udecode/plate-ui-mention) | Mention UI. || [`@udecode/plate-paragraph`](packages/nodes/paragraph/) | [
data:image/s3,"s3://crabby-images/f624b/f624b2891075f2db607cec09c59debaa51bdd7b1" alt="@udecode/plate-paragraph npm package badge"
](https://www.npmjs.com/package/@udecode/plate-paragraph) | Paragraph plugin. || [`@udecode/plate-table`](packages/nodes/table/) | [
data:image/s3,"s3://crabby-images/29034/2903406735fbf28859c27181f0765a9d4a1fe092" alt="@udecode/plate-table npm package badge"
](https://www.npmjs.com/package/@udecode/plate-table) | Table plugin. || [`@udecode/plate-ui-table`](packages/ui/nodes/table/) | [
data:image/s3,"s3://crabby-images/371fc/371fc0455dc6400537256bbbb14ea08d8a9237cf" alt="@udecode/plate-ui-table npm package badge"
](https://www.npmjs.com/package/@udecode/plate-ui-table) | Table UI. |
Mark Plugins
| Name | Version | Description |
|:-----------------------------------------------------------|:---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|:----------------------------------------------------------------------------------------------|
| [`@udecode/plate-basic-marks`](packages/nodes/basic-marks) | [
data:image/s3,"s3://crabby-images/2f926/2f926cb16386fbad335c1149195b68a62b0f16f6" alt="@udecode/plate-basic-marks npm package badge"
](https://www.npmjs.com/package/@udecode/plate-basic-marks) | Basic marks plugins: bold, code, italic, strikethrough, subscript, superscript and underline. || [`@udecode/plate-font`](packages/nodes/font) | [
data:image/s3,"s3://crabby-images/40f73/40f73bfba60f97bdbaeaa55f4dc993950948f356" alt="@udecode/plate-font npm package badge"
](https://www.npmjs.com/package/@udecode/plate-font) | Font color and background color plugins. || [`@udecode/plate-highlight`](packages/nodes/highlight/) | [
data:image/s3,"s3://crabby-images/be1fe/be1fe39809b3479d13be6ccbe9f5b88040995c9c" alt="@udecode/plate-highlight npm package badge"
](https://www.npmjs.com/package/@udecode/plate-highlight) | Highlight plugin. || [`@udecode/plate-kbd`](packages/nodes/kbd/) | [
data:image/s3,"s3://crabby-images/2dc5c/2dc5cc4f16b9aff9845d0dab0a51fa11e16225c5" alt="@udecode/plate-kbd npm package badge"
](https://www.npmjs.com/package/@udecode/plate-kbd) | Keyboard input plugin. |
Serializer Plugins
| Name | Version | Description |
|:-------------------------------------------------------------------------|:---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|:----------------------------|
| [`@udecode/plate-serializer-md`](packages/serializers/md) | [
data:image/s3,"s3://crabby-images/e2563/e25637cda4bf22da4f4de3cb46f4832127237fee" alt="@udecode/plate-serializer-md npm package badge"
](https://www.npmjs.com/package/@udecode/plate-serializer-md) | Markdown serializer plugin. || [`@udecode/plate-serializer-csv`](packages/serializers/csv) | [
data:image/s3,"s3://crabby-images/5a8ae/5a8aed8233003f322a4f9d8ff186d9391cd1ce2e" alt="@udecode/plate-serializer-csv npm package badge"
](https://www.npmjs.com/package/@udecode/plate-serializer-csv) | CSV serializer plugin. |
Plugins
| Name | Version | Description |
|:--------------------------------------------------------------------|:---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|:---------------------------------------------------------------------------------------------------------------|
| [`@udecode/plate`](packages/plate) | [
data:image/s3,"s3://crabby-images/0f087/0f087ff9ab6d6e091392a5d3d4a7412aac6ddeca" alt="@udecode/plate npm package badge"
](https://www.npmjs.com/package/@udecode/plate) | All-in-one package. || [`@udecode/plate-autoformat`](packages/editor/autoformat) | [
data:image/s3,"s3://crabby-images/0d42b/0d42bef75db61319fc32e93101f01d46780dd539" alt="@udecode/plate-autoformat npm package badge"
](https://www.npmjs.com/package/@udecode/plate-autoformat) | Autoformatting plugin. Replaces predefined characters with a corresponding format (e.g. **foo** becomes bold). || [`@udecode/plate-break`](packages/editor/break) | [
data:image/s3,"s3://crabby-images/14313/1431383c7b9e44a1b46a1247f8535e5bf642fef4" alt="@udecode/plate-break npm package badge"
](https://www.npmjs.com/package/@udecode/plate-break) | Insert break plugins. || [`@udecode/plate-ui-dnd`](packages/ui/dnd) | [
data:image/s3,"s3://crabby-images/ff267/ff267b8afa6dff651d457c7dab879734bd9bb5a8" alt="@udecode/plate-ui-dnd npm package badge"
](https://www.npmjs.com/package/@udecode/plate-ui-dnd) | Drag and drop with [react-dnd](https://github.com/react-dnd/react-dnd). || [`@udecode/plate-find-replace`](packages/decorators/find-replace) | [
data:image/s3,"s3://crabby-images/5046f/5046f25a0c18194414822f3412f4e3f510a846da" alt="@udecode/plate-find-replace npm package badge"
](https://www.npmjs.com/package/@udecode/plate-find-replace) | Find and replace plugin. || [`@udecode/plate-ui-find-replace`](packages/ui/find-replace) | [
data:image/s3,"s3://crabby-images/639b4/639b443ae4e9f1050fec6045d48fc747704fb678" alt="@udecode/plate-ui-find-replace npm package badge"
](https://www.npmjs.com/package/@udecode/plate-ui-find-replace) | Find and replace UI. || [`@udecode/plate-node-id`](packages/editor/node-id) | [
data:image/s3,"s3://crabby-images/ad97a/ad97a7d50944f8583c72b359f5763feb35be4e73" alt="@udecode/plate-node-id npm package badge"
](https://www.npmjs.com/package/@udecode/plate-node-id) | Node ID plugin. || [`@udecode/plate-normalizers`](packages/editor/normalizers) | [
data:image/s3,"s3://crabby-images/e1d3f/e1d3fdff1cd9e0235f4bac8061f99cf5887b6150" alt="@udecode/plate-normalizers npm package badge"
](https://www.npmjs.com/package/@udecode/plate-normalizers) | Normalizer plugins. || [`@udecode/plate-reset-node`](packages/editor/reset-node) | [
data:image/s3,"s3://crabby-images/d371a/d371aaa00394b82c39f1a92f7a1b2a6d2618bc0e" alt="@udecode/plate-reset-node npm package badge"
](https://www.npmjs.com/package/@udecode/plate-reset-node) | Reset node plugin. || [`@udecode/plate-select`](packages/editor/select) | [
data:image/s3,"s3://crabby-images/09fb1/09fb1024b53db19fb6fead04c020eab71a7307ea" alt="@udecode/plate-select npm package badge"
](https://www.npmjs.com/package/@udecode/plate-select) | Node selecting plugins. || [`@udecode/plate-styled-components`](packages/ui/styled-components) | [
data:image/s3,"s3://crabby-images/56eea/56eea1ff97f9d617fb5925125282c70198dcb758" alt="@udecode/plate-ui-fluent npm package badge"
](https://www.npmjs.com/package/@udecode/plate-ui-fluent) | Styled components (Plate UI library). || [`@udecode/plate-trailing-block`](packages/editor/trailing-block) | [
data:image/s3,"s3://crabby-images/38f99/38f99764a43390e6107d79c285a92e385b46e075" alt="@udecode/plate-trailing-block npm package badge"
](https://www.npmjs.com/package/@udecode/plate-trailing-block) | Trailing-block plugin. || [`@udecode/plate-ui-toolbar`](packages/ui/toolbar) | [
data:image/s3,"s3://crabby-images/eb878/eb878728df065f78fa1aa4725ceaa3f6aee5f5e8" alt="@udecode/plate-ui-toolbar npm package badge"
](https://www.npmjs.com/package/@udecode/plate-ui-toolbar) | Toolbar UI (balloon, heading, buttons, etc.). || [`@udecode/plate-test-utils`](packages/test-utils/) | [
data:image/s3,"s3://crabby-images/3ee60/3ee60fbe9c362bb6add2f4b63275bd6b70a317b0" alt="@udecode/plate-test-utils npm package badge"
](https://www.npmjs.com/package/@udecode/plate-test-utils) | Test utilities. |
Looking for slate-plugins?
This repo has been renamed to plate. The name change should not
disrupt any current usage, repo clones, pull requests or issue
reporting. Links should redirect to the new location. The library
formerly known as @udecode/slate-plugins is now available as
@udecode/plate.
Author's Note
editor like many of you and my first initiative was to spend months
to share this work, while hundreds of developers were coding and
debugging the exact same features. Open-source is a long-term
investment for a bug-free product and reducing technical debt, so
I can only encourage you to join this collaboration. Our goal is to
build a fully-featured editor.
Contributors
🌟 Stars and 📥 Pull requests are welcome! Don't hesitate to share
get started, or find us on
the time to guide you.
Thanks goes to these wonderful people
This project follows the
specification. Contributions of any kind welcome!
License