@eclipse-glsp/client
Version:
A sprotty-based client for GLSP
44 lines (42 loc) • 2.09 kB
text/typescript
/********************************************************************************
* Copyright (c) 2020-2023 EclipseSource and others.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the Eclipse
* Public License v. 2.0 are satisfied: GNU General Public License, version 2
* with the GNU Classpath Exception which is available at
* https://www.gnu.org/software/classpath/license.html.
*
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
********************************************************************************/
import { injectable } from 'inversify';
import { MouseListener, GModelElement } from '@eclipse-glsp/sprotty';
/**
* A mouse listener that clears the document selection on click
*
* Clicking on SVG elements doesn't update the document selection. In the context of diagramming
* with GLSP, this is unnatural, as the user would expect that clicking in the diagram (e.g. to
* select a diagram element) would clear any other selection state in the DOM. From a technical
* point of view, an active selection in the document after clicking into the diagram may also
* lead to bogus target elements in certain browser events, such as clipboard events, etc.
*
* This listener helps to overcome this problem by actively clearing any existing selection in
* the document, if the user clicks into the diagram.
*/
@injectable()
export class SelectionClearingMouseListener extends MouseListener {
override mouseDown(_target: GModelElement, event: MouseEvent): never[] {
const selection = document.getSelection();
// eslint-disable-next-line no-null/no-null
if (selection === null) {
return [];
}
selection.removeAllRanges();
selection.addRange(document.createRange());
return [];
}
}