UNPKG

@eclipse-glsp/client

Version:

A sprotty-based client for GLSP

72 lines 3.74 kB
"use strict"; /******************************************************************************** * Copyright (c) 2023-2025 Business Informatics Group (TU Wien) 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 ********************************************************************************/ 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.RevealEdgeElementSuggestionProvider = void 0; const sprotty_1 = require("@eclipse-glsp/sprotty"); const inversify_1 = require("inversify"); const autocomplete_suggestion_provider_1 = require("../../../base/auto-complete/autocomplete-suggestion-provider"); const model_1 = require("../../../model"); let RevealEdgeElementSuggestionProvider = class RevealEdgeElementSuggestionProvider { get id() { return 'glsp.reveal-edge-element-suggestion'; } canHandle(context) { return context === autocomplete_suggestion_provider_1.AutocompleteSuggestionProviderContext.CANVAS; } async getSuggestions(root, text) { const edges = (0, sprotty_1.toArray)(root.index.all().filter(element => element instanceof model_1.GEdge)); return edges.map(edge => ({ element: edge, action: { label: `[${edge.type}] ${this.getEdgeLabel(root, edge)}`, actions: this.createActions(edge), icon: (0, sprotty_1.codiconCSSString)('arrow-both') } })); } createActions(edge) { return [ sprotty_1.SelectAction.create({ selectedElementsIDs: [edge.id] }), sprotty_1.CenterAction.create([edge.sourceId, edge.targetId], { retainZoom: true }) ]; } getEdgeLabel(root, edge) { var _a, _b; let sourceName = ''; let targetName = ''; const sourceNode = root.index.getById(edge.sourceId); const targetNode = root.index.getById(edge.targetId); if (sourceNode !== undefined) { sourceName = (_a = (0, sprotty_1.name)(sourceNode)) !== null && _a !== void 0 ? _a : sourceNode.type; } if (targetNode !== undefined) { targetName = (_b = (0, sprotty_1.name)(targetNode)) !== null && _b !== void 0 ? _b : targetNode.type; } return sourceName + ' -> ' + targetName; } }; exports.RevealEdgeElementSuggestionProvider = RevealEdgeElementSuggestionProvider; exports.RevealEdgeElementSuggestionProvider = RevealEdgeElementSuggestionProvider = __decorate([ (0, inversify_1.injectable)() ], RevealEdgeElementSuggestionProvider); //# sourceMappingURL=edge-element-suggestions.js.map