UNPKG

5.71 kBJavaScriptView Raw
1"use strict";
2// *****************************************************************************
3// Copyright (C) 2022 Ericsson and others.
4//
5// This program and the accompanying materials are made available under the
6// terms of the Eclipse Public License v. 2.0 which is available at
7// http://www.eclipse.org/legal/epl-2.0.
8//
9// This Source Code may also be made available under the following Secondary
10// Licenses when the conditions for such availability set forth in the Eclipse
11// Public License v. 2.0 are satisfied: GNU General Public License, version 2
12// with the GNU Classpath Exception which is available at
13// https://www.gnu.org/software/classpath/license.html.
14//
15// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
16// *****************************************************************************
17var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
18 var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
19 if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
20 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;
21 return c > 3 && r && Object.defineProperty(target, key, r), r;
22};
23var __metadata = (this && this.__metadata) || function (k, v) {
24 if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
25};
26Object.defineProperty(exports, "__esModule", { value: true });
27exports.CompressedTreeModel = exports.TopDownCompressedTreeIterator = void 0;
28const inversify_1 = require("inversify");
29const tree_compression_service_1 = require("./tree-compression-service");
30const tree_1 = require("../tree");
31const tree_model_1 = require("../tree-model");
32const tree_selection_1 = require("../tree-selection");
33const tree_expansion_1 = require("../tree-expansion");
34const tree_iterator_1 = require("../tree-iterator");
35class TopDownCompressedTreeIterator extends tree_iterator_1.TopDownTreeIterator {
36 isCollapsed(candidate) {
37 return tree_expansion_1.ExpandableTreeNode.isCollapsed(candidate) && !tree_compression_service_1.TreeCompressionService.prototype.isCompressionParent(candidate);
38 }
39}
40exports.TopDownCompressedTreeIterator = TopDownCompressedTreeIterator;
41var BackOrForward;
42(function (BackOrForward) {
43 BackOrForward[BackOrForward["Forward"] = 0] = "Forward";
44 BackOrForward[BackOrForward["Backward"] = 1] = "Backward";
45})(BackOrForward || (BackOrForward = {}));
46let CompressedTreeModel = class CompressedTreeModel extends tree_model_1.TreeModelImpl {
47 selectAdjacentRow(direction, type = tree_selection_1.TreeSelection.SelectionType.DEFAULT, startingPoint = this.getFocusedNode()) {
48 var _a, _b;
49 if (!startingPoint && this.root) {
50 this.selectAdjacentRow(BackOrForward.Forward, type, this.root);
51 }
52 if (this.compressionService.isCompressionParticipant(startingPoint)) {
53 const chain = this.compressionService.getCompressionChain(startingPoint);
54 startingPoint = (_a = (direction === BackOrForward.Backward ? chain === null || chain === void 0 ? void 0 : chain.head() : chain === null || chain === void 0 ? void 0 : chain.tail())) !== null && _a !== void 0 ? _a : startingPoint;
55 }
56 const iterator = direction === BackOrForward.Backward ? this.createBackwardIterator(startingPoint) : this.createIterator(startingPoint);
57 const test = (candidate) => tree_selection_1.SelectableTreeNode.isVisible(candidate)
58 && (this.compressionService.isCompressionHead(candidate) || !this.compressionService.isCompressionParticipant(candidate));
59 const rowRoot = iterator && this.doGetNextNode(iterator, test);
60 const nodes = ((_b = this.compressionService.getCompressionChain(rowRoot)) !== null && _b !== void 0 ? _b : [rowRoot]).reverse();
61 const node = nodes.find(tree_selection_1.SelectableTreeNode.is);
62 if (node) {
63 this.addSelection({ node, type });
64 }
65 }
66 selectPrevRow(type) {
67 this.selectAdjacentRow(BackOrForward.Backward, type);
68 }
69 selectNextRow(type) {
70 this.selectAdjacentRow(BackOrForward.Forward, type);
71 }
72 createForwardIteratorForNode(node) {
73 return new TopDownCompressedTreeIterator(node, { pruneCollapsed: true });
74 }
75 selectIfAncestorOfSelected(node) {
76 var _a, _b;
77 if (!this.compressionToggle.compress) {
78 return super.selectIfAncestorOfSelected(node);
79 }
80 const tail = (_b = (_a = this.compressionService.getCompressionChain(node)) === null || _a === void 0 ? void 0 : _a.tail()) !== null && _b !== void 0 ? _b : node;
81 if (tree_selection_1.SelectableTreeNode.is(tail) && !tail.expanded && this.selectedNodes.some(selectedNode => tree_1.CompositeTreeNode.isAncestor(tail, selectedNode))) {
82 this.selectNode(tail);
83 }
84 }
85};
86__decorate([
87 (0, inversify_1.inject)(tree_compression_service_1.CompressionToggle),
88 __metadata("design:type", Object)
89], CompressedTreeModel.prototype, "compressionToggle", void 0);
90__decorate([
91 (0, inversify_1.inject)(tree_compression_service_1.TreeCompressionService),
92 __metadata("design:type", tree_compression_service_1.TreeCompressionService)
93], CompressedTreeModel.prototype, "compressionService", void 0);
94CompressedTreeModel = __decorate([
95 (0, inversify_1.injectable)()
96], CompressedTreeModel);
97exports.CompressedTreeModel = CompressedTreeModel;
98//# sourceMappingURL=compressed-tree-model.js.map
\No newline at end of file