UNPKG

@eclipse-glsp/client

Version:

A sprotty-based client for GLSP

127 lines 6.29 kB
"use strict"; 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; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; var __param = (this && this.__param) || function (paramIndex, decorator) { return function (target, key) { decorator(target, key, paramIndex); } }; Object.defineProperty(exports, "__esModule", { value: true }); exports.LocalComputedBoundsCommand = exports.LocalComputedBoundsAction = exports.LocalRequestBoundsAction = void 0; /******************************************************************************** * Copyright (c) 2023-2024 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 ********************************************************************************/ const sprotty_1 = require("@eclipse-glsp/sprotty"); const inversify_1 = require("inversify"); const glsp_model_source_1 = require("../../base/model/glsp-model-source"); const layout_data_1 = require("./layout-data"); var LocalRequestBoundsAction; (function (LocalRequestBoundsAction) { function is(object) { return sprotty_1.RequestBoundsAction.is(object) && !glsp_model_source_1.ServerAction.is(object) && (0, sprotty_1.hasArrayProp)(object, 'elementIDs', true); } LocalRequestBoundsAction.is = is; function create(newRoot, elementIDs) { return { ...sprotty_1.RequestBoundsAction.create(newRoot), elementIDs }; } LocalRequestBoundsAction.create = create; function fromCommand({ root }, actionDispatcher, cause, elementIDs) { // do not modify the main model (modelChanged = false) but request local bounds calculation on hidden model actionDispatcher.dispatch(LocalRequestBoundsAction.create(root, elementIDs)); return { model: root, modelChanged: false, cause }; } LocalRequestBoundsAction.fromCommand = fromCommand; })(LocalRequestBoundsAction || (exports.LocalRequestBoundsAction = LocalRequestBoundsAction = {})); var LocalComputedBoundsAction; (function (LocalComputedBoundsAction) { function is(object) { return sprotty_1.ComputedBoundsAction.is(object) && glsp_model_source_1.ServerAction.is(object); } LocalComputedBoundsAction.is = is; function mark(action) { // mimic: we mark the computed bounds action as coming from the server so it is not sent to the server and handled locally glsp_model_source_1.ServerAction.mark(action); return action; } LocalComputedBoundsAction.mark = mark; })(LocalComputedBoundsAction || (exports.LocalComputedBoundsAction = LocalComputedBoundsAction = {})); let LocalComputedBoundsCommand = class LocalComputedBoundsCommand extends sprotty_1.Command { constructor(action) { super(); this.action = action; } execute(context) { var _a, _b; if (LocalComputedBoundsAction.is(this.action)) { if (!this.viewerOptions.needsClientLayout) { return context.root; } // apply computed bounds from the hidden model and return updated model to render new main model this.computedBoundsApplicator.apply(context.root, this.action); (_a = this.action.layoutData) === null || _a === void 0 ? void 0 : _a.forEach(({ elementId, layoutData }) => { const element = context.root.index.getById(elementId); if (element !== undefined) { layout_data_1.LayoutAware.setLayoutData(element, layoutData); } }); return context.root; } (_b = this.action.layoutData) === null || _b === void 0 ? void 0 : _b.forEach(({ elementId, layoutData }) => { const element = context.root.index.getById(elementId); if (element !== undefined) { layout_data_1.LayoutAware.setLayoutData(element, layoutData); } }); // computed bounds action from server -> we do not care and do not trigger any update of the main model return { model: context.root, modelChanged: false }; } undo(context) { return context.root; } redo(context) { return context.root; } }; exports.LocalComputedBoundsCommand = LocalComputedBoundsCommand; LocalComputedBoundsCommand.KIND = sprotty_1.ComputedBoundsAction.KIND; __decorate([ (0, inversify_1.inject)(sprotty_1.ComputedBoundsApplicator), __metadata("design:type", sprotty_1.ComputedBoundsApplicator) ], LocalComputedBoundsCommand.prototype, "computedBoundsApplicator", void 0); __decorate([ (0, inversify_1.inject)(sprotty_1.TYPES.ViewerOptions), __metadata("design:type", Object) ], LocalComputedBoundsCommand.prototype, "viewerOptions", void 0); exports.LocalComputedBoundsCommand = LocalComputedBoundsCommand = __decorate([ (0, inversify_1.injectable)(), __param(0, (0, inversify_1.inject)(sprotty_1.TYPES.Action)), __metadata("design:paramtypes", [Object]) ], LocalComputedBoundsCommand); //# sourceMappingURL=local-bounds.js.map