Security News
Opengrep Emerges as Open Source Alternative Amid Semgrep Licensing Controversy
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
quill-cursors
Advanced tools
A collaborative editing module for the Quill text editor used by the Reedsy team.
npm install quill-cursors --save
quill-cursors
is a Quill module that exposes a number of methods to help display other users' cursors for
collaborative editing.
First, set up a Quill editor.
Next, load quill-cursors
through any of the options presented by UMD.
Then, register the quill-cursors
module:
Quill.register('modules/cursors', QuillCursors);
const quill = new Quill('#editor', {
modules: {
cursors: true,
}
});
Finally, use the exposed quill-cursors
methods to update the cursors (see below). For an example setup, see the
example code, which can be run with:
npm start
The quill-cursors
module has the following optional configuration:
template
string: override the default HTML template used for a cursorhideDelayMs
: number (default: 3000
): number of milliseconds to show the username flag before hiding ithideSpeedMs
: number (default: 400
): the duration of the flag hiding animation in millisecondsselectionChangeSource
string | null (default: api
): the event source to use when emitting selection-change
Provide these options when setting up the Quill editor:
const editor = new Quill('#editor', {
modules: {
cursors: {
template: '<div class="custom-cursor">...</div>',
hideDelayMs: 5000,
hideSpeedMs: 0,
selectionChangeSource: null,
},
},
});
template
For the custom template to work correctly with the module, it should closely follow the classes in the original template.
selectionChangeSource
By default, QuillJS will suppress selection-change
events when typing
to avoid noise.
However, you will probably want to update the quill-cursors
selection on both selection-change
and text-change
.
In order to aid this, quill-cursors
will automatically emit a selection-change
event on text-change
.
You can differentiate between user input and the quill-cursors
module by checking the source
argument for the
selection-change
event. By default, quill-cursors
will have source = 'api'
, but if you need to differentiate
between calls from quill-cursors
and other events, then you can change this source
using the selectionChangeSource
option.
If emitting an event is undesirable (eg you want selection-change
to act like the Quill default), then the
selectionChangeSource
can be set to null
, and an event will not be emitted. Note that in this case, you will need to
separately handle the text-change
event and update the cursor position.
The module instance can be retrieved through Quill's getModule
:
const cursors = editor.getModule('cursors');
createCursor
createCursor(id: string, name: string, color: string): Cursor;
Creates a Cursor
instance with the given id
. If a cursor with this id
already exists, a new one is not created.
id
string: the unique ID for the cursorname
string: the name to display on the cursorcolor
string: the CSS color to use for the cursorReturns a Cursor
object:
{
id: string;
name: string;
color: string;
range: Range; // See https://quilljs.com/docs/api/#selection-change
}
moveCursor
moveCursor(id: string, range: QuillRange): void;
Sets the selection range of the cursor with the given id
.
id
string: the ID of the cursor to moverange
Range: the selection rangeremoveCursor
removeCursor(id: string): void;
Removes the cursor with the given id
from the DOM.
id
string: the ID of the cursor to removeupdate
update(): void;
Redraws all of the cursors in the DOM.
clearCursors
clearCursors(): void;
Removes all the cursors from the DOM.
cursors
cursors(): Cursor[];
Returns an array of all the Cursor
objects in the DOM in no particular order.
This code is available under the MIT license.
2.0.2
FAQs
A multi cursor module for Quill.
The npm package quill-cursors receives a total of 3,812 weekly downloads. As such, quill-cursors popularity was classified as popular.
We found that quill-cursors demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.