@theia/core
Version:
Theia is a cloud & desktop IDE framework implemented in TypeScript.
194 lines • 9.59 kB
JavaScript
"use strict";
// *****************************************************************************
// Copyright (C) 2022 Ericsson 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;
};
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.CompressedTreeWidget = void 0;
require("../../../../src/browser/tree/tree-compression/tree-compression.css");
const inversify_1 = require("inversify");
const React = require("react");
const context_menu_renderer_1 = require("../../context-menu-renderer");
const tree_compression_service_1 = require("./tree-compression-service");
const tree_1 = require("../tree");
const tree_widget_1 = require("../tree-widget");
const tree_selection_1 = require("../tree-selection");
const tree_expansion_1 = require("../tree-expansion");
const tree_view_welcome_widget_1 = require("../tree-view-welcome-widget");
const compressed_tree_model_1 = require("./compressed-tree-model");
let CompressedTreeWidget = class CompressedTreeWidget extends tree_view_welcome_widget_1.TreeViewWelcomeWidget {
constructor(props, model, contextMenuRenderer) {
super(props, model, contextMenuRenderer);
this.model = model;
this.rows = new Map();
}
toggleCompression(newCompression = !this.compressionToggle.compress) {
if (newCompression !== this.compressionToggle.compress) {
this.compressionToggle.compress = newCompression;
this.updateRows();
}
}
shouldDisplayNode(node) {
if (this.compressionToggle.compress && this.compressionService.isCompressionParticipant(node) && !this.compressionService.isCompressionHead(node)) {
return false;
}
return super.shouldDisplayNode(node);
}
getDepthForNode(node, depths) {
var _a;
if (!this.compressionToggle.compress) {
return super.getDepthForNode(node, depths);
}
const parent = (_a = this.compressionService.getCompressionHead(node.parent)) !== null && _a !== void 0 ? _a : node.parent;
const parentDepth = depths.get(parent);
return parentDepth === undefined ? 0 : tree_1.TreeNode.isVisible(node.parent) ? parentDepth + 1 : parentDepth;
}
toNodeRow(node, index, depth) {
if (!this.compressionToggle.compress) {
return super.toNodeRow(node, index, depth);
}
const row = { node, index, depth };
if (this.compressionService.isCompressionHead(node)) {
row.compressionChain = this.compressionService.getCompressionChain(node);
}
return row;
}
doRenderNodeRow({ node, depth, compressionChain }) {
const nodeProps = { depth, compressionChain };
return React.createElement(React.Fragment, null,
this.renderIndent(node, nodeProps),
this.renderNode(node, nodeProps));
}
rowIsSelected(node, props) {
if (this.compressionToggle.compress && props.compressionChain) {
return props.compressionChain.some(participant => tree_selection_1.SelectableTreeNode.isSelected(participant));
}
return tree_selection_1.SelectableTreeNode.isSelected(node);
}
getCaptionAttributes(node, props) {
var _a, _b;
const operativeNode = (_b = (_a = props.compressionChain) === null || _a === void 0 ? void 0 : _a.tail()) !== null && _b !== void 0 ? _b : node;
return super.getCaptionAttributes(operativeNode, props);
}
getCaptionChildren(node, props) {
if (!this.compressionToggle.compress || !props.compressionChain) {
return super.getCaptionChildren(node, props);
}
return props.compressionChain.map((subNode, index, self) => {
const classes = ['theia-tree-compressed-label-part'];
if (tree_selection_1.SelectableTreeNode.isSelected(subNode)) {
classes.push('theia-tree-compressed-selected');
}
const handlers = this.getCaptionChildEventHandlers(subNode, props);
const caption = React.createElement("span", Object.assign({ className: classes.join(' '), key: subNode.id }, handlers), super.getCaptionChildren(subNode, props));
if (index === self.length - 1) {
return caption;
}
return [
caption,
React.createElement("span", { className: 'theia-tree-compressed-label-separator', key: subNode + '-separator' }, this.getSeparatorContent(node, props))
];
});
}
getCaptionChildEventHandlers(node, props) {
return {
onClick: event => (event.stopPropagation(), this.handleClickEvent(node, event)),
onDoubleClick: event => (event.stopPropagation(), this.handleDblClickEvent(node, event)),
onContextMenu: event => (event.stopPropagation(), this.handleContextMenuEvent(node, event)),
};
}
handleUp(event) {
if (!this.compressionToggle.compress) {
return super.handleUp(event);
}
const type = this.props.multiSelect && this.hasShiftMask(event) ? tree_selection_1.TreeSelection.SelectionType.RANGE : undefined;
this.model.selectPrevRow(type);
this.node.focus();
}
handleDown(event) {
if (!this.compressionToggle.compress) {
return super.handleDown(event);
}
const type = this.props.multiSelect && this.hasShiftMask(event) ? tree_selection_1.TreeSelection.SelectionType.RANGE : undefined;
this.model.selectNextRow(type);
this.node.focus();
}
async handleLeft(event) {
if (!this.compressionToggle.compress) {
return super.handleLeft(event);
}
if (Boolean(this.props.multiSelect) && (this.hasCtrlCmdMask(event) || this.hasShiftMask(event))) {
return;
}
const active = this.focusService.focusedNode;
if (tree_expansion_1.ExpandableTreeNode.isExpanded(active)
&& (this.compressionService.isCompressionHead(active)
|| !this.compressionService.isCompressionParticipant(active))) {
await this.model.collapseNode(active);
}
else {
this.model.selectParent();
}
}
async handleRight(event) {
if (!this.compressionToggle.compress) {
return super.handleRight(event);
}
if (Boolean(this.props.multiSelect) && (this.hasCtrlCmdMask(event) || this.hasShiftMask(event))) {
return;
}
const active = this.focusService.focusedNode;
if (tree_expansion_1.ExpandableTreeNode.isCollapsed(active)
&& (!this.compressionService.isCompressionParticipant(active)
|| this.compressionService.isCompressionTail(active))) {
await this.model.expandNode(active);
}
else if (tree_expansion_1.ExpandableTreeNode.is(active)) {
this.model.selectNextNode();
}
}
getSeparatorContent(node, props) {
return '/';
}
};
__decorate([
(0, inversify_1.inject)(tree_compression_service_1.CompressionToggle),
__metadata("design:type", Object)
], CompressedTreeWidget.prototype, "compressionToggle", void 0);
__decorate([
(0, inversify_1.inject)(tree_compression_service_1.TreeCompressionService),
__metadata("design:type", tree_compression_service_1.TreeCompressionService)
], CompressedTreeWidget.prototype, "compressionService", void 0);
CompressedTreeWidget = __decorate([
(0, inversify_1.injectable)(),
__param(0, (0, inversify_1.inject)(tree_widget_1.TreeProps)),
__param(1, (0, inversify_1.inject)(compressed_tree_model_1.CompressedTreeModel)),
__param(2, (0, inversify_1.inject)(context_menu_renderer_1.ContextMenuRenderer)),
__metadata("design:paramtypes", [Object, compressed_tree_model_1.CompressedTreeModel,
context_menu_renderer_1.ContextMenuRenderer])
], CompressedTreeWidget);
exports.CompressedTreeWidget = CompressedTreeWidget;
//# sourceMappingURL=compressed-tree-widget.js.map