mirror of
https://github.com/ueberdosis/tiptap.git
synced 2025-01-19 14:53:00 +08:00
f387ad3dd4
* chore:(core): migrate to tsup * chore: migrate blockquote and bold to tsup * chore: migrated bubble-menu and bullet-list to tsup * chore: migrated more packages to tsup * chore: migrate code and character extensions to tsup * chore: update package.json to simplify build for all packages * chore: move all packages to tsup as a build process * chore: change ci build task * feat(pm): add prosemirror meta package * rfix: resolve issues with build paths & export mappings * docs: update documentation to include notes for @tiptap/pm * chore(pm): update tsconfig * chore(packages): update packages * fix(pm): add package export infos & fix dependencies * chore(general): start moving to pm package as deps * chore: move to tiptap pm package internally * fix(demos): fix demos working with new pm package * fix(tables): fix tables package * fix(tables): fix tables package * chore(demos): pinned typescript version * chore: remove unnecessary tsconfig * chore: fix netlify build * fix(demos): fix package resolving for pm packages * fix(tests): fix package resolving for pm packages * fix(tests): fix package resolving for pm packages * chore(tests): fix tests not running correctly after pm package * chore(pm): add files to files array * chore: update build workflow * chore(tests): increase timeout time back to 12s * chore(docs): update docs * chore(docs): update installation guides & pm information to docs * chore(docs): add link to prosemirror docs * fix(vue-3): add missing build step * chore(docs): comment out cdn link * chore(docs): remove semicolons from docs * chore(docs): remove unnecessary installation note * chore(docs): remove unnecessary installation note
90 lines
2.9 KiB
Markdown
90 lines
2.9 KiB
Markdown
---
|
||
description: Collaborative text editing can be fricking complex, but it doesn’t have to be that way.
|
||
icon: user-voice-line
|
||
---
|
||
|
||
# Collaboration
|
||
[![Version](https://img.shields.io/npm/v/@tiptap/extension-collaboration.svg?label=version)](https://www.npmjs.com/package/@tiptap/extension-collaboration)
|
||
[![Downloads](https://img.shields.io/npm/dm/@tiptap/extension-collaboration.svg)](https://npmcharts.com/compare/@tiptap/extension-collaboration?minimal=true)
|
||
|
||
The Collaboration extension enables you to collaborate with others in a single document. The implementation is based on [Y.js by Kevin Jahns](https://github.com/yjs/yjs), which is the coolest thing to [integrate collaborative editing](/guide/collaborative-editing) in your project.
|
||
|
||
The history works totally different in a collaborative editing setup. If you undo a change, you don’t want to undo changes of other users. To handle that behaviour this extension provides an own `undo` and `redo` command. Don’t load the default [`History`](/api/extensions/history) extension together with the Collaboration extension to avoid conflicts.
|
||
|
||
:::pro Pro Extension
|
||
We kindly ask you to [sponsor our work](/sponsor) when using this extension in production.
|
||
:::
|
||
|
||
## Installation
|
||
```bash
|
||
npm install @tiptap/extension-collaboration yjs y-websocket
|
||
```
|
||
|
||
## Settings
|
||
|
||
### document
|
||
An initialized Y.js document.
|
||
|
||
Default: `null`
|
||
|
||
```js
|
||
Collaboration.configure({
|
||
document: new Y.Doc(),
|
||
})
|
||
```
|
||
|
||
### field
|
||
Name of a Y.js fragment, can be changed to sync multiple fields with one Y.js document.
|
||
|
||
Default: `'default'`
|
||
|
||
```js
|
||
Collaboration.configure({
|
||
document: new Y.Doc(),
|
||
field: 'title',
|
||
})
|
||
```
|
||
|
||
### fragment
|
||
A raw Y.js fragment, can be used instead of `document` and `field`.
|
||
|
||
Default: `null`
|
||
|
||
```js
|
||
Collaboration.configure({
|
||
fragment: new Y.Doc().getXmlFragment('body'),
|
||
})
|
||
```
|
||
|
||
## Commands
|
||
The `Collboration` extension comes with its own history extension. Make sure to disable the default extension, if you’re working with the `StarterKit`.
|
||
|
||
### undo()
|
||
Undo the last change.
|
||
|
||
```js
|
||
editor.commands.undo()
|
||
```
|
||
### redo()
|
||
Redo the last change.
|
||
|
||
```js
|
||
editor.commands.redo()
|
||
```
|
||
|
||
## Keyboard shortcuts
|
||
| Command | Windows/Linux | macOS |
|
||
| ------- | ----------------------------------------------------- | --------------------------------------------- |
|
||
| undo() | `Control` `Z` | `Cmd` `Z` |
|
||
| redo() | `Shift` `Control` `Z`<br>`Control` `Y` | `Shift` `Cmd` `Z`<br>`Cmd` `Y` |
|
||
|
||
## Source code
|
||
[packages/extension-collaboration/](https://github.com/ueberdosis/tiptap/blob/main/packages/extension-collaboration/)
|
||
|
||
## Usage
|
||
:::warning Public
|
||
The content of this editor is shared with other users.
|
||
:::
|
||
https://embed.tiptap.dev/preview/Extensions/Collaboration?hideSource
|
||
https://embed.tiptap.dev/preview/Extensions/Collaboration
|