I actually tried collaborative editing using 'Tiptap' which can easily create a WYSIWYG rich text editor that can be collaboratively edited and works on all browsers
data:image/s3,"s3://crabby-images/af02f/af02f345d2fcb31ade656eeb5028a9b10be97612" alt=""
Tiptap is an open source toolkit for building rich text editors on the web. '
Dev toolkit for building collaborative editors – Tiptap
https://tiptap.dev/
Node.js must be installed to use Tiptap. From the URL below, select the installation method that matches your environment.
Installing Node.js using a package manager | Node.js
https://nodejs.org/en/download/package-manager
In order to use Ubuntu this time, I installed Node.js with the following code.
[code]curl -fsSL https://deb.nodesource.com/setup_lts.x | sudo -E bash - &&\
sudo apt-get install -y nodejs[/code]
This time, we will implement Tiptap on Next.js. Prepare a working directory with the code below.
[code]npx create-next-app[/code]
You can set the name and the library to use, so select as follows. This time I named it 'tiptap-test'.
Move the directory with the code below and start the application.
[code] cd tiptap-test
npm run dev[/code]
Since the URL is displayed, open it with a browser.
data:image/s3,"s3://crabby-images/a666d/a666d6fa46f77fb89f98adacaf087311ccd7849c" alt=""
It is OK if the Next.js page opens as shown in the figure below. As stated on the page, the contents of 'src/app/page.tsx' are displayed.
data:image/s3,"s3://crabby-images/8e4ef/8e4ef4dd741be5fe5c2acad250e4128e3ab9b0d3" alt=""
Next, set up Tiptap. Install the Tiptap library with the following command.
[code]npm install @tiptap/react @tiptap/pm @tiptap/starter-kit[/code]
Copy the code for 4 files described in the 'Setting Up Tiptap' item
data:image/s3,"s3://crabby-images/656b6/656b6f821dea8fe0115ff0d8cd1df8504dad0e54" alt=""
Create 4 files where 'page.tsx' is and paste the copied code in each. Furthermore, after entering ''use client'' at the top of index.tsx, replace './Note.jsx' and './types.js' with './Note.tsx' and ' ./types.ts”.
Similarly, in the import statement of Note.tsx, it is OK if you rewrite the part where the extension is '.js' to '.ts'.
data:image/s3,"s3://crabby-images/012a5/012a596b15579634b81186f8b8c7ee7dc8097744" alt=""
Open 'tsconfig.json' and add ''allowImportingTsExtensions': true,' to 'compilerOptions' so that it can be imported as '.ts'.
data:image/s3,"s3://crabby-images/11474/114743e650c8fe77bb1e6c6370ab9a633209e2ca" alt=""
Finally, open page.tsx, import the content of index.tsx, and place it in an appropriate part.
data:image/s3,"s3://crabby-images/72594/7259461fbf796244e6c5007733d1b14ff2899f92" alt=""
When you look at the browser, the editor is inserted. You have successfully set up the Tiptap editor.
data:image/s3,"s3://crabby-images/3002c/3002c1302b9816414cb92555d3225ed401a6f84c" alt=""
Next, we introduce a collaborative editing mechanism. Install the required libraries with the following command.
[code]npm install @tiptap/extension-collaboration yjs @hocuspocus/provider[/code]
Scroll to the bottom of
data:image/s3,"s3://crabby-images/04d4d/04d4d5738dacf5d0a53435287a14fe796c342ce9" alt=""
To get the data necessary to set up collaborative editing, go to Tiptap's top page and click 'Sign up'.
data:image/s3,"s3://crabby-images/bf8c2/bf8c2efd5d0b97c0901481d045ca15cfbb7ef4cb" alt=""
Enter your name, email address, password and click 'Register'.
data:image/s3,"s3://crabby-images/9debc/9debc601d7db072634cacb0d4ce28d5b881e1e3e" alt=""
Give the app an easy-to-understand name and click 'Let's collab!'
data:image/s3,"s3://crabby-images/d4f48/d4f48e5b2bcb8c3679ca31053af8d2e145352281" alt=""
Since the dashboard opens, copy the 'App ID' and save it at hand.
data:image/s3,"s3://crabby-images/4f7e2/4f7e2c877af7add859afc2ae7c81f5933441731d" alt=""
Then click 'Settings' and copy 'JWT' in the Authentication item.
data:image/s3,"s3://crabby-images/f357b/f357be377606553c23ce380674c96b00b069efd7" alt=""
Replace the 18th and 19th lines of 'Note.tsx' with the copied App ID and JWT and save.
data:image/s3,"s3://crabby-images/0c8ce/0c8ce6874cd2ac06bed344d34d6806fd1cca0dae" alt=""
Collaborative editing is now possible. If you open two browsers as a trial and edit one, it will be reflected in the other in real time.
data:image/s3,"s3://crabby-images/38549/385491443c10cf3f12d9ad07310cb9e541cc3bc9" alt=""
The free version of the backend service is limited to 5000 connections and 10 simultaneous accesses per month. According to the price list , the Starter plan with a monthly charge of $ 1.49 (about 220 yen) can handle up to 100,000 connections and 200 simultaneous accesses per month, and the Business plan with a monthly charge of $ 9.99 (about 1460 yen) is 1 million per month It can handle up to 1000 connections/simultaneous accesses.
Related Posts:
in Review, Software, Web Service, Web Application, Posted by log1d_ts