UNPKG

@theia/core

Version:

Theia is a cloud & desktop IDE framework implemented in TypeScript.

97 lines 3.95 kB
"use strict"; // ***************************************************************************** // Copyright (C) 2017 TypeFox 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-only WITH Classpath-exception-2.0 // ***************************************************************************** var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.ContextMenuRenderer = exports.ContextMenuAccess = exports.coordinateFromAnchor = exports.toAnchor = exports.Coordinate = void 0; /* eslint-disable @typescript-eslint/no-explicit-any */ const inversify_1 = require("inversify"); const disposable_1 = require("../common/disposable"); exports.Coordinate = Symbol('Coordinate'); function toAnchor(anchor) { return anchor instanceof HTMLElement ? { x: anchor.offsetLeft, y: anchor.offsetTop } : anchor; } exports.toAnchor = toAnchor; function coordinateFromAnchor(anchor) { const { x, y } = anchor instanceof MouseEvent ? { x: anchor.clientX, y: anchor.clientY } : anchor; return { x, y }; } exports.coordinateFromAnchor = coordinateFromAnchor; class ContextMenuAccess { constructor(toClose) { this.toDispose = new disposable_1.DisposableCollection(); this.onDispose = this.toDispose.onDispose; this.toDispose.push(toClose); } get disposed() { return this.toDispose.disposed; } dispose() { this.toDispose.dispose(); } } exports.ContextMenuAccess = ContextMenuAccess; let ContextMenuRenderer = class ContextMenuRenderer { constructor() { this.toDisposeOnSetCurrent = new disposable_1.DisposableCollection(); } /** * Currently opened context menu. * Rendering a new context menu will close the current. */ get current() { return this._current; } setCurrent(current) { if (this._current === current) { return; } this.toDisposeOnSetCurrent.dispose(); this._current = current; if (current) { this.toDisposeOnSetCurrent.push(current.onDispose(() => { this._current = undefined; })); this.toDisposeOnSetCurrent.push(current); } } render(options) { const resolvedOptions = this.resolve(options); const access = this.doRender(resolvedOptions); this.setCurrent(access); return access; } resolve(options) { const args = options.args ? options.args.slice() : []; if (options.includeAnchorArg !== false) { args.push(options.anchor); } return { ...options, args }; } }; ContextMenuRenderer = __decorate([ (0, inversify_1.injectable)() ], ContextMenuRenderer); exports.ContextMenuRenderer = ContextMenuRenderer; //# sourceMappingURL=context-menu-renderer.js.map