@theia/preferences 1.34.2 → 1.34.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (128) hide show
  1. package/LICENSE +641 -641
  2. package/README.md +81 -81
  3. package/lib/browser/abstract-resource-preference-provider.d.ts +46 -46
  4. package/lib/browser/abstract-resource-preference-provider.js +237 -237
  5. package/lib/browser/abstract-resource-preference-provider.spec.d.ts +1 -1
  6. package/lib/browser/abstract-resource-preference-provider.spec.js +83 -83
  7. package/lib/browser/folder-preference-provider.d.ts +20 -20
  8. package/lib/browser/folder-preference-provider.js +59 -59
  9. package/lib/browser/folders-preferences-provider.d.ts +25 -25
  10. package/lib/browser/folders-preferences-provider.js +239 -239
  11. package/lib/browser/index.d.ts +7 -7
  12. package/lib/browser/index.js +34 -34
  13. package/lib/browser/monaco-jsonc-editor.d.ts +9 -9
  14. package/lib/browser/monaco-jsonc-editor.js +80 -80
  15. package/lib/browser/package.spec.js +25 -25
  16. package/lib/browser/preference-bindings.d.ts +4 -4
  17. package/lib/browser/preference-bindings.js +63 -63
  18. package/lib/browser/preference-frontend-module.d.ts +6 -6
  19. package/lib/browser/preference-frontend-module.js +52 -52
  20. package/lib/browser/preference-open-handler.d.ts +9 -9
  21. package/lib/browser/preference-open-handler.js +64 -64
  22. package/lib/browser/preference-transaction-manager.d.ts +98 -98
  23. package/lib/browser/preference-transaction-manager.js +295 -295
  24. package/lib/browser/preference-tree-model.d.ts +59 -59
  25. package/lib/browser/preference-tree-model.js +240 -240
  26. package/lib/browser/preferences-contribution.d.ts +37 -37
  27. package/lib/browser/preferences-contribution.js +279 -279
  28. package/lib/browser/preferences-json-schema-contribution.d.ts +17 -17
  29. package/lib/browser/preferences-json-schema-contribution.js +91 -91
  30. package/lib/browser/preferences-monaco-contribution.d.ts +1 -1
  31. package/lib/browser/preferences-monaco-contribution.js +30 -30
  32. package/lib/browser/section-preference-provider.d.ts +21 -21
  33. package/lib/browser/section-preference-provider.js +96 -96
  34. package/lib/browser/user-configs-preference-provider.d.ts +21 -21
  35. package/lib/browser/user-configs-preference-provider.js +134 -134
  36. package/lib/browser/user-preference-provider.d.ts +13 -13
  37. package/lib/browser/user-preference-provider.js +41 -41
  38. package/lib/browser/util/preference-scope-command-manager.d.ts +17 -17
  39. package/lib/browser/util/preference-scope-command-manager.js +87 -87
  40. package/lib/browser/util/preference-tree-generator.d.ts +30 -30
  41. package/lib/browser/util/preference-tree-generator.js +234 -234
  42. package/lib/browser/util/preference-tree-label-provider.d.ts +11 -11
  43. package/lib/browser/util/preference-tree-label-provider.js +77 -77
  44. package/lib/browser/util/preference-tree-label-provider.spec.d.ts +1 -1
  45. package/lib/browser/util/preference-tree-label-provider.spec.js +87 -87
  46. package/lib/browser/util/preference-types.d.ts +62 -62
  47. package/lib/browser/util/preference-types.js +128 -128
  48. package/lib/browser/views/components/preference-array-input.d.ts +28 -28
  49. package/lib/browser/views/components/preference-array-input.js +180 -180
  50. package/lib/browser/views/components/preference-boolean-input.d.ts +17 -17
  51. package/lib/browser/views/components/preference-boolean-input.js +79 -79
  52. package/lib/browser/views/components/preference-file-input.d.ts +29 -29
  53. package/lib/browser/views/components/preference-file-input.js +110 -110
  54. package/lib/browser/views/components/preference-json-input.d.ts +19 -19
  55. package/lib/browser/views/components/preference-json-input.js +93 -93
  56. package/lib/browser/views/components/preference-node-renderer-creator.d.ts +48 -48
  57. package/lib/browser/views/components/preference-node-renderer-creator.js +132 -132
  58. package/lib/browser/views/components/preference-node-renderer.d.ts +111 -111
  59. package/lib/browser/views/components/preference-node-renderer.js +460 -460
  60. package/lib/browser/views/components/preference-number-input.d.ts +34 -34
  61. package/lib/browser/views/components/preference-number-input.js +142 -142
  62. package/lib/browser/views/components/preference-select-input.d.ts +27 -27
  63. package/lib/browser/views/components/preference-select-input.js +135 -135
  64. package/lib/browser/views/components/preference-string-input.d.ts +17 -17
  65. package/lib/browser/views/components/preference-string-input.js +89 -89
  66. package/lib/browser/views/preference-editor-widget.d.ts +67 -67
  67. package/lib/browser/views/preference-editor-widget.js +376 -376
  68. package/lib/browser/views/preference-scope-tabbar-widget.d.ts +54 -54
  69. package/lib/browser/views/preference-scope-tabbar-widget.js +343 -343
  70. package/lib/browser/views/preference-searchbar-widget.d.ts +53 -53
  71. package/lib/browser/views/preference-searchbar-widget.js +173 -173
  72. package/lib/browser/views/preference-tree-widget.d.ts +17 -17
  73. package/lib/browser/views/preference-tree-widget.js +104 -104
  74. package/lib/browser/views/preference-widget-bindings.d.ts +3 -3
  75. package/lib/browser/views/preference-widget-bindings.js +85 -85
  76. package/lib/browser/views/preference-widget.d.ts +35 -35
  77. package/lib/browser/views/preference-widget.js +123 -123
  78. package/lib/browser/workspace-file-preference-provider.d.ts +23 -23
  79. package/lib/browser/workspace-file-preference-provider.js +110 -110
  80. package/lib/browser/workspace-preference-provider.d.ts +28 -28
  81. package/lib/browser/workspace-preference-provider.js +142 -142
  82. package/package.json +9 -9
  83. package/src/browser/abstract-resource-preference-provider.spec.ts +95 -95
  84. package/src/browser/abstract-resource-preference-provider.ts +228 -228
  85. package/src/browser/folder-preference-provider.ts +58 -58
  86. package/src/browser/folders-preferences-provider.ts +236 -236
  87. package/src/browser/index.ts +23 -23
  88. package/src/browser/monaco-jsonc-editor.ts +67 -67
  89. package/src/browser/package.spec.ts +28 -28
  90. package/src/browser/preference-bindings.ts +65 -65
  91. package/src/browser/preference-frontend-module.ts +57 -57
  92. package/src/browser/preference-open-handler.ts +53 -53
  93. package/src/browser/preference-transaction-manager.ts +283 -283
  94. package/src/browser/preference-tree-model.ts +246 -246
  95. package/src/browser/preferences-contribution.ts +263 -263
  96. package/src/browser/preferences-json-schema-contribution.ts +86 -86
  97. package/src/browser/preferences-monaco-contribution.ts +30 -30
  98. package/src/browser/section-preference-provider.ts +83 -83
  99. package/src/browser/style/index.css +456 -456
  100. package/src/browser/style/preference-array.css +90 -90
  101. package/src/browser/style/preference-context-menu.css +74 -74
  102. package/src/browser/style/preference-file.css +32 -32
  103. package/src/browser/style/preference-object.css +49 -49
  104. package/src/browser/style/search-input.css +66 -66
  105. package/src/browser/user-configs-preference-provider.ts +123 -123
  106. package/src/browser/user-preference-provider.ts +35 -35
  107. package/src/browser/util/preference-scope-command-manager.ts +75 -75
  108. package/src/browser/util/preference-tree-generator.ts +222 -222
  109. package/src/browser/util/preference-tree-label-provider.spec.ts +108 -108
  110. package/src/browser/util/preference-tree-label-provider.ts +64 -64
  111. package/src/browser/util/preference-types.ts +169 -169
  112. package/src/browser/views/components/preference-array-input.ts +174 -174
  113. package/src/browser/views/components/preference-boolean-input.ts +69 -69
  114. package/src/browser/views/components/preference-file-input.ts +104 -104
  115. package/src/browser/views/components/preference-json-input.ts +78 -78
  116. package/src/browser/views/components/preference-node-renderer-creator.ts +141 -141
  117. package/src/browser/views/components/preference-node-renderer.ts +499 -499
  118. package/src/browser/views/components/preference-number-input.ts +147 -147
  119. package/src/browser/views/components/preference-select-input.ts +127 -127
  120. package/src/browser/views/components/preference-string-input.ts +76 -76
  121. package/src/browser/views/preference-editor-widget.ts +361 -361
  122. package/src/browser/views/preference-scope-tabbar-widget.tsx +344 -344
  123. package/src/browser/views/preference-searchbar-widget.tsx +183 -183
  124. package/src/browser/views/preference-tree-widget.tsx +93 -93
  125. package/src/browser/views/preference-widget-bindings.ts +99 -99
  126. package/src/browser/views/preference-widget.tsx +113 -113
  127. package/src/browser/workspace-file-preference-provider.ts +100 -100
  128. package/src/browser/workspace-preference-provider.ts +134 -134
