@theia/preferences 1.45.0 → 1.46.0-next.72
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.
- package/README.md +81 -81
- package/lib/browser/abstract-resource-preference-provider.d.ts +47 -47
- package/lib/browser/abstract-resource-preference-provider.js +240 -240
- package/lib/browser/abstract-resource-preference-provider.spec.d.ts +1 -1
- package/lib/browser/abstract-resource-preference-provider.spec.js +83 -83
- package/lib/browser/folder-preference-provider.d.ts +20 -20
- package/lib/browser/folder-preference-provider.js +59 -59
- package/lib/browser/folders-preferences-provider.d.ts +27 -27
- package/lib/browser/folders-preferences-provider.js +245 -245
- package/lib/browser/index.d.ts +7 -7
- package/lib/browser/index.js +34 -34
- package/lib/browser/monaco-jsonc-editor.d.ts +9 -9
- package/lib/browser/monaco-jsonc-editor.js +80 -80
- package/lib/browser/package.spec.js +25 -25
- package/lib/browser/preference-bindings.d.ts +4 -4
- package/lib/browser/preference-bindings.js +63 -63
- package/lib/browser/preference-frontend-module.d.ts +6 -6
- package/lib/browser/preference-frontend-module.js +52 -52
- package/lib/browser/preference-open-handler.d.ts +9 -9
- package/lib/browser/preference-open-handler.js +64 -64
- package/lib/browser/preference-transaction-manager.d.ts +100 -100
- package/lib/browser/preference-transaction-manager.js +293 -293
- package/lib/browser/preference-tree-model.d.ts +60 -60
- package/lib/browser/preference-tree-model.js +243 -243
- package/lib/browser/preferences-contribution.d.ts +37 -37
- package/lib/browser/preferences-contribution.js +280 -280
- package/lib/browser/preferences-json-schema-contribution.d.ts +17 -17
- package/lib/browser/preferences-json-schema-contribution.js +91 -91
- package/lib/browser/preferences-monaco-contribution.d.ts +1 -1
- package/lib/browser/preferences-monaco-contribution.js +27 -27
- package/lib/browser/section-preference-provider.d.ts +21 -21
- package/lib/browser/section-preference-provider.js +96 -96
- package/lib/browser/user-configs-preference-provider.d.ts +22 -22
- package/lib/browser/user-configs-preference-provider.js +137 -137
- package/lib/browser/user-preference-provider.d.ts +13 -13
- package/lib/browser/user-preference-provider.js +41 -41
- package/lib/browser/util/preference-scope-command-manager.d.ts +17 -17
- package/lib/browser/util/preference-scope-command-manager.js +87 -87
- package/lib/browser/util/preference-tree-generator.d.ts +31 -31
- package/lib/browser/util/preference-tree-generator.js +237 -237
- package/lib/browser/util/preference-tree-label-provider.d.ts +11 -11
- package/lib/browser/util/preference-tree-label-provider.js +77 -77
- package/lib/browser/util/preference-tree-label-provider.spec.d.ts +1 -1
- package/lib/browser/util/preference-tree-label-provider.spec.js +87 -87
- package/lib/browser/util/preference-types.d.ts +62 -62
- package/lib/browser/util/preference-types.js +128 -128
- package/lib/browser/views/components/preference-array-input.d.ts +28 -28
- package/lib/browser/views/components/preference-array-input.js +180 -180
- package/lib/browser/views/components/preference-boolean-input.d.ts +17 -17
- package/lib/browser/views/components/preference-boolean-input.js +79 -79
- package/lib/browser/views/components/preference-file-input.d.ts +29 -29
- package/lib/browser/views/components/preference-file-input.js +110 -110
- package/lib/browser/views/components/preference-json-input.d.ts +19 -19
- package/lib/browser/views/components/preference-json-input.js +93 -93
- package/lib/browser/views/components/preference-markdown-renderer.d.ts +12 -12
- package/lib/browser/views/components/preference-markdown-renderer.js +81 -81
- package/lib/browser/views/components/preference-node-renderer-creator.d.ts +48 -48
- package/lib/browser/views/components/preference-node-renderer-creator.js +132 -132
- package/lib/browser/views/components/preference-node-renderer.d.ts +112 -112
- package/lib/browser/views/components/preference-node-renderer.js +441 -441
- package/lib/browser/views/components/preference-number-input.d.ts +34 -34
- package/lib/browser/views/components/preference-number-input.js +142 -142
- package/lib/browser/views/components/preference-select-input.d.ts +28 -28
- package/lib/browser/views/components/preference-select-input.js +138 -138
- package/lib/browser/views/components/preference-string-input.d.ts +17 -17
- package/lib/browser/views/components/preference-string-input.js +89 -89
- package/lib/browser/views/preference-editor-widget.d.ts +67 -67
- package/lib/browser/views/preference-editor-widget.js +363 -363
- package/lib/browser/views/preference-scope-tabbar-widget.d.ts +54 -54
- package/lib/browser/views/preference-scope-tabbar-widget.js +343 -343
- package/lib/browser/views/preference-searchbar-widget.d.ts +53 -53
- package/lib/browser/views/preference-searchbar-widget.js +173 -173
- package/lib/browser/views/preference-tree-widget.d.ts +17 -17
- package/lib/browser/views/preference-tree-widget.js +104 -104
- package/lib/browser/views/preference-widget-bindings.d.ts +3 -3
- package/lib/browser/views/preference-widget-bindings.js +87 -87
- package/lib/browser/views/preference-widget.d.ts +36 -36
- package/lib/browser/views/preference-widget.js +126 -126
- package/lib/browser/workspace-file-preference-provider.d.ts +23 -23
- package/lib/browser/workspace-file-preference-provider.js +110 -110
- package/lib/browser/workspace-preference-provider.d.ts +28 -28
- package/lib/browser/workspace-preference-provider.js +142 -142
- package/package.json +10 -10
- package/src/browser/abstract-resource-preference-provider.spec.ts +95 -95
- package/src/browser/abstract-resource-preference-provider.ts +232 -232
- package/src/browser/folder-preference-provider.ts +58 -58
- package/src/browser/folders-preferences-provider.ts +244 -244
- package/src/browser/index.ts +23 -23
- package/src/browser/monaco-jsonc-editor.ts +67 -67
- package/src/browser/package.spec.ts +28 -28
- package/src/browser/preference-bindings.ts +65 -65
- package/src/browser/preference-frontend-module.ts +57 -57
- package/src/browser/preference-open-handler.ts +53 -53
- package/src/browser/preference-transaction-manager.ts +287 -287
- package/src/browser/preference-tree-model.ts +250 -250
- package/src/browser/preferences-contribution.ts +263 -263
- package/src/browser/preferences-json-schema-contribution.ts +86 -86
- package/src/browser/preferences-monaco-contribution.ts +27 -27
- package/src/browser/section-preference-provider.ts +83 -83
- package/src/browser/style/index.css +506 -506
- package/src/browser/style/preference-array.css +94 -94
- package/src/browser/style/preference-context-menu.css +74 -74
- package/src/browser/style/preference-file.css +31 -31
- package/src/browser/style/preference-object.css +49 -49
- package/src/browser/style/search-input.css +66 -66
- package/src/browser/user-configs-preference-provider.ts +127 -127
- package/src/browser/user-preference-provider.ts +35 -35
- package/src/browser/util/preference-scope-command-manager.ts +75 -75
- package/src/browser/util/preference-tree-generator.ts +226 -226
- package/src/browser/util/preference-tree-label-provider.spec.ts +108 -108
- package/src/browser/util/preference-tree-label-provider.ts +64 -64
- package/src/browser/util/preference-types.ts +169 -169
- package/src/browser/views/components/preference-array-input.ts +174 -174
- package/src/browser/views/components/preference-boolean-input.ts +69 -69
- package/src/browser/views/components/preference-file-input.ts +104 -104
- package/src/browser/views/components/preference-json-input.ts +78 -78
- package/src/browser/views/components/preference-markdown-renderer.ts +68 -68
- package/src/browser/views/components/preference-node-renderer-creator.ts +141 -141
- package/src/browser/views/components/preference-node-renderer.ts +477 -477
- package/src/browser/views/components/preference-number-input.ts +147 -147
- package/src/browser/views/components/preference-select-input.ts +131 -131
- package/src/browser/views/components/preference-string-input.ts +76 -76
- package/src/browser/views/preference-editor-widget.ts +349 -349
- package/src/browser/views/preference-scope-tabbar-widget.tsx +344 -344
- package/src/browser/views/preference-searchbar-widget.tsx +183 -183
- package/src/browser/views/preference-tree-widget.tsx +93 -93
- package/src/browser/views/preference-widget-bindings.ts +102 -102
- package/src/browser/views/preference-widget.tsx +117 -117
- package/src/browser/workspace-file-preference-provider.ts +100 -100
- package/src/browser/workspace-preference-provider.ts +134 -134
|
@@ -1,174 +1,174 @@
|
|
|
1
|
-
// *****************************************************************************
|
|
2
|
-
// Copyright (C) 2021 Ericsson and others.
|
|
3
|
-
//
|
|
4
|
-
// This program and the accompanying materials are made available under the
|
|
5
|
-
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
6
|
-
// http://www.eclipse.org/legal/epl-2.0.
|
|
7
|
-
//
|
|
8
|
-
// This Source Code may also be made available under the following Secondary
|
|
9
|
-
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
10
|
-
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
11
|
-
// with the GNU Classpath Exception which is available at
|
|
12
|
-
// https://www.gnu.org/software/classpath/license.html.
|
|
13
|
-
//
|
|
14
|
-
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
15
|
-
// *****************************************************************************
|
|
16
|
-
|
|
17
|
-
import { codiconArray } from '@theia/core/lib/browser';
|
|
18
|
-
import { injectable, interfaces } from '@theia/core/shared/inversify';
|
|
19
|
-
import { IJSONSchema } from '@theia/core/lib/common/json-schema';
|
|
20
|
-
import { Preference } from '../../util/preference-types';
|
|
21
|
-
import { PreferenceLeafNodeRenderer, PreferenceNodeRenderer } from './preference-node-renderer';
|
|
22
|
-
import { PreferenceLeafNodeRendererContribution } from './preference-node-renderer-creator';
|
|
23
|
-
|
|
24
|
-
@injectable()
|
|
25
|
-
export class PreferenceArrayInputRenderer extends PreferenceLeafNodeRenderer<string[], HTMLInputElement> {
|
|
26
|
-
existingValues = new Map<string, { node: HTMLElement, index: number }>();
|
|
27
|
-
wrapper: HTMLElement;
|
|
28
|
-
inputWrapper: HTMLElement;
|
|
29
|
-
|
|
30
|
-
protected createInteractable(parent: HTMLElement): void {
|
|
31
|
-
const wrapper = document.createElement('ul');
|
|
32
|
-
wrapper.classList.add('preference-array');
|
|
33
|
-
this.wrapper = wrapper;
|
|
34
|
-
const currentValue = this.getValue();
|
|
35
|
-
if (Array.isArray(currentValue)) {
|
|
36
|
-
for (const [index, value] of currentValue.entries()) {
|
|
37
|
-
const node = this.createExistingValue(value);
|
|
38
|
-
wrapper.appendChild(node);
|
|
39
|
-
this.existingValues.set(value, { node, index });
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
const inputWrapper = this.createInput();
|
|
43
|
-
wrapper.appendChild(inputWrapper);
|
|
44
|
-
parent.appendChild(wrapper);
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
protected getFallbackValue(): string[] {
|
|
48
|
-
return [];
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
protected createExistingValue(value: string): HTMLElement {
|
|
52
|
-
const existingValue = document.createElement('li');
|
|
53
|
-
existingValue.classList.add('preference-array-element');
|
|
54
|
-
const valueWrapper = document.createElement('span');
|
|
55
|
-
valueWrapper.classList.add('preference-array-element-val');
|
|
56
|
-
valueWrapper.textContent = value;
|
|
57
|
-
existingValue.appendChild(valueWrapper);
|
|
58
|
-
const iconWrapper = document.createElement('span');
|
|
59
|
-
iconWrapper.classList.add('preference-array-element-btn', 'remove-btn');
|
|
60
|
-
const handler = this.removeItem.bind(this, value);
|
|
61
|
-
iconWrapper.onclick = handler;
|
|
62
|
-
iconWrapper.onkeydown = handler;
|
|
63
|
-
iconWrapper.setAttribute('role', 'button');
|
|
64
|
-
iconWrapper.tabIndex = 0;
|
|
65
|
-
existingValue.appendChild(iconWrapper);
|
|
66
|
-
const icon = document.createElement('i');
|
|
67
|
-
icon.classList.add(...codiconArray('close'));
|
|
68
|
-
iconWrapper.appendChild(icon);
|
|
69
|
-
return existingValue;
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
protected createInput(): HTMLElement {
|
|
73
|
-
const inputWrapper = document.createElement('li');
|
|
74
|
-
this.inputWrapper = inputWrapper;
|
|
75
|
-
const input = document.createElement('input');
|
|
76
|
-
inputWrapper.appendChild(input);
|
|
77
|
-
this.interactable = input;
|
|
78
|
-
input.classList.add('preference-array-input', 'theia-input');
|
|
79
|
-
input.type = 'text';
|
|
80
|
-
input.placeholder = 'Add Value...';
|
|
81
|
-
input.spellcheck = false;
|
|
82
|
-
input.onkeydown = this.handleEnter.bind(this);
|
|
83
|
-
input.setAttribute('aria-label', 'Preference String Input');
|
|
84
|
-
const iconWrapper = document.createElement('span');
|
|
85
|
-
inputWrapper.appendChild(iconWrapper);
|
|
86
|
-
iconWrapper.classList.add('preference-array-element-btn', ...codiconArray('add'));
|
|
87
|
-
iconWrapper.setAttribute('role', 'button');
|
|
88
|
-
const handler = this.addItem.bind(this);
|
|
89
|
-
iconWrapper.onclick = handler;
|
|
90
|
-
iconWrapper.onkeydown = handler;
|
|
91
|
-
iconWrapper.tabIndex = 0;
|
|
92
|
-
iconWrapper.setAttribute('aria-label', 'Submit Preference Input');
|
|
93
|
-
return inputWrapper;
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
protected doHandleValueChange(): void {
|
|
97
|
-
this.updateInspection();
|
|
98
|
-
const values = this.getValue() ?? [];
|
|
99
|
-
const newValues = new Set(...values);
|
|
100
|
-
for (const [value, row] of this.existingValues.entries()) {
|
|
101
|
-
if (!newValues.has(value)) {
|
|
102
|
-
row.node.remove();
|
|
103
|
-
this.existingValues.delete(value);
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
for (const [index, value] of values.entries()) {
|
|
107
|
-
let row = this.existingValues.get(value);
|
|
108
|
-
if (row) {
|
|
109
|
-
row.index = index;
|
|
110
|
-
} else {
|
|
111
|
-
row = { node: this.createExistingValue(value), index };
|
|
112
|
-
this.existingValues.set(value, row);
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
if (this.wrapper.children[index] !== row.node) {
|
|
116
|
-
this.wrapper.children[index].insertAdjacentElement('beforebegin', row.node);
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
this.updateModificationStatus();
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
protected removeItem(value: string): void {
|
|
123
|
-
const row = this.existingValues.get(value);
|
|
124
|
-
if (row) {
|
|
125
|
-
row.node.remove();
|
|
126
|
-
this.existingValues.delete(value);
|
|
127
|
-
this.setPreferenceImmediately(this.getOrderedValues());
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
protected handleEnter(e: KeyboardEvent): void {
|
|
132
|
-
if (e.key === 'Enter') {
|
|
133
|
-
e.preventDefault();
|
|
134
|
-
this.addItem();
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
protected addItem(): void {
|
|
139
|
-
const newItem = this.interactable.value;
|
|
140
|
-
if (newItem && !this.existingValues.has(newItem)) {
|
|
141
|
-
const node = this.createExistingValue(newItem);
|
|
142
|
-
this.inputWrapper.insertAdjacentElement('beforebegin', node);
|
|
143
|
-
this.existingValues.set(newItem, { node, index: this.existingValues.size });
|
|
144
|
-
this.setPreferenceImmediately(this.getOrderedValues());
|
|
145
|
-
}
|
|
146
|
-
this.interactable.value = '';
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
protected getOrderedValues(): string[] {
|
|
150
|
-
return Array.from(this.existingValues.entries())
|
|
151
|
-
.sort(([, a], [, b]) => a.index - b.index)
|
|
152
|
-
.map(([value]) => value);
|
|
153
|
-
}
|
|
154
|
-
|
|
155
|
-
override dispose(): void {
|
|
156
|
-
this.existingValues.clear();
|
|
157
|
-
super.dispose();
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
@injectable()
|
|
162
|
-
export class PreferenceArrayInputRendererContribution extends PreferenceLeafNodeRendererContribution {
|
|
163
|
-
static ID = 'preference-array-input-renderer';
|
|
164
|
-
id = PreferenceArrayInputRendererContribution.ID;
|
|
165
|
-
|
|
166
|
-
canHandleLeafNode(node: Preference.LeafNode): number {
|
|
167
|
-
const type = Preference.LeafNode.getType(node);
|
|
168
|
-
return type === 'array' && (node.preference.data.items as IJSONSchema)?.type === 'string' ? 2 : 0;
|
|
169
|
-
}
|
|
170
|
-
|
|
171
|
-
createLeafNodeRenderer(container: interfaces.Container): PreferenceNodeRenderer {
|
|
172
|
-
return container.get(PreferenceArrayInputRenderer);
|
|
173
|
-
}
|
|
174
|
-
}
|
|
1
|
+
// *****************************************************************************
|
|
2
|
+
// Copyright (C) 2021 Ericsson and others.
|
|
3
|
+
//
|
|
4
|
+
// This program and the accompanying materials are made available under the
|
|
5
|
+
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
6
|
+
// http://www.eclipse.org/legal/epl-2.0.
|
|
7
|
+
//
|
|
8
|
+
// This Source Code may also be made available under the following Secondary
|
|
9
|
+
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
10
|
+
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
11
|
+
// with the GNU Classpath Exception which is available at
|
|
12
|
+
// https://www.gnu.org/software/classpath/license.html.
|
|
13
|
+
//
|
|
14
|
+
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
15
|
+
// *****************************************************************************
|
|
16
|
+
|
|
17
|
+
import { codiconArray } from '@theia/core/lib/browser';
|
|
18
|
+
import { injectable, interfaces } from '@theia/core/shared/inversify';
|
|
19
|
+
import { IJSONSchema } from '@theia/core/lib/common/json-schema';
|
|
20
|
+
import { Preference } from '../../util/preference-types';
|
|
21
|
+
import { PreferenceLeafNodeRenderer, PreferenceNodeRenderer } from './preference-node-renderer';
|
|
22
|
+
import { PreferenceLeafNodeRendererContribution } from './preference-node-renderer-creator';
|
|
23
|
+
|
|
24
|
+
@injectable()
|
|
25
|
+
export class PreferenceArrayInputRenderer extends PreferenceLeafNodeRenderer<string[], HTMLInputElement> {
|
|
26
|
+
existingValues = new Map<string, { node: HTMLElement, index: number }>();
|
|
27
|
+
wrapper: HTMLElement;
|
|
28
|
+
inputWrapper: HTMLElement;
|
|
29
|
+
|
|
30
|
+
protected createInteractable(parent: HTMLElement): void {
|
|
31
|
+
const wrapper = document.createElement('ul');
|
|
32
|
+
wrapper.classList.add('preference-array');
|
|
33
|
+
this.wrapper = wrapper;
|
|
34
|
+
const currentValue = this.getValue();
|
|
35
|
+
if (Array.isArray(currentValue)) {
|
|
36
|
+
for (const [index, value] of currentValue.entries()) {
|
|
37
|
+
const node = this.createExistingValue(value);
|
|
38
|
+
wrapper.appendChild(node);
|
|
39
|
+
this.existingValues.set(value, { node, index });
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
const inputWrapper = this.createInput();
|
|
43
|
+
wrapper.appendChild(inputWrapper);
|
|
44
|
+
parent.appendChild(wrapper);
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
protected getFallbackValue(): string[] {
|
|
48
|
+
return [];
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
protected createExistingValue(value: string): HTMLElement {
|
|
52
|
+
const existingValue = document.createElement('li');
|
|
53
|
+
existingValue.classList.add('preference-array-element');
|
|
54
|
+
const valueWrapper = document.createElement('span');
|
|
55
|
+
valueWrapper.classList.add('preference-array-element-val');
|
|
56
|
+
valueWrapper.textContent = value;
|
|
57
|
+
existingValue.appendChild(valueWrapper);
|
|
58
|
+
const iconWrapper = document.createElement('span');
|
|
59
|
+
iconWrapper.classList.add('preference-array-element-btn', 'remove-btn');
|
|
60
|
+
const handler = this.removeItem.bind(this, value);
|
|
61
|
+
iconWrapper.onclick = handler;
|
|
62
|
+
iconWrapper.onkeydown = handler;
|
|
63
|
+
iconWrapper.setAttribute('role', 'button');
|
|
64
|
+
iconWrapper.tabIndex = 0;
|
|
65
|
+
existingValue.appendChild(iconWrapper);
|
|
66
|
+
const icon = document.createElement('i');
|
|
67
|
+
icon.classList.add(...codiconArray('close'));
|
|
68
|
+
iconWrapper.appendChild(icon);
|
|
69
|
+
return existingValue;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
protected createInput(): HTMLElement {
|
|
73
|
+
const inputWrapper = document.createElement('li');
|
|
74
|
+
this.inputWrapper = inputWrapper;
|
|
75
|
+
const input = document.createElement('input');
|
|
76
|
+
inputWrapper.appendChild(input);
|
|
77
|
+
this.interactable = input;
|
|
78
|
+
input.classList.add('preference-array-input', 'theia-input');
|
|
79
|
+
input.type = 'text';
|
|
80
|
+
input.placeholder = 'Add Value...';
|
|
81
|
+
input.spellcheck = false;
|
|
82
|
+
input.onkeydown = this.handleEnter.bind(this);
|
|
83
|
+
input.setAttribute('aria-label', 'Preference String Input');
|
|
84
|
+
const iconWrapper = document.createElement('span');
|
|
85
|
+
inputWrapper.appendChild(iconWrapper);
|
|
86
|
+
iconWrapper.classList.add('preference-array-element-btn', ...codiconArray('add'));
|
|
87
|
+
iconWrapper.setAttribute('role', 'button');
|
|
88
|
+
const handler = this.addItem.bind(this);
|
|
89
|
+
iconWrapper.onclick = handler;
|
|
90
|
+
iconWrapper.onkeydown = handler;
|
|
91
|
+
iconWrapper.tabIndex = 0;
|
|
92
|
+
iconWrapper.setAttribute('aria-label', 'Submit Preference Input');
|
|
93
|
+
return inputWrapper;
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
protected doHandleValueChange(): void {
|
|
97
|
+
this.updateInspection();
|
|
98
|
+
const values = this.getValue() ?? [];
|
|
99
|
+
const newValues = new Set(...values);
|
|
100
|
+
for (const [value, row] of this.existingValues.entries()) {
|
|
101
|
+
if (!newValues.has(value)) {
|
|
102
|
+
row.node.remove();
|
|
103
|
+
this.existingValues.delete(value);
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
for (const [index, value] of values.entries()) {
|
|
107
|
+
let row = this.existingValues.get(value);
|
|
108
|
+
if (row) {
|
|
109
|
+
row.index = index;
|
|
110
|
+
} else {
|
|
111
|
+
row = { node: this.createExistingValue(value), index };
|
|
112
|
+
this.existingValues.set(value, row);
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
if (this.wrapper.children[index] !== row.node) {
|
|
116
|
+
this.wrapper.children[index].insertAdjacentElement('beforebegin', row.node);
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
this.updateModificationStatus();
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
protected removeItem(value: string): void {
|
|
123
|
+
const row = this.existingValues.get(value);
|
|
124
|
+
if (row) {
|
|
125
|
+
row.node.remove();
|
|
126
|
+
this.existingValues.delete(value);
|
|
127
|
+
this.setPreferenceImmediately(this.getOrderedValues());
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
protected handleEnter(e: KeyboardEvent): void {
|
|
132
|
+
if (e.key === 'Enter') {
|
|
133
|
+
e.preventDefault();
|
|
134
|
+
this.addItem();
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
protected addItem(): void {
|
|
139
|
+
const newItem = this.interactable.value;
|
|
140
|
+
if (newItem && !this.existingValues.has(newItem)) {
|
|
141
|
+
const node = this.createExistingValue(newItem);
|
|
142
|
+
this.inputWrapper.insertAdjacentElement('beforebegin', node);
|
|
143
|
+
this.existingValues.set(newItem, { node, index: this.existingValues.size });
|
|
144
|
+
this.setPreferenceImmediately(this.getOrderedValues());
|
|
145
|
+
}
|
|
146
|
+
this.interactable.value = '';
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
protected getOrderedValues(): string[] {
|
|
150
|
+
return Array.from(this.existingValues.entries())
|
|
151
|
+
.sort(([, a], [, b]) => a.index - b.index)
|
|
152
|
+
.map(([value]) => value);
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
override dispose(): void {
|
|
156
|
+
this.existingValues.clear();
|
|
157
|
+
super.dispose();
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
@injectable()
|
|
162
|
+
export class PreferenceArrayInputRendererContribution extends PreferenceLeafNodeRendererContribution {
|
|
163
|
+
static ID = 'preference-array-input-renderer';
|
|
164
|
+
id = PreferenceArrayInputRendererContribution.ID;
|
|
165
|
+
|
|
166
|
+
canHandleLeafNode(node: Preference.LeafNode): number {
|
|
167
|
+
const type = Preference.LeafNode.getType(node);
|
|
168
|
+
return type === 'array' && (node.preference.data.items as IJSONSchema)?.type === 'string' ? 2 : 0;
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
createLeafNodeRenderer(container: interfaces.Container): PreferenceNodeRenderer {
|
|
172
|
+
return container.get(PreferenceArrayInputRenderer);
|
|
173
|
+
}
|
|
174
|
+
}
|
|
@@ -1,69 +1,69 @@
|
|
|
1
|
-
// *****************************************************************************
|
|
2
|
-
// Copyright (C) 2021 Ericsson and others.
|
|
3
|
-
//
|
|
4
|
-
// This program and the accompanying materials are made available under the
|
|
5
|
-
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
6
|
-
// http://www.eclipse.org/legal/epl-2.0.
|
|
7
|
-
//
|
|
8
|
-
// This Source Code may also be made available under the following Secondary
|
|
9
|
-
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
10
|
-
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
11
|
-
// with the GNU Classpath Exception which is available at
|
|
12
|
-
// https://www.gnu.org/software/classpath/license.html.
|
|
13
|
-
//
|
|
14
|
-
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
15
|
-
// *****************************************************************************
|
|
16
|
-
|
|
17
|
-
import { injectable, interfaces } from '@theia/core/shared/inversify';
|
|
18
|
-
import { Preference } from '../../util/preference-types';
|
|
19
|
-
import { PreferenceLeafNodeRenderer, PreferenceNodeRenderer } from './preference-node-renderer';
|
|
20
|
-
import { PreferenceLeafNodeRendererContribution } from './preference-node-renderer-creator';
|
|
21
|
-
|
|
22
|
-
@injectable()
|
|
23
|
-
export class PreferenceBooleanInputRenderer extends PreferenceLeafNodeRenderer<boolean, HTMLInputElement> {
|
|
24
|
-
protected createInteractable(parent: HTMLElement): void {
|
|
25
|
-
const interactable = document.createElement('input');
|
|
26
|
-
this.interactable = interactable;
|
|
27
|
-
interactable.type = 'checkbox';
|
|
28
|
-
interactable.classList.add('theia-input');
|
|
29
|
-
interactable.defaultChecked = Boolean(this.getValue());
|
|
30
|
-
interactable.onchange = this.handleUserInteraction.bind(this);
|
|
31
|
-
parent.appendChild(interactable);
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
protected override getAdditionalNodeClassnames(): Iterable<string> {
|
|
35
|
-
return ['boolean'];
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
protected getFallbackValue(): false {
|
|
39
|
-
return false;
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
protected handleUserInteraction(): Promise<void> {
|
|
43
|
-
return this.setPreferenceImmediately(this.interactable.checked);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
protected doHandleValueChange(): void {
|
|
47
|
-
const currentValue = this.interactable.checked;
|
|
48
|
-
this.updateInspection();
|
|
49
|
-
const newValue = Boolean(this.getValue());
|
|
50
|
-
this.updateModificationStatus(newValue);
|
|
51
|
-
if (newValue !== currentValue && document.activeElement !== this.interactable) {
|
|
52
|
-
this.interactable.checked = newValue;
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
@injectable()
|
|
58
|
-
export class PreferenceBooleanInputRendererContribution extends PreferenceLeafNodeRendererContribution {
|
|
59
|
-
static ID = 'preference-boolean-input-renderer';
|
|
60
|
-
id = PreferenceBooleanInputRendererContribution.ID;
|
|
61
|
-
|
|
62
|
-
canHandleLeafNode(node: Preference.LeafNode): number {
|
|
63
|
-
return Preference.LeafNode.getType(node) === 'boolean' ? 2 : 0;
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
createLeafNodeRenderer(container: interfaces.Container): PreferenceNodeRenderer {
|
|
67
|
-
return container.get(PreferenceBooleanInputRenderer);
|
|
68
|
-
}
|
|
69
|
-
}
|
|
1
|
+
// *****************************************************************************
|
|
2
|
+
// Copyright (C) 2021 Ericsson and others.
|
|
3
|
+
//
|
|
4
|
+
// This program and the accompanying materials are made available under the
|
|
5
|
+
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
6
|
+
// http://www.eclipse.org/legal/epl-2.0.
|
|
7
|
+
//
|
|
8
|
+
// This Source Code may also be made available under the following Secondary
|
|
9
|
+
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
10
|
+
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
11
|
+
// with the GNU Classpath Exception which is available at
|
|
12
|
+
// https://www.gnu.org/software/classpath/license.html.
|
|
13
|
+
//
|
|
14
|
+
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
15
|
+
// *****************************************************************************
|
|
16
|
+
|
|
17
|
+
import { injectable, interfaces } from '@theia/core/shared/inversify';
|
|
18
|
+
import { Preference } from '../../util/preference-types';
|
|
19
|
+
import { PreferenceLeafNodeRenderer, PreferenceNodeRenderer } from './preference-node-renderer';
|
|
20
|
+
import { PreferenceLeafNodeRendererContribution } from './preference-node-renderer-creator';
|
|
21
|
+
|
|
22
|
+
@injectable()
|
|
23
|
+
export class PreferenceBooleanInputRenderer extends PreferenceLeafNodeRenderer<boolean, HTMLInputElement> {
|
|
24
|
+
protected createInteractable(parent: HTMLElement): void {
|
|
25
|
+
const interactable = document.createElement('input');
|
|
26
|
+
this.interactable = interactable;
|
|
27
|
+
interactable.type = 'checkbox';
|
|
28
|
+
interactable.classList.add('theia-input');
|
|
29
|
+
interactable.defaultChecked = Boolean(this.getValue());
|
|
30
|
+
interactable.onchange = this.handleUserInteraction.bind(this);
|
|
31
|
+
parent.appendChild(interactable);
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
protected override getAdditionalNodeClassnames(): Iterable<string> {
|
|
35
|
+
return ['boolean'];
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
protected getFallbackValue(): false {
|
|
39
|
+
return false;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
protected handleUserInteraction(): Promise<void> {
|
|
43
|
+
return this.setPreferenceImmediately(this.interactable.checked);
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
protected doHandleValueChange(): void {
|
|
47
|
+
const currentValue = this.interactable.checked;
|
|
48
|
+
this.updateInspection();
|
|
49
|
+
const newValue = Boolean(this.getValue());
|
|
50
|
+
this.updateModificationStatus(newValue);
|
|
51
|
+
if (newValue !== currentValue && document.activeElement !== this.interactable) {
|
|
52
|
+
this.interactable.checked = newValue;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
@injectable()
|
|
58
|
+
export class PreferenceBooleanInputRendererContribution extends PreferenceLeafNodeRendererContribution {
|
|
59
|
+
static ID = 'preference-boolean-input-renderer';
|
|
60
|
+
id = PreferenceBooleanInputRendererContribution.ID;
|
|
61
|
+
|
|
62
|
+
canHandleLeafNode(node: Preference.LeafNode): number {
|
|
63
|
+
return Preference.LeafNode.getType(node) === 'boolean' ? 2 : 0;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
createLeafNodeRenderer(container: interfaces.Container): PreferenceNodeRenderer {
|
|
67
|
+
return container.get(PreferenceBooleanInputRenderer);
|
|
68
|
+
}
|
|
69
|
+
}
|