Compare commits

...

25 Commits

Author SHA1 Message Date
Alec LaLonde
d13b0ec4d5
Merge pull request #21 from CGNonofr/show-tooltip-on-hover
Show tooltip on cursor hover
2022-09-19 20:40:23 -06:00
Alec LaLonde
6edfb6253d
Merge branch 'master' into show-tooltip-on-hover 2022-09-19 20:40:14 -06:00
Alec LaLonde
03f782bda8
Merge pull request #24 from CodinGame/fix-label-xss
Prevent XSS in tooltip label
2022-09-19 20:30:32 -06:00
Loïc Mangeonjean
e37ce9b99c fix: prevent XSS in tooltip label 2022-09-15 10:28:11 +02:00
Alec LaLonde
cdefbb151f
Merge pull request #22 from CodinGame/provide-class-name-to-tweak-display
Allow adding custom element class names
2022-06-22 14:22:28 -06:00
Samuel Olivier
91bdec1bb7 add additional elements class names 2022-06-13 10:19:46 +02:00
Loïc Mangeonjean
38713d59b9 Add showTooltipOnHover option 2022-05-18 15:10:45 +02:00
Loïc Mangeonjean
a3b0b8a57c Add missing type 2022-05-18 15:09:57 +02:00
Loïc Mangeonjean
4c03bc00eb Refactor tooltip management a little 2022-05-18 15:09:46 +02:00
Michael MacFadden
6ece72028e Updated dependencies and version. 2021-04-08 11:06:51 -05:00
Michael MacFadden
d221975bb7
Merge pull request #13 from CGNonofr/monaco-22
Accept new monaco-editor versions
2021-02-23 10:12:38 -07:00
Loïc Mangeonjean
5091b32d6f Accept new monaco-editor versions 2021-02-09 16:45:03 +01:00
Michael MacFadden
1e9743f5f9 Updated for 0.3.1 2020-11-08 16:24:21 -06:00
Michael MacFadden
8fbca4da22
Merge pull request #9 from convergencelabs/dependabot/npm_and_yarn/elliptic-6.5.3
Bump elliptic from 6.5.2 to 6.5.3
2020-11-08 14:21:16 -08:00
Michael MacFadden
ac5c60a2cf
Merge pull request #10 from CGNonofr/monaco-21
Accept monaco-editor until v0.21
2020-11-06 05:19:37 -08:00
Loïc Mangeonjean
5054f9ecba Accept monaco-editor until v0.21 2020-11-05 19:14:41 +01:00
dependabot[bot]
9b7119067e
Bump elliptic from 6.5.2 to 6.5.3
Bumps [elliptic](https://github.com/indutny/elliptic) from 6.5.2 to 6.5.3.
- [Release notes](https://github.com/indutny/elliptic/releases)
- [Commits](https://github.com/indutny/elliptic/compare/v6.5.2...v6.5.3)

Signed-off-by: dependabot[bot] <support@github.com>
2020-08-01 09:49:51 +00:00
Michael MacFadden
afb2b80dbb
Merge pull request #5 from convergencelabs/dependabot/npm_and_yarn/acorn-5.7.4
Bump acorn from 5.7.3 to 5.7.4
2020-07-04 22:47:35 -05:00
dependabot[bot]
e2f9f40507
Bump acorn from 5.7.3 to 5.7.4
Bumps [acorn](https://github.com/acornjs/acorn) from 5.7.3 to 5.7.4.
- [Release notes](https://github.com/acornjs/acorn/releases)
- [Commits](https://github.com/acornjs/acorn/compare/5.7.3...5.7.4)

Signed-off-by: dependabot[bot] <support@github.com>
2020-03-16 16:42:39 +00:00
Michael MacFadden
d0cf867f78 Prepping for 0.3.0. 2020-03-06 09:29:01 -06:00
Michael MacFadden
be5d65c147 Fixes #3. 2020-03-06 09:28:31 -06:00
Michael MacFadden
705b55b117
Merge pull request #4 from CGNonofr/monaco-19
Update to work with latest monaco
2020-03-05 10:19:36 -05:00
Loïc Mangeonjean
645123dbb7 Regenerate package-lock 2020-03-03 16:41:24 +01:00
Loïc Mangeonjean
3e0008ed78 Update to work with latest monaco 2020-03-03 16:39:32 +01:00
Loïc Mangeonjean
6a17b25fcc Accept monaco-editor until v0.20 2020-03-03 16:39:32 +01:00
5 changed files with 2710 additions and 2476 deletions

View File

@ -1,6 +1,13 @@
# Change Log
## [v0.3.1](https://github.com/convergencelabs/monaco-collab-ext/tree/0.3.1) (2020-11-08)
## [v0.2.0](https://github.com/convergencelabs/monaco-collab-ext/tree/0.1.0) (2020-01-08)
- Add support for Monaco >= 0.21
## [v0.3.0](https://github.com/convergencelabs/monaco-collab-ext/tree/0.3.0) (2020-03-06)
- Add support for Monaco >= 0.19.0. [#3](https://github.com/convergencelabs/monaco-collab-ext/issues/3)
## [v0.2.0](https://github.com/convergencelabs/monaco-collab-ext/tree/0.2.0) (2020-01-08)
- Added remote select hover labels. [#2](https://github.com/convergencelabs/monaco-collab-ext/pull/2)

5075
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -1,6 +1,6 @@
{
"name": "@convergencelabs/monaco-collab-ext",
"version": "0.2.0",
"version": "0.3.2",
"title": "Monaco Editor Collaborative Extensions",
"description": "Collaborative Extensions for the Monaco Editor",
"keywords": [
@ -30,23 +30,23 @@
"access": "public"
},
"dependencies": {
"monaco-editor": "^0.15.6"
"monaco-editor": ">=0.15.6"
},
"devDependencies": {
"@babel/cli": "7.2.3",
"@babel/core": "7.2.2",
"@babel/node": "7.2.2",
"@babel/preset-env": "7.2.3",
"@babel/preset-stage-3": "7.0.0",
"@babel/preset-typescript": "7.1.0",
"@babel/register": "7.0.0",
"babel-plugin-module-resolver": "3.1.1",
"@babel/cli": "7.13.14",
"@babel/core": "7.13.15",
"@babel/node": "7.13.13",
"@babel/preset-env": "7.13.15",
"@babel/preset-stage-3": "7.8.3",
"@babel/preset-typescript": "7.13.0",
"@babel/register": "7.13.14",
"babel-plugin-module-resolver": "4.1.0",
"babel-plugin-transform-class-properties": "6.24.1",
"del": "3.0.0",
"gulp": "4.0.0",
"del": "6.0.0",
"gulp": "4.0.2",
"gulp-babel": "8.0.0",
"gulp-bump": "3.1.1",
"gulp-clean-css": "4.0.0",
"gulp-bump": "3.2.0",
"gulp-clean-css": "4.3.0",
"gulp-filter-each": "1.0.1",
"gulp-header": "2.0.7",
"gulp-insert": "0.5.0",

View File

@ -23,6 +23,11 @@ export interface IRemoteCursorManagerOptions {
*/
editor: monaco.editor.ICodeEditor;
/**
* An additional class name for the cursor element, to tweak the default style
*/
className?: string;
/**
* Determines if tooltips will be shown when the cursor is moved.
*/
@ -33,6 +38,16 @@ export interface IRemoteCursorManagerOptions {
* it was last moved.
*/
tooltipDuration?: number;
/**
* Show the tooltip when the cursor is hovered
*/
showTooltipOnHover?: boolean;
/**
* An additional class name for the tooltip element, to tweak the default style
*/
tooltipClassName?: string;
}
/**
@ -47,7 +62,7 @@ export class RemoteCursorManager {
* The default values for optional parameters.
* @internal
*/
private static readonly DEFAULT_OPTIONS = {tooltips: true, tooltipDuration: 1};
private static readonly DEFAULT_OPTIONS: Partial<IRemoteCursorManagerOptions> = {tooltips: true, tooltipDuration: 1, showTooltipOnHover: false};
/**
* A counter that generates unique ids for the cursor widgets.
@ -116,10 +131,13 @@ export class RemoteCursorManager {
const cursorWidget = new RemoteCursorWidget(
this._options.editor,
widgetId,
this._options.className,
color,
label,
this._options.tooltips,
tooltipDurationMs,
this._options.showTooltipOnHover,
this._options.tooltipClassName,
() => this.removeCursor(id));
this._cursorWidgets.set(id, cursorWidget);

View File

@ -12,6 +12,21 @@ import {EditorContentManager} from "./EditorContentManager";
import {OnDisposed} from "./OnDisposed";
import {Validation} from "./Validation";
interface IConfiguration {
readonly lineHeight: number;
}
function getConfiguration(editorInstance: editor.ICodeEditor): IConfiguration {
// Support for Monaco < 0.19.0
if (typeof (editorInstance as any).getConfiguration === "function") {
return (editorInstance as any).getConfiguration();
}
return {
lineHeight: editorInstance.getOption(editor.EditorOption.lineHeight)
};
}
/**
* This class implements a Monaco Content Widget to render a remote user's
* cursor, and an optional tooltip.
@ -36,10 +51,13 @@ export class RemoteCursorWidget implements editor.IContentWidget, IDisposable {
constructor(codeEditor: editor.ICodeEditor,
widgetId: string,
className: string | undefined,
color: string,
label: string,
tooltipEnabled: boolean,
tooltipDuration: number,
showTooltipOnHover: boolean,
tooltipClassName: string | undefined,
onDisposed: OnDisposed) {
this._editor = codeEditor;
this._tooltipDuration = tooltipDuration;
@ -47,18 +65,18 @@ export class RemoteCursorWidget implements editor.IContentWidget, IDisposable {
this._onDisposed = onDisposed;
// Create the main node for the cursor element.
const {lineHeight} = this._editor.getConfiguration();
const {lineHeight} = getConfiguration(this._editor);
this._domNode = document.createElement("div");
this._domNode.className = "monaco-remote-cursor";
this._domNode.className = classNames('monaco-remote-cursor', className)
this._domNode.style.background = color;
this._domNode.style.height = `${lineHeight}px`;
// Create the tooltip element if the tooltip is enabled.
if (tooltipEnabled) {
this._tooltipNode = document.createElement("div");
this._tooltipNode.className = "monaco-remote-cursor-tooltip";
this._tooltipNode.className = classNames('monaco-remote-cursor-tooltip', tooltipClassName)
this._tooltipNode.style.background = color;
this._tooltipNode.innerHTML = label;
this._tooltipNode.innerText = label;
this._domNode.appendChild(this._tooltipNode);
// we only need to listen to scroll positions to update the
@ -66,6 +84,16 @@ export class RemoteCursorWidget implements editor.IContentWidget, IDisposable {
this._scrollListener = this._editor.onDidScrollChange(() => {
this._updateTooltipPosition();
});
if (showTooltipOnHover) {
this._domNode.style.pointerEvents = 'auto';
this._domNode.addEventListener('mouseover', () => {
this._setTooltipVisible(true);
})
this._domNode.addEventListener('mouseout', () => {
this._setTooltipVisible(false);
})
}
} else {
this._tooltipNode = null;
this._scrollListener = null;
@ -156,17 +184,10 @@ export class RemoteCursorWidget implements editor.IContentWidget, IDisposable {
}
private _showTooltip(): void {
this._updateTooltipPosition();
if (this._hideTimer !== null) {
clearTimeout(this._hideTimer);
} else {
this._setTooltipVisible(true);
}
this._setTooltipVisible(true);
this._hideTimer = setTimeout(() => {
this._setTooltipVisible(false);
this._hideTimer = null;
}, this._tooltipDuration);
}
@ -182,7 +203,12 @@ export class RemoteCursorWidget implements editor.IContentWidget, IDisposable {
}
private _setTooltipVisible(visible: boolean): void {
if (this._hideTimer !== null) {
clearTimeout(this._hideTimer);
this._hideTimer = null;
}
if (visible) {
this._updateTooltipPosition();
this._tooltipNode.style.opacity = "1.0";
} else {
this._tooltipNode.style.opacity = "0";
@ -228,3 +254,7 @@ export class RemoteCursorWidget implements editor.IContentWidget, IDisposable {
}
}
}
function classNames(...names: (string|undefined|null)[]) {
return names.filter(className => className != null && className.length > 0).join(' ')
}