@@ -1,461 +1,461 @@
1
- "use strict";
2
- // *****************************************************************************
3
- // Copyright (C) 2020 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
- // *****************************************************************************
17
- var __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
- };
23
- var __metadata = (this && this.__metadata) || function (k, v) {
24
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
25
- };
26
- Object.defineProperty(exports, "__esModule", { value: true });
27
- exports.PreferenceLeafNodeRenderer = exports.PreferenceHeaderRenderer = exports.PreferenceNodeRenderer = exports.SUBHEADER_CLASS = exports.HEADER_CLASS = exports.PreferenceNodeRendererFactory = void 0;
28
- const inversify_1 = require("@theia/core/shared/inversify");
29
- const browser_1 = require("@theia/core/lib/browser");
30
- const preference_types_1 = require("../../util/preference-types");
31
- const preference_tree_label_provider_1 = require("../../util/preference-tree-label-provider");
32
- const preference_scope_tabbar_widget_1 = require("../preference-scope-tabbar-widget");
33
- const common_1 = require("@theia/core/lib/common");
34
- const debounce = require("@theia/core/shared/lodash.debounce");
35
- const preference_tree_model_1 = require("../../preference-tree-model");
36
- const preference_searchbar_widget_1 = require("../preference-searchbar-widget");
37
- const markdownit = require("@theia/core/shared/markdown-it");
38
- const DOMPurify = require("@theia/core/shared/dompurify");
39
- const uri_1 = require("@theia/core/lib/common/uri");
40
- exports.PreferenceNodeRendererFactory = Symbol('PreferenceNodeRendererFactory');
41
- exports.HEADER_CLASS = 'settings-section-category-title';
42
- exports.SUBHEADER_CLASS = 'settings-section-subcategory-title';
43
- let PreferenceNodeRenderer = class PreferenceNodeRenderer {
44
- constructor() {
45
- this.attached = false;
46
- }
47
- get node() {
48
- return this.domNode;
49
- }
50
- get nodeId() {
51
- return this.preferenceNode.id;
52
- }
53
- get id() {
54
- return this._id;
55
- }
56
- get group() {
57
- return this._group;
58
- }
59
- get visible() {
60
- return !this.node.classList.contains('hidden');
61
- }
62
- init() {
63
- this.setId();
64
- this.domNode = this.createDomNode();
65
- }
66
- setId() {
67
- var _a;
68
- const { id, group } = preference_types_1.Preference.TreeNode.getGroupAndIdFromNodeId(this.preferenceNode.id);
69
- const segments = id.split('.');
70
- this._id = id;
71
- this._group = group;
72
- this._subgroup = (_a = (group === segments[0] ? segments[1] : segments[0])) !== null && _a !== void 0 ? _a : '';
73
- }
74
- getAdditionalNodeClassnames() {
75
- return [];
76
- }
77
- insertBefore(nextSibling) {
78
- nextSibling.insertAdjacentElement('beforebegin', this.domNode);
79
- this.attached = true;
80
- }
81
- insertAfter(previousSibling) {
82
- previousSibling.insertAdjacentElement('afterend', this.domNode);
83
- }
84
- appendTo(parent) {
85
- parent.appendChild(this.domNode);
86
- }
87
- prependTo(parent) {
88
- parent.prepend(this.domNode);
89
- }
90
- hide() {
91
- this.domNode.classList.add('hidden');
92
- }
93
- show() {
94
- this.domNode.classList.remove('hidden');
95
- }
96
- dispose() {
97
- this.domNode.remove();
98
- }
99
- };
100
- __decorate([
101
- (0, inversify_1.inject)(preference_types_1.Preference.Node),
102
- __metadata("design:type", Object)
103
- ], PreferenceNodeRenderer.prototype, "preferenceNode", void 0);
104
- __decorate([
105
- (0, inversify_1.inject)(preference_tree_label_provider_1.PreferenceTreeLabelProvider),
106
- __metadata("design:type", preference_tree_label_provider_1.PreferenceTreeLabelProvider)
107
- ], PreferenceNodeRenderer.prototype, "labelProvider", void 0);
108
- __decorate([
109
- (0, inversify_1.postConstruct)(),
110
- __metadata("design:type", Function),
111
- __metadata("design:paramtypes", []),
112
- __metadata("design:returntype", void 0)
113
- ], PreferenceNodeRenderer.prototype, "init", null);
114
- PreferenceNodeRenderer = __decorate([
115
- (0, inversify_1.injectable)()
116
- ], PreferenceNodeRenderer);
117
- exports.PreferenceNodeRenderer = PreferenceNodeRenderer;
118
- class PreferenceHeaderRenderer extends PreferenceNodeRenderer {
119
- createDomNode() {
120
- const wrapper = document.createElement('ul');
121
- wrapper.className = 'settings-section';
122
- wrapper.id = `${this.preferenceNode.id}-editor`;
123
- const isCategory = preference_types_1.Preference.TreeNode.isTopLevel(this.preferenceNode);
124
- const hierarchyClassName = isCategory ? exports.HEADER_CLASS : exports.SUBHEADER_CLASS;
125
- const name = this.labelProvider.getName(this.preferenceNode);
126
- const label = document.createElement('li');
127
- label.classList.add('settings-section-title', hierarchyClassName);
128
- label.textContent = name;
129
- wrapper.appendChild(label);
130
- return wrapper;
131
- }
132
- }
133
- exports.PreferenceHeaderRenderer = PreferenceHeaderRenderer;
134
- let PreferenceLeafNodeRenderer = class PreferenceLeafNodeRenderer extends PreferenceNodeRenderer {
135
- constructor() {
136
- super(...arguments);
137
- this.isModifiedFromDefault = false;
138
- this.setPreferenceWithDebounce = debounce(this.setPreferenceImmediately.bind(this), 500, { leading: false, trailing: true });
139
- }
140
- init() {
141
- this.setId();
142
- this.updateInspection();
143
- this.markdownRenderer = this.buildMarkdownRenderer();
144
- this.domNode = this.createDomNode();
145
- this.updateModificationStatus();
146
- }
147
- updateInspection() {
148
- this.inspection = this.preferenceService.inspect(this.id, this.scopeTracker.currentScope.uri);
149
- }
150
- buildMarkdownRenderer() {
151
- const engine = markdownit();
152
- const inlineCode = engine.renderer.rules.code_inline;
153
- engine.renderer.rules.code_inline = (tokens, idx, options, env, self) => {
154
- const token = tokens[idx];
155
- const content = token.content;
156
- if (content.startsWith('#') && content.endsWith('#')) {
157
- const preferenceId = content.substring(1, content.length - 1);
158
- const preferenceNode = this.model.getNodeFromPreferenceId(preferenceId);
159
- if (preferenceNode) {
160
- let name = this.labelProvider.getName(preferenceNode);
161
- const prefix = this.labelProvider.getPrefix(preferenceNode, true);
162
- if (prefix) {
163
- name = prefix + name;
164
- }
165
- return `<a title="${preferenceId}" href="preference:${preferenceId}">${name}</a>`;
166
- }
167
- else {
168
- console.warn(`Linked preference "${preferenceId}" not found. Source: "${this.preferenceNode.preferenceId}"`);
169
- }
170
- }
171
- return inlineCode ? inlineCode(tokens, idx, options, env, self) : '';
172
- };
173
- return engine;
174
- }
175
- openLink(event) {
176
- if (event.target instanceof HTMLAnchorElement) {
177
- event.preventDefault();
178
- event.stopPropagation();
179
- // Exclude right click
180
- if (event.button < 2) {
181
- const uri = new uri_1.default(event.target.href);
182
- (0, browser_1.open)(this.openerService, uri);
183
- }
184
- }
185
- }
186
- createDomNode() {
187
- const wrapper = document.createElement('li');
188
- wrapper.classList.add('single-pref');
189
- wrapper.id = `${this.id}-editor`;
190
- wrapper.tabIndex = 0;
191
- wrapper.setAttribute('data-pref-id', this.id);
192
- wrapper.setAttribute('data-node-id', this.preferenceNode.id);
193
- const headlineWrapper = document.createElement('div');
194
- headlineWrapper.classList.add('pref-name');
195
- headlineWrapper.title = this.id;
196
- this.headlineWrapper = headlineWrapper;
197
- wrapper.appendChild(headlineWrapper);
198
- this.updateHeadline();
199
- const gutter = document.createElement('div');
200
- gutter.classList.add('pref-context-gutter');
201
- this.gutter = gutter;
202
- wrapper.appendChild(gutter);
203
- const cog = document.createElement('i');
204
- cog.className = `${(0, browser_1.codicon)('settings-gear', true)} settings-context-menu-btn`;
205
- cog.setAttribute('aria-label', 'Open Context Menu');
206
- cog.setAttribute('role', 'button');
207
- cog.onclick = this.handleCogAction.bind(this);
208
- cog.onkeydown = this.handleCogAction.bind(this);
209
- cog.title = common_1.nls.localizeByDefault('More Actions...');
210
- gutter.appendChild(cog);
211
- const contentWrapper = document.createElement('div');
212
- contentWrapper.classList.add('pref-content-container', ...this.getAdditionalNodeClassnames());
213
- wrapper.appendChild(contentWrapper);
214
- const { description, markdownDescription } = this.preferenceNode.preference.data;
215
- if (markdownDescription || description) {
216
- const descriptionWrapper = document.createElement('div');
217
- descriptionWrapper.classList.add('pref-description');
218
- if (markdownDescription) {
219
- const renderedDescription = this.markdownRenderer.render(markdownDescription);
220
- descriptionWrapper.onauxclick = this.openLink.bind(this);
221
- descriptionWrapper.onclick = this.openLink.bind(this);
222
- descriptionWrapper.oncontextmenu = () => false;
223
- descriptionWrapper.innerHTML = DOMPurify.sanitize(renderedDescription, {
224
- ALLOW_UNKNOWN_PROTOCOLS: true
225
- });
226
- }
227
- else if (description) {
228
- descriptionWrapper.textContent = description;
229
- }
230
- contentWrapper.appendChild(descriptionWrapper);
231
- }
232
- const interactableWrapper = document.createElement('div');
233
- interactableWrapper.classList.add('pref-input');
234
- contentWrapper.appendChild(interactableWrapper);
235
- this.createInteractable(interactableWrapper);
236
- return wrapper;
237
- }
238
- handleCogAction({ currentTarget }) {
239
- var _a, _b;
240
- const value = (_a = preference_types_1.Preference.getValueInScope(this.inspection, this.scopeTracker.currentScope.scope)) !== null && _a !== void 0 ? _a : (_b = this.inspection) === null || _b === void 0 ? void 0 : _b.defaultValue;
241
- const target = currentTarget;
242
- if (target && value !== undefined) {
243
- this.showCog();
244
- const domRect = target.getBoundingClientRect();
245
- this.menuRenderer.render({
246
- menuPath: preference_types_1.PreferenceMenus.PREFERENCE_EDITOR_CONTEXT_MENU,
247
- anchor: { x: domRect.left, y: domRect.bottom },
248
- args: [{ id: this.id, value }],
249
- onHide: () => this.hideCog()
250
- });
251
- }
252
- }
253
- addModifiedMarking() {
254
- this.gutter.classList.add('theia-mod-item-modified');
255
- }
256
- removeModifiedMarking() {
257
- this.gutter.classList.remove('theia-mod-item-modified');
258
- }
259
- showCog() {
260
- this.gutter.classList.add('show-cog');
261
- }
262
- hideCog() {
263
- this.gutter.classList.remove('show-cog');
264
- }
265
- updateModificationStatus(knownCurrentValue) {
266
- const wasModified = this.isModifiedFromDefault;
267
- const { inspection } = this;
268
- const valueInCurrentScope = knownCurrentValue !== null && knownCurrentValue !== void 0 ? knownCurrentValue : preference_types_1.Preference.getValueInScope(inspection, this.scopeTracker.currentScope.scope);
269
- this.isModifiedFromDefault = valueInCurrentScope !== undefined && !browser_1.PreferenceProvider.deepEqual(valueInCurrentScope, inspection === null || inspection === void 0 ? void 0 : inspection.defaultValue);
270
- if (wasModified !== this.isModifiedFromDefault) {
271
- this.gutter.classList.toggle('theia-mod-item-modified', this.isModifiedFromDefault);
272
- }
273
- }
274
- updateHeadline(filtered = this.model.isFiltered) {
275
- const { headlineWrapper } = this;
276
- if (this.headlineWrapper.childElementCount === 0) {
277
- const name = this.labelProvider.getName(this.preferenceNode);
278
- const nameWrapper = document.createElement('span');
279
- nameWrapper.classList.add('preference-leaf-headline-name');
280
- nameWrapper.textContent = name;
281
- headlineWrapper.appendChild(nameWrapper);
282
- }
283
- const prefix = this.labelProvider.getPrefix(this.preferenceNode, filtered);
284
- const currentFirstChild = headlineWrapper.children[0];
285
- const currentFirstChildIsPrefix = currentFirstChild.classList.contains('preference-leaf-headline-prefix');
286
- if (prefix) {
287
- let prefixWrapper;
288
- if (currentFirstChildIsPrefix) {
289
- prefixWrapper = currentFirstChild;
290
- }
291
- else {
292
- prefixWrapper = document.createElement('span');
293
- prefixWrapper.classList.add('preference-leaf-headline-prefix');
294
- headlineWrapper.insertBefore(prefixWrapper, currentFirstChild);
295
- }
296
- prefixWrapper.textContent = prefix;
297
- }
298
- else if (currentFirstChildIsPrefix) {
299
- headlineWrapper.removeChild(currentFirstChild);
300
- }
301
- const currentLastChild = headlineWrapper.lastChild;
302
- if (currentLastChild.classList.contains('preference-leaf-headline-suffix')) {
303
- this.compareOtherModifiedScopes(headlineWrapper, currentLastChild);
304
- }
305
- else {
306
- this.createOtherModifiedScopes(headlineWrapper);
307
- }
308
- }
309
- compareOtherModifiedScopes(headlineWrapper, currentSuffix) {
310
- const modifiedScopes = this.getModifiedScopesAsStrings();
311
- if (modifiedScopes.length === 0) {
312
- headlineWrapper.removeChild(currentSuffix);
313
- }
314
- else {
315
- const modifiedMessagePrefix = currentSuffix.children[0];
316
- const newMessagePrefix = this.getModifiedMessagePrefix();
317
- if (modifiedMessagePrefix.textContent !== newMessagePrefix) {
318
- modifiedMessagePrefix.textContent = newMessagePrefix;
319
- }
320
- const [firstModifiedScope, secondModifiedScope] = modifiedScopes;
321
- const firstScopeMessage = currentSuffix.children[1];
322
- const secondScopeMessage = currentSuffix.children[2];
323
- firstScopeMessage.children[0].textContent = browser_1.PreferenceScope[firstModifiedScope];
324
- this.addEventHandlerToModifiedScope(firstModifiedScope, firstScopeMessage.children[0]);
325
- if (modifiedScopes.length === 1 && secondScopeMessage) {
326
- currentSuffix.removeChild(secondScopeMessage);
327
- }
328
- else if (modifiedScopes.length === 2 && !secondScopeMessage) {
329
- const newSecondMessage = this.createModifiedScopeMessage(secondModifiedScope);
330
- currentSuffix.appendChild(newSecondMessage);
331
- }
332
- // If both scopes are modified and both messages are present, do nothing.
333
- }
334
- }
335
- createOtherModifiedScopes(headlineWrapper) {
336
- const modifiedScopes = this.getModifiedScopesAsStrings();
337
- if (modifiedScopes.length !== 0) {
338
- const wrapper = document.createElement('i');
339
- wrapper.classList.add('preference-leaf-headline-suffix');
340
- headlineWrapper.appendChild(wrapper);
341
- const messagePrefix = this.getModifiedMessagePrefix();
342
- const messageWrapper = document.createElement('span');
343
- messageWrapper.classList.add('preference-other-modified-scope-alert');
344
- messageWrapper.textContent = messagePrefix;
345
- wrapper.appendChild(messageWrapper);
346
- modifiedScopes.forEach((scopeName, i) => {
347
- const scopeWrapper = this.createModifiedScopeMessage(scopeName);
348
- wrapper.appendChild(scopeWrapper);
349
- });
350
- }
351
- }
352
- createModifiedScopeMessage(scope) {
353
- const scopeWrapper = document.createElement('span');
354
- scopeWrapper.classList.add('preference-modified-scope-wrapper');
355
- const scopeInteractable = document.createElement('span');
356
- scopeInteractable.classList.add('preference-scope-underlined');
357
- const scopeName = browser_1.PreferenceScope[scope];
358
- this.addEventHandlerToModifiedScope(scope, scopeInteractable);
359
- scopeInteractable.textContent = scopeName;
360
- scopeWrapper.appendChild(scopeInteractable);
361
- return scopeWrapper;
362
- }
363
- getModifiedMessagePrefix() {
364
- return (this.isModifiedFromDefault ? common_1.nls.localizeByDefault('Also modified in') : common_1.nls.localizeByDefault('Modified in')) + ': ';
365
- }
366
- addEventHandlerToModifiedScope(scope, scopeWrapper) {
367
- if (scope === browser_1.PreferenceScope.User || scope === browser_1.PreferenceScope.Workspace) {
368
- const eventHandler = () => {
369
- this.scopeTracker.setScope(scope);
370
- this.searchbar.updateSearchTerm(this.id);
371
- };
372
- scopeWrapper.onclick = eventHandler;
373
- scopeWrapper.onkeydown = eventHandler;
374
- scopeWrapper.tabIndex = 0;
375
- }
376
- else {
377
- scopeWrapper.onclick = null; // eslint-disable-line no-null/no-null
378
- scopeWrapper.onkeydown = null; // eslint-disable-line no-null/no-null
379
- scopeWrapper.tabIndex = -1;
380
- }
381
- }
382
- getModifiedScopesAsStrings() {
383
- const currentScopeInView = this.scopeTracker.currentScope.scope;
384
- const { inspection } = this;
385
- const modifiedScopes = [];
386
- if (inspection) {
387
- for (const otherScope of [browser_1.PreferenceScope.User, browser_1.PreferenceScope.Workspace]) {
388
- if (otherScope !== currentScopeInView) {
389
- const valueInOtherScope = preference_types_1.Preference.getValueInScope(inspection, otherScope);
390
- if (valueInOtherScope !== undefined && !browser_1.PreferenceProvider.deepEqual(valueInOtherScope, inspection.defaultValue)) {
391
- modifiedScopes.push(otherScope);
392
- }
393
- }
394
- }
395
- }
396
- return modifiedScopes;
397
- }
398
- // Many preferences allow `null` and even use it as a default regardless of the declared type.
399
- getValue() {
400
- var _a;
401
- let currentValue = preference_types_1.Preference.getValueInScope(this.inspection, this.scopeTracker.currentScope.scope);
402
- if (currentValue === undefined) {
403
- currentValue = (_a = this.inspection) === null || _a === void 0 ? void 0 : _a.defaultValue;
404
- }
405
- return currentValue !== undefined ? currentValue : this.getFallbackValue();
406
- }
407
- setPreferenceImmediately(value) {
408
- return this.preferenceService.set(this.id, value, this.scopeTracker.currentScope.scope, this.scopeTracker.currentScope.uri)
409
- .catch(() => this.handleValueChange());
410
- }
411
- handleSearchChange(isFiltered = this.model.isFiltered) {
412
- this.updateHeadline(isFiltered);
413
- }
414
- handleScopeChange(isFiltered = this.model.isFiltered) {
415
- this.handleValueChange();
416
- this.updateHeadline(isFiltered);
417
- }
418
- handleValueChange() {
419
- this.doHandleValueChange();
420
- this.updateHeadline();
421
- }
422
- };
423
- __decorate([
424
- (0, inversify_1.inject)(preference_types_1.Preference.Node),
425
- __metadata("design:type", Object)
426
- ], PreferenceLeafNodeRenderer.prototype, "preferenceNode", void 0);
427
- __decorate([
428
- (0, inversify_1.inject)(browser_1.PreferenceService),
429
- __metadata("design:type", Object)
430
- ], PreferenceLeafNodeRenderer.prototype, "preferenceService", void 0);
431
- __decorate([
432
- (0, inversify_1.inject)(browser_1.ContextMenuRenderer),
433
- __metadata("design:type", browser_1.ContextMenuRenderer)
434
- ], PreferenceLeafNodeRenderer.prototype, "menuRenderer", void 0);
435
- __decorate([
436
- (0, inversify_1.inject)(preference_scope_tabbar_widget_1.PreferencesScopeTabBar),
437
- __metadata("design:type", preference_scope_tabbar_widget_1.PreferencesScopeTabBar)
438
- ], PreferenceLeafNodeRenderer.prototype, "scopeTracker", void 0);
439
- __decorate([
440
- (0, inversify_1.inject)(preference_tree_model_1.PreferenceTreeModel),
441
- __metadata("design:type", preference_tree_model_1.PreferenceTreeModel)
442
- ], PreferenceLeafNodeRenderer.prototype, "model", void 0);
443
- __decorate([
444
- (0, inversify_1.inject)(preference_searchbar_widget_1.PreferencesSearchbarWidget),
445
- __metadata("design:type", preference_searchbar_widget_1.PreferencesSearchbarWidget)
446
- ], PreferenceLeafNodeRenderer.prototype, "searchbar", void 0);
447
- __decorate([
448
- (0, inversify_1.inject)(browser_1.OpenerService),
449
- __metadata("design:type", Object)
450
- ], PreferenceLeafNodeRenderer.prototype, "openerService", void 0);
451
- __decorate([
452
- (0, inversify_1.postConstruct)(),
453
- __metadata("design:type", Function),
454
- __metadata("design:paramtypes", []),
455
- __metadata("design:returntype", void 0)
456
- ], PreferenceLeafNodeRenderer.prototype, "init", null);
457
- PreferenceLeafNodeRenderer = __decorate([
458
- (0, inversify_1.injectable)()
459
- ], PreferenceLeafNodeRenderer);
460
- exports.PreferenceLeafNodeRenderer = PreferenceLeafNodeRenderer;
1
+ "use strict";
2
+ // *****************************************************************************
3
+ // Copyright (C) 2020 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
+ // *****************************************************************************
17
+ var __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
+ };
23
+ var __metadata = (this && this.__metadata) || function (k, v) {
24
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
25
+ };
26
+ Object.defineProperty(exports, "__esModule", { value: true });
27
+ exports.PreferenceLeafNodeRenderer = exports.PreferenceHeaderRenderer = exports.PreferenceNodeRenderer = exports.SUBHEADER_CLASS = exports.HEADER_CLASS = exports.PreferenceNodeRendererFactory = void 0;
28
+ const inversify_1 = require("@theia/core/shared/inversify");
29
+ const browser_1 = require("@theia/core/lib/browser");
30
+ const preference_types_1 = require("../../util/preference-types");
31
+ const preference_tree_label_provider_1 = require("../../util/preference-tree-label-provider");
32
+ const preference_scope_tabbar_widget_1 = require("../preference-scope-tabbar-widget");
33
+ const common_1 = require("@theia/core/lib/common");
34
+ const debounce = require("@theia/core/shared/lodash.debounce");
35
+ const preference_tree_model_1 = require("../../preference-tree-model");
36
+ const preference_searchbar_widget_1 = require("../preference-searchbar-widget");
37
+ const markdownit = require("@theia/core/shared/markdown-it");
38
+ const DOMPurify = require("@theia/core/shared/dompurify");
39
+ const uri_1 = require("@theia/core/lib/common/uri");
40
+ exports.PreferenceNodeRendererFactory = Symbol('PreferenceNodeRendererFactory');
41
+ exports.HEADER_CLASS = 'settings-section-category-title';
42
+ exports.SUBHEADER_CLASS = 'settings-section-subcategory-title';
43
+ let PreferenceNodeRenderer = class PreferenceNodeRenderer {
44
+ constructor() {
45
+ this.attached = false;
46
+ }
47
+ get node() {
48
+ return this.domNode;
49
+ }
50
+ get nodeId() {
51
+ return this.preferenceNode.id;
52
+ }
53
+ get id() {
54
+ return this._id;
55
+ }
56
+ get group() {
57
+ return this._group;
58
+ }
59
+ get visible() {
60
+ return !this.node.classList.contains('hidden');
61
+ }
62
+ init() {
63
+ this.setId();
64
+ this.domNode = this.createDomNode();
65
+ }
66
+ setId() {
67
+ var _a;
68
+ const { id, group } = preference_types_1.Preference.TreeNode.getGroupAndIdFromNodeId(this.preferenceNode.id);
69
+ const segments = id.split('.');
70
+ this._id = id;
71
+ this._group = group;
72
+ this._subgroup = (_a = (group === segments[0] ? segments[1] : segments[0])) !== null && _a !== void 0 ? _a : '';
73
+ }
74
+ getAdditionalNodeClassnames() {
75
+ return [];
76
+ }
77
+ insertBefore(nextSibling) {
78
+ nextSibling.insertAdjacentElement('beforebegin', this.domNode);
79
+ this.attached = true;
80
+ }
81
+ insertAfter(previousSibling) {
82
+ previousSibling.insertAdjacentElement('afterend', this.domNode);
83
+ }
84
+ appendTo(parent) {
85
+ parent.appendChild(this.domNode);
86
+ }
87
+ prependTo(parent) {
88
+ parent.prepend(this.domNode);
89
+ }
90
+ hide() {
91
+ this.domNode.classList.add('hidden');
92
+ }
93
+ show() {
94
+ this.domNode.classList.remove('hidden');
95
+ }
96
+ dispose() {
97
+ this.domNode.remove();
98
+ }
99
+ };
100
+ __decorate([
101
+ (0, inversify_1.inject)(preference_types_1.Preference.Node),
102
+ __metadata("design:type", Object)
103
+ ], PreferenceNodeRenderer.prototype, "preferenceNode", void 0);
104
+ __decorate([
105
+ (0, inversify_1.inject)(preference_tree_label_provider_1.PreferenceTreeLabelProvider),
106
+ __metadata("design:type", preference_tree_label_provider_1.PreferenceTreeLabelProvider)
107
+ ], PreferenceNodeRenderer.prototype, "labelProvider", void 0);
108
+ __decorate([
109
+ (0, inversify_1.postConstruct)(),
110
+ __metadata("design:type", Function),
111
+ __metadata("design:paramtypes", []),
112
+ __metadata("design:returntype", void 0)
113
+ ], PreferenceNodeRenderer.prototype, "init", null);
114
+ PreferenceNodeRenderer = __decorate([
115
+ (0, inversify_1.injectable)()
116
+ ], PreferenceNodeRenderer);
117
+ exports.PreferenceNodeRenderer = PreferenceNodeRenderer;
118
+ class PreferenceHeaderRenderer extends PreferenceNodeRenderer {
119
+ createDomNode() {
120
+ const wrapper = document.createElement('ul');
121
+ wrapper.className = 'settings-section';
122
+ wrapper.id = `${this.preferenceNode.id}-editor`;
123
+ const isCategory = preference_types_1.Preference.TreeNode.isTopLevel(this.preferenceNode);
124
+ const hierarchyClassName = isCategory ? exports.HEADER_CLASS : exports.SUBHEADER_CLASS;
125
+ const name = this.labelProvider.getName(this.preferenceNode);
126
+ const label = document.createElement('li');
127
+ label.classList.add('settings-section-title', hierarchyClassName);
128
+ label.textContent = name;
129
+ wrapper.appendChild(label);
130
+ return wrapper;
131
+ }
132
+ }
133
+ exports.PreferenceHeaderRenderer = PreferenceHeaderRenderer;
134
+ let PreferenceLeafNodeRenderer = class PreferenceLeafNodeRenderer extends PreferenceNodeRenderer {
135
+ constructor() {
136
+ super(...arguments);
137
+ this.isModifiedFromDefault = false;
138
+ this.setPreferenceWithDebounce = debounce(this.setPreferenceImmediately.bind(this), 500, { leading: false, trailing: true });
139
+ }
140
+ init() {
141
+ this.setId();
142
+ this.updateInspection();
143
+ this.markdownRenderer = this.buildMarkdownRenderer();
144
+ this.domNode = this.createDomNode();
145
+ this.updateModificationStatus();
146
+ }
147
+ updateInspection() {
148
+ this.inspection = this.preferenceService.inspect(this.id, this.scopeTracker.currentScope.uri);
149
+ }
150
+ buildMarkdownRenderer() {
151
+ const engine = markdownit();
152
+ const inlineCode = engine.renderer.rules.code_inline;
153
+ engine.renderer.rules.code_inline = (tokens, idx, options, env, self) => {
154
+ const token = tokens[idx];
155
+ const content = token.content;
156
+ if (content.startsWith('#') && content.endsWith('#')) {
157
+ const preferenceId = content.substring(1, content.length - 1);
158
+ const preferenceNode = this.model.getNodeFromPreferenceId(preferenceId);
159
+ if (preferenceNode) {
160
+ let name = this.labelProvider.getName(preferenceNode);
161
+ const prefix = this.labelProvider.getPrefix(preferenceNode, true);
162
+ if (prefix) {
163
+ name = prefix + name;
164
+ }
165
+ return `<a title="${preferenceId}" href="preference:${preferenceId}">${name}</a>`;
166
+ }
167
+ else {
168
+ console.warn(`Linked preference "${preferenceId}" not found. Source: "${this.preferenceNode.preferenceId}"`);
169
+ }
170
+ }
171
+ return inlineCode ? inlineCode(tokens, idx, options, env, self) : '';
172
+ };
173
+ return engine;
174
+ }
175
+ openLink(event) {
176
+ if (event.target instanceof HTMLAnchorElement) {
177
+ event.preventDefault();
178
+ event.stopPropagation();
179
+ // Exclude right click
180
+ if (event.button < 2) {
181
+ const uri = new uri_1.default(event.target.href);
182
+ (0, browser_1.open)(this.openerService, uri);
183
+ }
184
+ }
185
+ }
186
+ createDomNode() {
187
+ const wrapper = document.createElement('li');
188
+ wrapper.classList.add('single-pref');
189
+ wrapper.id = `${this.id}-editor`;
190
+ wrapper.tabIndex = 0;
191
+ wrapper.setAttribute('data-pref-id', this.id);
192
+ wrapper.setAttribute('data-node-id', this.preferenceNode.id);
193
+ const headlineWrapper = document.createElement('div');
194
+ headlineWrapper.classList.add('pref-name');
195
+ headlineWrapper.title = this.id;
196
+ this.headlineWrapper = headlineWrapper;
197
+ wrapper.appendChild(headlineWrapper);
198
+ this.updateHeadline();
199
+ const gutter = document.createElement('div');
200
+ gutter.classList.add('pref-context-gutter');
201
+ this.gutter = gutter;
202
+ wrapper.appendChild(gutter);
203
+ const cog = document.createElement('i');
204
+ cog.className = `${(0, browser_1.codicon)('settings-gear', true)} settings-context-menu-btn`;
205
+ cog.setAttribute('aria-label', 'Open Context Menu');
206
+ cog.setAttribute('role', 'button');
207
+ cog.onclick = this.handleCogAction.bind(this);
208
+ cog.onkeydown = this.handleCogAction.bind(this);
209
+ cog.title = common_1.nls.localizeByDefault('More Actions...');
210
+ gutter.appendChild(cog);
211
+ const contentWrapper = document.createElement('div');
212
+ contentWrapper.classList.add('pref-content-container', ...this.getAdditionalNodeClassnames());
213
+ wrapper.appendChild(contentWrapper);
214
+ const { description, markdownDescription } = this.preferenceNode.preference.data;
215
+ if (markdownDescription || description) {
216
+ const descriptionWrapper = document.createElement('div');
217
+ descriptionWrapper.classList.add('pref-description');
218
+ if (markdownDescription) {
219
+ const renderedDescription = this.markdownRenderer.render(markdownDescription);
220
+ descriptionWrapper.onauxclick = this.openLink.bind(this);
221
+ descriptionWrapper.onclick = this.openLink.bind(this);
222
+ descriptionWrapper.oncontextmenu = () => false;
223
+ descriptionWrapper.innerHTML = DOMPurify.sanitize(renderedDescription, {
224
+ ALLOW_UNKNOWN_PROTOCOLS: true
225
+ });
226
+ }
227
+ else if (description) {
228
+ descriptionWrapper.textContent = description;
229
+ }
230
+ contentWrapper.appendChild(descriptionWrapper);
231
+ }
232
+ const interactableWrapper = document.createElement('div');
233
+ interactableWrapper.classList.add('pref-input');
234
+ contentWrapper.appendChild(interactableWrapper);
235
+ this.createInteractable(interactableWrapper);
236
+ return wrapper;
237
+ }
238
+ handleCogAction({ currentTarget }) {
239
+ var _a, _b;
240
+ const value = (_a = preference_types_1.Preference.getValueInScope(this.inspection, this.scopeTracker.currentScope.scope)) !== null && _a !== void 0 ? _a : (_b = this.inspection) === null || _b === void 0 ? void 0 : _b.defaultValue;
241
+ const target = currentTarget;
242
+ if (target && value !== undefined) {
243
+ this.showCog();
244
+ const domRect = target.getBoundingClientRect();
245
+ this.menuRenderer.render({
246
+ menuPath: preference_types_1.PreferenceMenus.PREFERENCE_EDITOR_CONTEXT_MENU,
247
+ anchor: { x: domRect.left, y: domRect.bottom },
248
+ args: [{ id: this.id, value }],
249
+ onHide: () => this.hideCog()
250
+ });
251
+ }
252
+ }
253
+ addModifiedMarking() {
254
+ this.gutter.classList.add('theia-mod-item-modified');
255
+ }
256
+ removeModifiedMarking() {
257
+ this.gutter.classList.remove('theia-mod-item-modified');
258
+ }
259
+ showCog() {
260
+ this.gutter.classList.add('show-cog');
261
+ }
262
+ hideCog() {
263
+ this.gutter.classList.remove('show-cog');
264
+ }
265
+ updateModificationStatus(knownCurrentValue) {
266
+ const wasModified = this.isModifiedFromDefault;
267
+ const { inspection } = this;
268
+ const valueInCurrentScope = knownCurrentValue !== null && knownCurrentValue !== void 0 ? knownCurrentValue : preference_types_1.Preference.getValueInScope(inspection, this.scopeTracker.currentScope.scope);
269
+ this.isModifiedFromDefault = valueInCurrentScope !== undefined && !browser_1.PreferenceProvider.deepEqual(valueInCurrentScope, inspection === null || inspection === void 0 ? void 0 : inspection.defaultValue);
270
+ if (wasModified !== this.isModifiedFromDefault) {
271
+ this.gutter.classList.toggle('theia-mod-item-modified', this.isModifiedFromDefault);
272
+ }
273
+ }
274
+ updateHeadline(filtered = this.model.isFiltered) {
275
+ const { headlineWrapper } = this;
276
+ if (this.headlineWrapper.childElementCount === 0) {
277
+ const name = this.labelProvider.getName(this.preferenceNode);
278
+ const nameWrapper = document.createElement('span');
279
+ nameWrapper.classList.add('preference-leaf-headline-name');
280
+ nameWrapper.textContent = name;
281
+ headlineWrapper.appendChild(nameWrapper);
282
+ }
283
+ const prefix = this.labelProvider.getPrefix(this.preferenceNode, filtered);
284
+ const currentFirstChild = headlineWrapper.children[0];
285
+ const currentFirstChildIsPrefix = currentFirstChild.classList.contains('preference-leaf-headline-prefix');
286
+ if (prefix) {
287
+ let prefixWrapper;
288
+ if (currentFirstChildIsPrefix) {
289
+ prefixWrapper = currentFirstChild;
290
+ }
291
+ else {
292
+ prefixWrapper = document.createElement('span');
293
+ prefixWrapper.classList.add('preference-leaf-headline-prefix');
294
+ headlineWrapper.insertBefore(prefixWrapper, currentFirstChild);
295
+ }
296
+ prefixWrapper.textContent = prefix;
297
+ }
298
+ else if (currentFirstChildIsPrefix) {
299
+ headlineWrapper.removeChild(currentFirstChild);
300
+ }
301
+ const currentLastChild = headlineWrapper.lastChild;
302
+ if (currentLastChild.classList.contains('preference-leaf-headline-suffix')) {
303
+ this.compareOtherModifiedScopes(headlineWrapper, currentLastChild);
304
+ }
305
+ else {
306
+ this.createOtherModifiedScopes(headlineWrapper);
307
+ }
308
+ }
309
+ compareOtherModifiedScopes(headlineWrapper, currentSuffix) {
310
+ const modifiedScopes = this.getModifiedScopesAsStrings();
311
+ if (modifiedScopes.length === 0) {
312
+ headlineWrapper.removeChild(currentSuffix);
313
+ }
314
+ else {
315
+ const modifiedMessagePrefix = currentSuffix.children[0];
316
+ const newMessagePrefix = this.getModifiedMessagePrefix();
317
+ if (modifiedMessagePrefix.textContent !== newMessagePrefix) {
318
+ modifiedMessagePrefix.textContent = newMessagePrefix;
319
+ }
320
+ const [firstModifiedScope, secondModifiedScope] = modifiedScopes;
321
+ const firstScopeMessage = currentSuffix.children[1];
322
+ const secondScopeMessage = currentSuffix.children[2];
323
+ firstScopeMessage.children[0].textContent = browser_1.PreferenceScope[firstModifiedScope];
324
+ this.addEventHandlerToModifiedScope(firstModifiedScope, firstScopeMessage.children[0]);
325
+ if (modifiedScopes.length === 1 && secondScopeMessage) {
326
+ currentSuffix.removeChild(secondScopeMessage);
327
+ }
328
+ else if (modifiedScopes.length === 2 && !secondScopeMessage) {
329
+ const newSecondMessage = this.createModifiedScopeMessage(secondModifiedScope);
330
+ currentSuffix.appendChild(newSecondMessage);
331
+ }
332
+ // If both scopes are modified and both messages are present, do nothing.
333
+ }
334
+ }
335
+ createOtherModifiedScopes(headlineWrapper) {
336
+ const modifiedScopes = this.getModifiedScopesAsStrings();
337
+ if (modifiedScopes.length !== 0) {
338
+ const wrapper = document.createElement('i');
339
+ wrapper.classList.add('preference-leaf-headline-suffix');
340
+ headlineWrapper.appendChild(wrapper);
341
+ const messagePrefix = this.getModifiedMessagePrefix();
342
+ const messageWrapper = document.createElement('span');
343
+ messageWrapper.classList.add('preference-other-modified-scope-alert');
344
+ messageWrapper.textContent = messagePrefix;
345
+ wrapper.appendChild(messageWrapper);
346
+ modifiedScopes.forEach((scopeName, i) => {
347
+ const scopeWrapper = this.createModifiedScopeMessage(scopeName);
348
+ wrapper.appendChild(scopeWrapper);
349
+ });
350
+ }
351
+ }
352
+ createModifiedScopeMessage(scope) {
353
+ const scopeWrapper = document.createElement('span');
354
+ scopeWrapper.classList.add('preference-modified-scope-wrapper');
355
+ const scopeInteractable = document.createElement('span');
356
+ scopeInteractable.classList.add('preference-scope-underlined');
357
+ const scopeName = browser_1.PreferenceScope[scope];
358
+ this.addEventHandlerToModifiedScope(scope, scopeInteractable);
359
+ scopeInteractable.textContent = scopeName;
360
+ scopeWrapper.appendChild(scopeInteractable);
361
+ return scopeWrapper;
362
+ }
363
+ getModifiedMessagePrefix() {
364
+ return (this.isModifiedFromDefault ? common_1.nls.localizeByDefault('Also modified in') : common_1.nls.localizeByDefault('Modified in')) + ': ';
365
+ }
366
+ addEventHandlerToModifiedScope(scope, scopeWrapper) {
367
+ if (scope === browser_1.PreferenceScope.User || scope === browser_1.PreferenceScope.Workspace) {
368
+ const eventHandler = () => {
369
+ this.scopeTracker.setScope(scope);
370
+ this.searchbar.updateSearchTerm(this.id);
371
+ };
372
+ scopeWrapper.onclick = eventHandler;
373
+ scopeWrapper.onkeydown = eventHandler;
374
+ scopeWrapper.tabIndex = 0;
375
+ }
376
+ else {
377
+ scopeWrapper.onclick = null; // eslint-disable-line no-null/no-null
378
+ scopeWrapper.onkeydown = null; // eslint-disable-line no-null/no-null
379
+ scopeWrapper.tabIndex = -1;
380
+ }
381
+ }
382
+ getModifiedScopesAsStrings() {
383
+ const currentScopeInView = this.scopeTracker.currentScope.scope;
384
+ const { inspection } = this;
385
+ const modifiedScopes = [];
386
+ if (inspection) {
387
+ for (const otherScope of [browser_1.PreferenceScope.User, browser_1.PreferenceScope.Workspace]) {
388
+ if (otherScope !== currentScopeInView) {
389
+ const valueInOtherScope = preference_types_1.Preference.getValueInScope(inspection, otherScope);
390
+ if (valueInOtherScope !== undefined && !browser_1.PreferenceProvider.deepEqual(valueInOtherScope, inspection.defaultValue)) {
391
+ modifiedScopes.push(otherScope);
392
+ }
393
+ }
394
+ }
395
+ }
396
+ return modifiedScopes;
397
+ }
398
+ // Many preferences allow `null` and even use it as a default regardless of the declared type.
399
+ getValue() {
400
+ var _a;
401
+ let currentValue = preference_types_1.Preference.getValueInScope(this.inspection, this.scopeTracker.currentScope.scope);
402
+ if (currentValue === undefined) {
403
+ currentValue = (_a = this.inspection) === null || _a === void 0 ? void 0 : _a.defaultValue;
404
+ }
405
+ return currentValue !== undefined ? currentValue : this.getFallbackValue();
406
+ }
407
+ setPreferenceImmediately(value) {
408
+ return this.preferenceService.set(this.id, value, this.scopeTracker.currentScope.scope, this.scopeTracker.currentScope.uri)
409
+ .catch(() => this.handleValueChange());
410
+ }
411
+ handleSearchChange(isFiltered = this.model.isFiltered) {
412
+ this.updateHeadline(isFiltered);
413
+ }
414
+ handleScopeChange(isFiltered = this.model.isFiltered) {
415
+ this.handleValueChange();
416
+ this.updateHeadline(isFiltered);
417
+ }
418
+ handleValueChange() {
419
+ this.doHandleValueChange();
420
+ this.updateHeadline();
421
+ }
422
+ };
423
+ __decorate([
424
+ (0, inversify_1.inject)(preference_types_1.Preference.Node),
425
+ __metadata("design:type", Object)
426
+ ], PreferenceLeafNodeRenderer.prototype, "preferenceNode", void 0);
427
+ __decorate([
428
+ (0, inversify_1.inject)(browser_1.PreferenceService),
429
+ __metadata("design:type", Object)
430
+ ], PreferenceLeafNodeRenderer.prototype, "preferenceService", void 0);
431
+ __decorate([
432
+ (0, inversify_1.inject)(browser_1.ContextMenuRenderer),
433
+ __metadata("design:type", browser_1.ContextMenuRenderer)
434
+ ], PreferenceLeafNodeRenderer.prototype, "menuRenderer", void 0);
435
+ __decorate([
436
+ (0, inversify_1.inject)(preference_scope_tabbar_widget_1.PreferencesScopeTabBar),
437
+ __metadata("design:type", preference_scope_tabbar_widget_1.PreferencesScopeTabBar)
438
+ ], PreferenceLeafNodeRenderer.prototype, "scopeTracker", void 0);
439
+ __decorate([
440
+ (0, inversify_1.inject)(preference_tree_model_1.PreferenceTreeModel),
441
+ __metadata("design:type", preference_tree_model_1.PreferenceTreeModel)
442
+ ], PreferenceLeafNodeRenderer.prototype, "model", void 0);
443
+ __decorate([
444
+ (0, inversify_1.inject)(preference_searchbar_widget_1.PreferencesSearchbarWidget),
445
+ __metadata("design:type", preference_searchbar_widget_1.PreferencesSearchbarWidget)
446
+ ], PreferenceLeafNodeRenderer.prototype, "searchbar", void 0);
447
+ __decorate([
448
+ (0, inversify_1.inject)(browser_1.OpenerService),
449
+ __metadata("design:type", Object)
450
+ ], PreferenceLeafNodeRenderer.prototype, "openerService", void 0);
451
+ __decorate([
452
+ (0, inversify_1.postConstruct)(),
453
+ __metadata("design:type", Function),
454
+ __metadata("design:paramtypes", []),
455
+ __metadata("design:returntype", void 0)
456
+ ], PreferenceLeafNodeRenderer.prototype, "init", null);
457
+ PreferenceLeafNodeRenderer = __decorate([
458
+ (0, inversify_1.injectable)()
459
+ ], PreferenceLeafNodeRenderer);
460
+ exports.PreferenceLeafNodeRenderer = PreferenceLeafNodeRenderer;
461
461
  //# sourceMappingURL=preference-node-renderer.js.map