@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,147 +1,147 @@
|
|
|
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 { nls } from '@theia/core';
|
|
18
|
-
import { injectable, interfaces } from '@theia/core/shared/inversify';
|
|
19
|
-
import { Preference } from '../../util/preference-types';
|
|
20
|
-
import { PreferenceLeafNodeRenderer, PreferenceNodeRenderer } from './preference-node-renderer';
|
|
21
|
-
import { PreferenceLeafNodeRendererContribution } from './preference-node-renderer-creator';
|
|
22
|
-
|
|
23
|
-
interface PreferenceNumberInputValidation {
|
|
24
|
-
/**
|
|
25
|
-
* the numeric value of the input. `NaN` if there is an error.
|
|
26
|
-
*/
|
|
27
|
-
value: number;
|
|
28
|
-
/**
|
|
29
|
-
* the error message to display.
|
|
30
|
-
*/
|
|
31
|
-
message: string;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
@injectable()
|
|
35
|
-
export class PreferenceNumberInputRenderer extends PreferenceLeafNodeRenderer<number, HTMLInputElement> {
|
|
36
|
-
|
|
37
|
-
protected _errorMessage: HTMLElement | undefined;
|
|
38
|
-
protected interactableWrapper: HTMLElement;
|
|
39
|
-
|
|
40
|
-
get errorMessage(): HTMLElement {
|
|
41
|
-
if (!this._errorMessage) {
|
|
42
|
-
const errorMessage = document.createElement('div');
|
|
43
|
-
errorMessage.classList.add('pref-error-notification');
|
|
44
|
-
this._errorMessage = errorMessage;
|
|
45
|
-
}
|
|
46
|
-
return this._errorMessage;
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
protected createInteractable(parent: HTMLElement): void {
|
|
50
|
-
const interactableWrapper = document.createElement('div');
|
|
51
|
-
this.interactableWrapper = interactableWrapper;
|
|
52
|
-
interactableWrapper.classList.add('pref-input-container');
|
|
53
|
-
const interactable = document.createElement('input');
|
|
54
|
-
this.interactable = interactable;
|
|
55
|
-
interactable.type = 'number';
|
|
56
|
-
interactable.step = this.preferenceNode.preference.data.type === 'integer' ? '1' : 'any';
|
|
57
|
-
interactable.classList.add('theia-input');
|
|
58
|
-
interactable.defaultValue = this.getValue()?.toString() ?? '';
|
|
59
|
-
interactable.oninput = this.handleUserInteraction.bind(this);
|
|
60
|
-
interactable.onblur = this.handleBlur.bind(this);
|
|
61
|
-
interactableWrapper.appendChild(interactable);
|
|
62
|
-
parent.appendChild(interactableWrapper);
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
protected getFallbackValue(): number {
|
|
66
|
-
return 0;
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
protected handleUserInteraction(): void {
|
|
70
|
-
const { value, message } = this.getInputValidation(this.interactable.value);
|
|
71
|
-
if (isNaN(value)) {
|
|
72
|
-
this.showErrorMessage(message);
|
|
73
|
-
} else {
|
|
74
|
-
this.hideErrorMessage();
|
|
75
|
-
this.setPreferenceWithDebounce(value);
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
protected async handleBlur(): Promise<void> {
|
|
80
|
-
this.hideErrorMessage();
|
|
81
|
-
await this.setPreferenceWithDebounce.flush();
|
|
82
|
-
this.handleValueChange();
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
protected doHandleValueChange(): void {
|
|
86
|
-
const { value } = this.interactable;
|
|
87
|
-
const currentValue = value.length ? Number(value) : NaN;
|
|
88
|
-
this.updateInspection();
|
|
89
|
-
const newValue = this.getValue() ?? '';
|
|
90
|
-
this.updateModificationStatus(newValue);
|
|
91
|
-
if (newValue !== currentValue) {
|
|
92
|
-
if (document.activeElement !== this.interactable) {
|
|
93
|
-
this.interactable.value = newValue.toString();
|
|
94
|
-
} else {
|
|
95
|
-
this.handleUserInteraction(); // give priority to the value of the input if it is focused.
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
protected getInputValidation(input: string): PreferenceNumberInputValidation {
|
|
101
|
-
const { preference: { data } } = this.preferenceNode;
|
|
102
|
-
const inputValue = Number(input);
|
|
103
|
-
const errorMessages: string[] = [];
|
|
104
|
-
|
|
105
|
-
if (input === '' || isNaN(inputValue)) {
|
|
106
|
-
return { value: NaN, message: nls.localizeByDefault('Value must be a number.') };
|
|
107
|
-
}
|
|
108
|
-
if (data.minimum && inputValue < data.minimum) {
|
|
109
|
-
errorMessages.push(nls.localizeByDefault('Value must be greater than or equal to {0}.', data.minimum));
|
|
110
|
-
};
|
|
111
|
-
if (data.maximum && inputValue > data.maximum) {
|
|
112
|
-
errorMessages.push(nls.localizeByDefault('Value must be less than or equal to {0}.', data.maximum));
|
|
113
|
-
};
|
|
114
|
-
if (data.type === 'integer' && !Number.isInteger(inputValue)) {
|
|
115
|
-
errorMessages.push(nls.localizeByDefault('Value must be an integer.'));
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
return {
|
|
119
|
-
value: errorMessages.length ? NaN : inputValue,
|
|
120
|
-
message: errorMessages.join(' ')
|
|
121
|
-
};
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
protected showErrorMessage(message: string): void {
|
|
125
|
-
this.errorMessage.textContent = message;
|
|
126
|
-
this.interactableWrapper.appendChild(this.errorMessage);
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
protected hideErrorMessage(): void {
|
|
130
|
-
this.errorMessage.remove();
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
|
|
134
|
-
@injectable()
|
|
135
|
-
export class PreferenceNumberInputRendererContribution extends PreferenceLeafNodeRendererContribution {
|
|
136
|
-
static ID = 'preference-number-input-renderer';
|
|
137
|
-
id = PreferenceNumberInputRendererContribution.ID;
|
|
138
|
-
|
|
139
|
-
canHandleLeafNode(node: Preference.LeafNode): number {
|
|
140
|
-
const type = Preference.LeafNode.getType(node);
|
|
141
|
-
return type === 'integer' || type === 'number' ? 2 : 0;
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
createLeafNodeRenderer(container: interfaces.Container): PreferenceNodeRenderer {
|
|
145
|
-
return container.get(PreferenceNumberInputRenderer);
|
|
146
|
-
}
|
|
147
|
-
}
|
|
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 { nls } from '@theia/core';
|
|
18
|
+
import { injectable, interfaces } from '@theia/core/shared/inversify';
|
|
19
|
+
import { Preference } from '../../util/preference-types';
|
|
20
|
+
import { PreferenceLeafNodeRenderer, PreferenceNodeRenderer } from './preference-node-renderer';
|
|
21
|
+
import { PreferenceLeafNodeRendererContribution } from './preference-node-renderer-creator';
|
|
22
|
+
|
|
23
|
+
interface PreferenceNumberInputValidation {
|
|
24
|
+
/**
|
|
25
|
+
* the numeric value of the input. `NaN` if there is an error.
|
|
26
|
+
*/
|
|
27
|
+
value: number;
|
|
28
|
+
/**
|
|
29
|
+
* the error message to display.
|
|
30
|
+
*/
|
|
31
|
+
message: string;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
@injectable()
|
|
35
|
+
export class PreferenceNumberInputRenderer extends PreferenceLeafNodeRenderer<number, HTMLInputElement> {
|
|
36
|
+
|
|
37
|
+
protected _errorMessage: HTMLElement | undefined;
|
|
38
|
+
protected interactableWrapper: HTMLElement;
|
|
39
|
+
|
|
40
|
+
get errorMessage(): HTMLElement {
|
|
41
|
+
if (!this._errorMessage) {
|
|
42
|
+
const errorMessage = document.createElement('div');
|
|
43
|
+
errorMessage.classList.add('pref-error-notification');
|
|
44
|
+
this._errorMessage = errorMessage;
|
|
45
|
+
}
|
|
46
|
+
return this._errorMessage;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
protected createInteractable(parent: HTMLElement): void {
|
|
50
|
+
const interactableWrapper = document.createElement('div');
|
|
51
|
+
this.interactableWrapper = interactableWrapper;
|
|
52
|
+
interactableWrapper.classList.add('pref-input-container');
|
|
53
|
+
const interactable = document.createElement('input');
|
|
54
|
+
this.interactable = interactable;
|
|
55
|
+
interactable.type = 'number';
|
|
56
|
+
interactable.step = this.preferenceNode.preference.data.type === 'integer' ? '1' : 'any';
|
|
57
|
+
interactable.classList.add('theia-input');
|
|
58
|
+
interactable.defaultValue = this.getValue()?.toString() ?? '';
|
|
59
|
+
interactable.oninput = this.handleUserInteraction.bind(this);
|
|
60
|
+
interactable.onblur = this.handleBlur.bind(this);
|
|
61
|
+
interactableWrapper.appendChild(interactable);
|
|
62
|
+
parent.appendChild(interactableWrapper);
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
protected getFallbackValue(): number {
|
|
66
|
+
return 0;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
protected handleUserInteraction(): void {
|
|
70
|
+
const { value, message } = this.getInputValidation(this.interactable.value);
|
|
71
|
+
if (isNaN(value)) {
|
|
72
|
+
this.showErrorMessage(message);
|
|
73
|
+
} else {
|
|
74
|
+
this.hideErrorMessage();
|
|
75
|
+
this.setPreferenceWithDebounce(value);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
protected async handleBlur(): Promise<void> {
|
|
80
|
+
this.hideErrorMessage();
|
|
81
|
+
await this.setPreferenceWithDebounce.flush();
|
|
82
|
+
this.handleValueChange();
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
protected doHandleValueChange(): void {
|
|
86
|
+
const { value } = this.interactable;
|
|
87
|
+
const currentValue = value.length ? Number(value) : NaN;
|
|
88
|
+
this.updateInspection();
|
|
89
|
+
const newValue = this.getValue() ?? '';
|
|
90
|
+
this.updateModificationStatus(newValue);
|
|
91
|
+
if (newValue !== currentValue) {
|
|
92
|
+
if (document.activeElement !== this.interactable) {
|
|
93
|
+
this.interactable.value = newValue.toString();
|
|
94
|
+
} else {
|
|
95
|
+
this.handleUserInteraction(); // give priority to the value of the input if it is focused.
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
protected getInputValidation(input: string): PreferenceNumberInputValidation {
|
|
101
|
+
const { preference: { data } } = this.preferenceNode;
|
|
102
|
+
const inputValue = Number(input);
|
|
103
|
+
const errorMessages: string[] = [];
|
|
104
|
+
|
|
105
|
+
if (input === '' || isNaN(inputValue)) {
|
|
106
|
+
return { value: NaN, message: nls.localizeByDefault('Value must be a number.') };
|
|
107
|
+
}
|
|
108
|
+
if (data.minimum && inputValue < data.minimum) {
|
|
109
|
+
errorMessages.push(nls.localizeByDefault('Value must be greater than or equal to {0}.', data.minimum));
|
|
110
|
+
};
|
|
111
|
+
if (data.maximum && inputValue > data.maximum) {
|
|
112
|
+
errorMessages.push(nls.localizeByDefault('Value must be less than or equal to {0}.', data.maximum));
|
|
113
|
+
};
|
|
114
|
+
if (data.type === 'integer' && !Number.isInteger(inputValue)) {
|
|
115
|
+
errorMessages.push(nls.localizeByDefault('Value must be an integer.'));
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
return {
|
|
119
|
+
value: errorMessages.length ? NaN : inputValue,
|
|
120
|
+
message: errorMessages.join(' ')
|
|
121
|
+
};
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
protected showErrorMessage(message: string): void {
|
|
125
|
+
this.errorMessage.textContent = message;
|
|
126
|
+
this.interactableWrapper.appendChild(this.errorMessage);
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
protected hideErrorMessage(): void {
|
|
130
|
+
this.errorMessage.remove();
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
@injectable()
|
|
135
|
+
export class PreferenceNumberInputRendererContribution extends PreferenceLeafNodeRendererContribution {
|
|
136
|
+
static ID = 'preference-number-input-renderer';
|
|
137
|
+
id = PreferenceNumberInputRendererContribution.ID;
|
|
138
|
+
|
|
139
|
+
canHandleLeafNode(node: Preference.LeafNode): number {
|
|
140
|
+
const type = Preference.LeafNode.getType(node);
|
|
141
|
+
return type === 'integer' || type === 'number' ? 2 : 0;
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
createLeafNodeRenderer(container: interfaces.Container): PreferenceNodeRenderer {
|
|
145
|
+
return container.get(PreferenceNumberInputRenderer);
|
|
146
|
+
}
|
|
147
|
+
}
|
|
@@ -1,131 +1,131 @@
|
|
|
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 { PreferenceLeafNodeRenderer, PreferenceNodeRenderer } from './preference-node-renderer';
|
|
18
|
-
import { injectable, interfaces } from '@theia/core/shared/inversify';
|
|
19
|
-
import { JSONValue } from '@theia/core/shared/@phosphor/coreutils';
|
|
20
|
-
import { PreferenceProvider } from '@theia/core/lib/browser/preferences/preference-provider';
|
|
21
|
-
import { SelectComponent, SelectOption } from '@theia/core/lib/browser/widgets/select-component';
|
|
22
|
-
import { Preference } from '../../util/preference-types';
|
|
23
|
-
import { PreferenceLeafNodeRendererContribution } from './preference-node-renderer-creator';
|
|
24
|
-
import * as React from '@theia/core/shared/react';
|
|
25
|
-
import { createRoot } from '@theia/core/shared/react-dom/client';
|
|
26
|
-
import { escapeInvisibleChars } from '@theia/core/lib/common/strings';
|
|
27
|
-
|
|
28
|
-
@injectable()
|
|
29
|
-
export class PreferenceSelectInputRenderer extends PreferenceLeafNodeRenderer<JSONValue, HTMLDivElement> {
|
|
30
|
-
|
|
31
|
-
protected readonly selectComponent = React.createRef<SelectComponent>();
|
|
32
|
-
|
|
33
|
-
protected selectOptions: SelectOption[] = [];
|
|
34
|
-
|
|
35
|
-
protected get enumValues(): JSONValue[] {
|
|
36
|
-
return this.preferenceNode.preference.data.enum!;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
protected updateSelectOptions(): void {
|
|
40
|
-
const updatedSelectOptions: SelectOption[] = [];
|
|
41
|
-
const values = this.enumValues;
|
|
42
|
-
const preferenceData = this.preferenceNode.preference.data;
|
|
43
|
-
const defaultValue = preferenceData.default;
|
|
44
|
-
for (let i = 0; i < values.length; i++) {
|
|
45
|
-
const value = values[i];
|
|
46
|
-
const stringValue = `${value}`;
|
|
47
|
-
const label = escapeInvisibleChars(preferenceData.enumItemLabels?.[i] ?? stringValue);
|
|
48
|
-
const detail = PreferenceProvider.deepEqual(defaultValue, value) ? 'default' : undefined;
|
|
49
|
-
let enumDescription = preferenceData.enumDescriptions?.[i];
|
|
50
|
-
let markdown = false;
|
|
51
|
-
const markdownEnumDescription = preferenceData.markdownEnumDescriptions?.[i];
|
|
52
|
-
if (markdownEnumDescription) {
|
|
53
|
-
enumDescription = this.markdownRenderer.renderInline(markdownEnumDescription);
|
|
54
|
-
markdown = true;
|
|
55
|
-
}
|
|
56
|
-
updatedSelectOptions.push({
|
|
57
|
-
label,
|
|
58
|
-
value: stringValue,
|
|
59
|
-
detail,
|
|
60
|
-
description: enumDescription,
|
|
61
|
-
markdown
|
|
62
|
-
});
|
|
63
|
-
}
|
|
64
|
-
this.selectOptions = updatedSelectOptions;
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
protected createInteractable(parent: HTMLElement): void {
|
|
68
|
-
this.updateSelectOptions();
|
|
69
|
-
const interactable = document.createElement('div');
|
|
70
|
-
const selectComponent = React.createElement(SelectComponent, {
|
|
71
|
-
options: this.selectOptions,
|
|
72
|
-
defaultValue: this.getDataValue(),
|
|
73
|
-
onChange: (_, index) => this.handleUserInteraction(index),
|
|
74
|
-
ref: this.selectComponent
|
|
75
|
-
});
|
|
76
|
-
this.interactable = interactable;
|
|
77
|
-
const root = createRoot(interactable);
|
|
78
|
-
root.render(selectComponent);
|
|
79
|
-
parent.appendChild(interactable);
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
protected getFallbackValue(): JSONValue {
|
|
83
|
-
const { default: schemaDefault, defaultValue, enum: enumValues } = this.preferenceNode.preference.data;
|
|
84
|
-
return schemaDefault !== undefined
|
|
85
|
-
? schemaDefault : defaultValue !== undefined
|
|
86
|
-
? defaultValue
|
|
87
|
-
: enumValues![0];
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
protected doHandleValueChange(): void {
|
|
91
|
-
this.updateInspection();
|
|
92
|
-
this.updateSelectOptions();
|
|
93
|
-
const newValue = this.getDataValue();
|
|
94
|
-
this.updateModificationStatus(this.getValue());
|
|
95
|
-
if (document.activeElement !== this.interactable && this.selectComponent.current) {
|
|
96
|
-
this.selectComponent.current.value = newValue;
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
/**
|
|
101
|
-
* Returns the stringified index corresponding to the currently selected value.
|
|
102
|
-
*/
|
|
103
|
-
protected getDataValue(): number {
|
|
104
|
-
const currentValue = this.getValue();
|
|
105
|
-
let selected = this.enumValues.findIndex(value => PreferenceProvider.deepEqual(value, currentValue));
|
|
106
|
-
if (selected === -1) {
|
|
107
|
-
const fallback = this.getFallbackValue();
|
|
108
|
-
selected = this.enumValues.findIndex(value => PreferenceProvider.deepEqual(value, fallback));
|
|
109
|
-
}
|
|
110
|
-
return Math.max(selected, 0);
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
protected handleUserInteraction(selected: number): void {
|
|
114
|
-
const value = this.enumValues[selected];
|
|
115
|
-
this.setPreferenceImmediately(value);
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
@injectable()
|
|
120
|
-
export class PreferenceSelectInputRendererContribution extends PreferenceLeafNodeRendererContribution {
|
|
121
|
-
static ID = 'preference-select-input-renderer';
|
|
122
|
-
id = PreferenceSelectInputRendererContribution.ID;
|
|
123
|
-
|
|
124
|
-
canHandleLeafNode(node: Preference.LeafNode): number {
|
|
125
|
-
return node.preference.data.enum ? 3 : 0;
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
createLeafNodeRenderer(container: interfaces.Container): PreferenceNodeRenderer {
|
|
129
|
-
return container.get(PreferenceSelectInputRenderer);
|
|
130
|
-
}
|
|
131
|
-
}
|
|
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 { PreferenceLeafNodeRenderer, PreferenceNodeRenderer } from './preference-node-renderer';
|
|
18
|
+
import { injectable, interfaces } from '@theia/core/shared/inversify';
|
|
19
|
+
import { JSONValue } from '@theia/core/shared/@phosphor/coreutils';
|
|
20
|
+
import { PreferenceProvider } from '@theia/core/lib/browser/preferences/preference-provider';
|
|
21
|
+
import { SelectComponent, SelectOption } from '@theia/core/lib/browser/widgets/select-component';
|
|
22
|
+
import { Preference } from '../../util/preference-types';
|
|
23
|
+
import { PreferenceLeafNodeRendererContribution } from './preference-node-renderer-creator';
|
|
24
|
+
import * as React from '@theia/core/shared/react';
|
|
25
|
+
import { createRoot } from '@theia/core/shared/react-dom/client';
|
|
26
|
+
import { escapeInvisibleChars } from '@theia/core/lib/common/strings';
|
|
27
|
+
|
|
28
|
+
@injectable()
|
|
29
|
+
export class PreferenceSelectInputRenderer extends PreferenceLeafNodeRenderer<JSONValue, HTMLDivElement> {
|
|
30
|
+
|
|
31
|
+
protected readonly selectComponent = React.createRef<SelectComponent>();
|
|
32
|
+
|
|
33
|
+
protected selectOptions: SelectOption[] = [];
|
|
34
|
+
|
|
35
|
+
protected get enumValues(): JSONValue[] {
|
|
36
|
+
return this.preferenceNode.preference.data.enum!;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
protected updateSelectOptions(): void {
|
|
40
|
+
const updatedSelectOptions: SelectOption[] = [];
|
|
41
|
+
const values = this.enumValues;
|
|
42
|
+
const preferenceData = this.preferenceNode.preference.data;
|
|
43
|
+
const defaultValue = preferenceData.default;
|
|
44
|
+
for (let i = 0; i < values.length; i++) {
|
|
45
|
+
const value = values[i];
|
|
46
|
+
const stringValue = `${value}`;
|
|
47
|
+
const label = escapeInvisibleChars(preferenceData.enumItemLabels?.[i] ?? stringValue);
|
|
48
|
+
const detail = PreferenceProvider.deepEqual(defaultValue, value) ? 'default' : undefined;
|
|
49
|
+
let enumDescription = preferenceData.enumDescriptions?.[i];
|
|
50
|
+
let markdown = false;
|
|
51
|
+
const markdownEnumDescription = preferenceData.markdownEnumDescriptions?.[i];
|
|
52
|
+
if (markdownEnumDescription) {
|
|
53
|
+
enumDescription = this.markdownRenderer.renderInline(markdownEnumDescription);
|
|
54
|
+
markdown = true;
|
|
55
|
+
}
|
|
56
|
+
updatedSelectOptions.push({
|
|
57
|
+
label,
|
|
58
|
+
value: stringValue,
|
|
59
|
+
detail,
|
|
60
|
+
description: enumDescription,
|
|
61
|
+
markdown
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
this.selectOptions = updatedSelectOptions;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
protected createInteractable(parent: HTMLElement): void {
|
|
68
|
+
this.updateSelectOptions();
|
|
69
|
+
const interactable = document.createElement('div');
|
|
70
|
+
const selectComponent = React.createElement(SelectComponent, {
|
|
71
|
+
options: this.selectOptions,
|
|
72
|
+
defaultValue: this.getDataValue(),
|
|
73
|
+
onChange: (_, index) => this.handleUserInteraction(index),
|
|
74
|
+
ref: this.selectComponent
|
|
75
|
+
});
|
|
76
|
+
this.interactable = interactable;
|
|
77
|
+
const root = createRoot(interactable);
|
|
78
|
+
root.render(selectComponent);
|
|
79
|
+
parent.appendChild(interactable);
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
protected getFallbackValue(): JSONValue {
|
|
83
|
+
const { default: schemaDefault, defaultValue, enum: enumValues } = this.preferenceNode.preference.data;
|
|
84
|
+
return schemaDefault !== undefined
|
|
85
|
+
? schemaDefault : defaultValue !== undefined
|
|
86
|
+
? defaultValue
|
|
87
|
+
: enumValues![0];
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
protected doHandleValueChange(): void {
|
|
91
|
+
this.updateInspection();
|
|
92
|
+
this.updateSelectOptions();
|
|
93
|
+
const newValue = this.getDataValue();
|
|
94
|
+
this.updateModificationStatus(this.getValue());
|
|
95
|
+
if (document.activeElement !== this.interactable && this.selectComponent.current) {
|
|
96
|
+
this.selectComponent.current.value = newValue;
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
/**
|
|
101
|
+
* Returns the stringified index corresponding to the currently selected value.
|
|
102
|
+
*/
|
|
103
|
+
protected getDataValue(): number {
|
|
104
|
+
const currentValue = this.getValue();
|
|
105
|
+
let selected = this.enumValues.findIndex(value => PreferenceProvider.deepEqual(value, currentValue));
|
|
106
|
+
if (selected === -1) {
|
|
107
|
+
const fallback = this.getFallbackValue();
|
|
108
|
+
selected = this.enumValues.findIndex(value => PreferenceProvider.deepEqual(value, fallback));
|
|
109
|
+
}
|
|
110
|
+
return Math.max(selected, 0);
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
protected handleUserInteraction(selected: number): void {
|
|
114
|
+
const value = this.enumValues[selected];
|
|
115
|
+
this.setPreferenceImmediately(value);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
@injectable()
|
|
120
|
+
export class PreferenceSelectInputRendererContribution extends PreferenceLeafNodeRendererContribution {
|
|
121
|
+
static ID = 'preference-select-input-renderer';
|
|
122
|
+
id = PreferenceSelectInputRendererContribution.ID;
|
|
123
|
+
|
|
124
|
+
canHandleLeafNode(node: Preference.LeafNode): number {
|
|
125
|
+
return node.preference.data.enum ? 3 : 0;
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
createLeafNodeRenderer(container: interfaces.Container): PreferenceNodeRenderer {
|
|
129
|
+
return container.get(PreferenceSelectInputRenderer);
|
|
130
|
+
}
|
|
131
|
+
}
|